2 unstable releases
| 0.13.0 | Aug 29, 2025 |
|---|---|
| 0.1.0 | Aug 12, 2025 |
#1208 in Graphics APIs
72 downloads per month
1.5MB
7K
SLoC
rough_vello
This crate is an adapter crate between roughr and vello crates. Converts from roughr drawing primitives to vello's Scene types. Also has convenience traits for drawing onto vello scenes. For more detailed information you can check roughr crate.
Below examples are output of rough_vello adapter.
📦 Cargo.toml
[dependencies]
rough_vello = "0.1"
🔧 Example
Rust Logo
use rough_vello::VelloGenerator;
use vello::Scene;
use palette::Srgba;
use roughr::core::{FillStyle, OptionsBuilder};
let options = OptionsBuilder::default()
.stroke(Srgba::from_components((114u8, 87u8, 82u8, 255u8)).into_format())
.fill(Srgba::from_components((254u8, 246u8, 201u8, 255)).into_format())
.fill_style(FillStyle::Hachure)
.fill_weight(1.0)
.bowing(0.8)
.build()
.unwrap();
let generator = VelloGenerator::new(options);
let rust_logo_svg_path = "..."; // SVG path data for the Rust logo
let rust_logo_drawing = generator.path::<f32>(rust_logo_svg_path);
let mut scene = Scene::new();
rust_logo_drawing.draw(&mut scene);
🖨️ Output Rust Logo

Filler Implementation Status
- Hachure
- Zigzag
- Cross-Hatch
- Dots
- Dashed
- Zigzag-Line
🔭 Examples
For more examples have a look at the examples folder.
🔌 Integration
Bevy Integration
For Bevy game engine integration, you can use bevy_vello which provides a Bevy plugin for vello. This allows you to render rough_vello drawings directly in your Bevy applications by converting the vello Scene to Bevy-compatible rendering.
[dependencies]
rough_vello = "0.1"
bevy_vello = "0.1" # Check latest version
bevy = "0.14" # Or latest compatible version
📝 License
Licensed under MIT License (LICENSE).
🚧 Contributions
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the MIT license, shall be licensed as above, without any additional terms or conditions.
Dependencies
~14–46MB
~703K SLoC