13 releases (breaking)
Uses new Rust 2021
|0.9.0||Jan 1, 2022|
|0.8.0||Nov 16, 2021|
|0.7.0||Oct 8, 2021|
|0.5.0||Jul 17, 2021|
|0.0.2||Nov 4, 2019|
#3 in Rendering
2,807 downloads per month
Used in 21 crates (20 directly)
A tiny hardware-accelerated pixel frame buffer. 🦀
Rapidly prototype a simple 2D game, pixel-based animations, software renderers, or an emulator for your favorite platform. Then add shaders to simulate a CRT or just to spice it up with some nice VFX.
pixels is more than just a library to push pixels to a screen, but less than a full framework. You're in charge of managing a window environment, event loop, and input handling.
The Minimum Supported Rust Version for
pixels will always be made available in the MSRV.md file on GitHub.
- Built on modern graphics APIs powered by
wgpu: Vulkan, Metal, DirectX 12, OpenGL ES3.
- DirectX 11, WebGL2, and WebGPU support are a work in progress.
- Use your own custom shaders for special effects.
- Hardware accelerated scaling on perfect pixel boundaries.
- Supports non-square pixel aspect ratios. (WIP)
- Conway's Game of Life
- Custom Shader
- Dear ImGui example with
- Egui example with
- Minimal example for WebGL2
- Minimal example with SDL2
- Minimal example with
- Minimal example with
- Pixel Invaders
resolver = "2"
Perhaps a better alternative is specifying
edition = "2021", especially if you are starting a new project with Rust
1.56.0 or later.
The most common issue is having an outdated graphics driver installed on the host machine.
requests a low power (aka integrated) GPU by default. If the examples are not working for any reason, you may try setting the
WGPU_POWER_PREF=high environment variable to see if that addresses the issue on your host machine.
You should also try to keep your graphics drivers up-to-date, especially if you have an old Intel integrated GPU. Keep in mind that some drivers and GPUs are EOL and will not be supported.
You may want to use the
RUST_LOG environment variable (see
env_logger for full documentation) to gain additional insight while troubleshooting the examples.
RUST_LOG=trace will spew all logs to
stderr on debug builds:
$ RUST_LOG=trace cargo run --package minimal-winit
And also on release builds when default features are disabled:
$ RUST_LOG=trace cargo run --package minimal-winit --release --no-default-features
minifb crate shares some similarities with
pixels; it also allows rapid prototyping of 2D games and emulators. But it requires the use of its own window/GUI management, event loop, and input handling. One of the disadvantages with the
minifb approach is the lack of hardware acceleration (except on macOS, which uses Metal but is not configurable). An advantage is that it relies on fewer dependencies.