diff options
author | Silas Bartha <silas@exvacuum.dev> | 2024-04-26 01:27:13 -0400 |
---|---|---|
committer | Silas Bartha <silas@exvacuum.dev> | 2024-04-26 01:27:13 -0400 |
commit | 646db8328611f21a5850cc9834b6c72bfdf0c829 (patch) | |
tree | 0d65f0c20b70da007aab141cfe6b123119e8c909 /README.md |
Initial Commitv0.1.0
Diffstat (limited to 'README.md')
-rw-r--r-- | README.md | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/README.md b/README.md new file mode 100644 index 0000000..a8e1687 --- /dev/null +++ b/README.md @@ -0,0 +1,71 @@ +# grex_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: +- `TerminalDisplayBundle` 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 +- Keyboard input enhancements using kitty protocol + +Future Goals: +- Find a way to integrate into a TUI library like ratatui for more interaction options. +- Move kitty enhancements to a feature maybe + +## Screenshots +![](./doc/screenshot.png) +## Compatibility + +| Crate Version | Bevy Version | +|--- |--- | +| 0.1 | 0.13 | + +## Installation + +### Using git URL in Cargo.toml +```toml +[dependencies.grex_terminal_display] +git = "https://github.com/exvacuum/grex_terminal_display.git" +``` + +## Example Usage + +In `main.rs`: +```rs +use bevy::prelude::*; +use grex_terminal_display; + +fn main() { + App::new() + .add_plugins(( + DefaultPlugins.build().disable::<WinitPlugin>(), + ScheduleRunnerPlugin::run_loop(Duration::from_secs_f32(1.0 / 60.0)), + grex_terminal_display::TerminalDisplayPlugin, + )) + .insert_resource(Msaa::Off) // For post-process + .run(); +} +``` + +When spawning a camera: +```rs +let terminal_display_bundle = grex_terminal_display::components::TerminalDisplayBundle::new(3, &asset_server); + +commands.spawn(( + Camera3dBundle { + camera: Camera { + target: terminal_display_bundle.image_handle().into(), + ..Default::default() + }, + ..Default::default() + }, + terminal_display_bundle, +)); +``` + + + |