The simulator can be used to test and debug embedded-graphics code, or produce examples and interactive demos to show off embedded graphics features.
More simulator examples can be found in the examples repository.
use embedded_graphics::{
pixelcolor::BinaryColor,
prelude::*,
primitives::{Circle, Line, Rectangle, PrimitiveStyle},
mono_font::{ascii::Font6x9, MonoTextStyle},
text::Text,
};
use embedded_graphics_simulator::{BinaryColorTheme, SimulatorDisplay, Window, OutputSettingsBuilder};
fn main() -> Result<(), core::convert::Infallible> {
let mut display: SimulatorDisplay<BinaryColor> = SimulatorDisplay::new(Size::new(128, 64));
let line_style = PrimitiveStyle::with_stroke(BinaryColor::On, 1);
Circle::new(Point::new(72, 8), 48)
.into_styled(line_style)
.draw(&mut display)?;
Line::new(Point::new(48, 16), Point::new(8, 16))
.into_styled(line_style)
.draw(&mut display)?;
Line::new(Point::new(48, 16), Point::new(64, 32))
.into_styled(line_style)
.draw(&mut display)?;
Rectangle::new(Point::new(79, 15), Size::new(34, 34))
.into_styled(line_style)
.draw(&mut display)?;
Text::new("Hello World!", Point::new(5, 5))
.into_styled(MonoTextStyle::new(Font6x9, BinaryColor::On))
.draw(&mut display)?;
let output_settings = OutputSettingsBuilder::new()
.theme(BinaryColorTheme::OledBlue)
.build();
Window::new("Hello World", &output_settings).show_static(&display);
Ok(())
}
The simulator uses SDL2 and its development libraries which must be installed to build and run it.
sudo apt install libsdl2-dev
brew install sdl2
The Windows install process is a bit more involved, but it does work. See the Rust-SDL2 crate's README for instructions. There are multiple ways to get it working, but probably the simplest method is copying the binaries as shown here.
Screenshots of programs, that use Window
to display a simulated display, can be created by
setting the EG_SIMULATOR_DUMP
environment variable:
EG_SIMULATOR_DUMP=screenshot.png cargo run
By setting the variable the display passed to the first Window::update
call gets exported as a
PNG file to the specified path. After the file is exported the process is terminated.
If a program doesn't require to display a window and only needs to export one or more images, a
SimulatorDisplay
can also be converted to an image
crate ImageBuffer
by using the
to_image_buffer
method. The resulting buffer can then be used to save the display content to
any format supported by image
.
When the simulator is used in headless/CI environments that don't require showing a window, SDL2 support can be disabled. This removes the requirement of SDL2 being installed on the target machine, but still allows the simulator to be used to generate images.
The with-sdl
feature is enabled by default and can be disabled by adding default-features = false
to the dependency:
[dependencies.embedded-graphics-simulator]
version = "0.2.0"
default-features = false
See the Choosing Features Cargo manifest documentation for more details.
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.