# bevy_terminal_display [![Crates](https://img.shields.io/crates/v/bevy_terminal_display)](https://crates.io/crates/bevy_terminal_display) ![License](https://img.shields.io/badge/license-0BSD%2FMIT%2FApache-blue.svg) ![Tag](https://img.shields.io/github/v/tag/exvacuum/bevy_terminal_display) [![Docs](https://img.shields.io/website?url=https%3A%2F%2Fexvacuum.github.io%2Fbevy_terminal_display%2F&label=docs)](https://exvacuum.github.io/bevy_terminal_display) A (very experimental) plugin for the [Bevy](https://bevyengine.org) engine which allows for rendering to a terminal window. WARNING: I highly recommend using the kitty terminal emulator with this, not only due to the gpu-accelerated rendering, but also the implementation of the kitty protocol which enables the advanced input detection. Features Include: - `TerminalDisplay` automatically sets up a correctly-formatted render texture - Post-process dithers colors to pure black and white, which are then printed as braille characters to the terminal - Responsiveness to terminal window resizing - `TerminalInput` resource which keeps track of pressed & released keys - `Widget` component for rendering ratatui TUI widgets - `TerminalWidget` trait for creating custom TUI widget components - Log redirection ## Screenshots ![](https://git.exvacuum.dev/bevy_terminal_display/plain/doc/screenshot.png) ## Compatibility | Crate Version | Bevy Version | | ------------- | ------------ | | 0.6 | 0.15 | | 0.4 | 0.14 | | 0.2 | 0.13 | ## Installation ### crates.io ```toml [dependencies] bevy_terminal_display = "0.5" ``` ### Using git URL in Cargo.toml ```toml [dependencies.bevy_terminal_display] git = "https://git.exvacuum.dev/bevy_terminal_display" ``` ## Example Usage In `main.rs`: ```rs use bevy::prelude::*; use bevy_terminal_display; fn main() { App::new() .add_plugins(( DefaultPlugins.build().disable::().disable::, ScheduleRunnerPlugin::run_loop(Duration::from_secs_f32(1.0 / 60.0)), bevy_terminal_display::TerminalDisplayPlugin::default(), )) .run(); } ``` When spawning a camera: ```rs commands.spawn(( // Camera3d... TerminalDisplay(3), // Field is level of dithering )); ``` ## License This crate is licensed under your choice of 0BSD, Apache-2.0, or MIT license.