10 releases

0.3.2 Jan 3, 2025
0.3.1 Jan 31, 2024
0.3.0 Nov 29, 2023
0.2.3 Sep 29, 2023
0.1.2 Oct 11, 2020

#16 in Graphics APIs

Download history 20748/week @ 2024-09-22 21790/week @ 2024-09-29 21929/week @ 2024-10-06 19111/week @ 2024-10-13 15612/week @ 2024-10-20 18986/week @ 2024-10-27 18115/week @ 2024-11-03 17471/week @ 2024-11-10 18529/week @ 2024-11-17 17714/week @ 2024-11-24 23157/week @ 2024-12-01 19174/week @ 2024-12-08 20832/week @ 2024-12-15 15393/week @ 2024-12-22 19829/week @ 2024-12-29 26847/week @ 2025-01-05

84,969 downloads per month
Used in 12 crates (8 directly)

Apache-2.0 OR MIT

195KB
5K SLoC

zeno

Zeno is a pure Rust crate that provides a high performance, low level 2D rasterization library with support for rendering paths of various styles into alpha or subpixel masks.

Crates.io Docs.rs Apache 2.0 or MIT license.

Features

  • 256x anti-aliased rasterization (8-bit alpha or 32-bit RGBA subpixel alpha)
  • Pixel perfect hit testing with customizable coverage threshold
  • Non-zero and even-odd fills
  • Stroking with the standard set of joins and caps (separate start and end caps are possible)
  • Numerically stable dashing for smooth dash offset animation
  • Vertex traversal for marker placement
  • Stepped distance traversal for animation or text-on-path support
  • Abstract representation of path data that imposes no policy on storage

Usage

Rendering a dashed stroke of a triangle:

use zeno::{Cap, Join, Mask, PathData, Stroke};

// Buffer to store the mask
let mut mask = [0u8; 64 * 64];

/// Create a mask builder with some path data
Mask::new("M 8,56 32,8 56,56 Z")
    .style(
        // Stroke style with a width of 4
        Stroke::new(4.0)
            // Round line joins
            .join(Join::Round)
            // And round line caps
            .cap(Cap::Round)
            // Dash pattern followed by a dash offset
            .dash(&[10.0, 12.0, 0.0], 0.0),
    )
    // Set the target dimensions
    .size(64, 64)
    // Render into the target buffer
    .render_into(&mut mask, None);

Resulting in the following mask:

Dashed Triangle

For detail on additional features and more advanced usage, see the full API documentation.

License

Licensed under either of

at your option.

Contribution

Contributions are welcome by pull request. The Rust code of conduct applies.

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 licensed as above, without any additional terms or conditions.

Dependencies

~99KB