rasterization

Crates.iorasterization
lib.rsrasterization
version0.2.0
sourcesrc
created_at2024-09-08 19:27:43.945465
updated_at2024-09-16 16:51:59.839081
descriptionIterator and iterator adapters for rasterizing a circle and its parts.
homepagehttps://github.com/pic16f877ccs/rasterization
repositoryhttps://github.com/pic16f877ccs/rasterization
max_upload_size
id1368479
size260,207
(pic16f877ccs)

documentation

README

Rasterization

This crate provides iterators and adapters for generating sequential coordinates for various shapes of a circle or its parts using Bresenham's algorithm.

Gallery

Visual examples of different shapes:



Examples

Here's how to use the crate:

use rasterization::{Rasterization, SemicircleFilled, DirectionGradient::Bottom};

let radius = 128_usize;
let iter = SemicircleFilled::<i32>::new(radius)
    .circle()
    .offset(radius as i32, radius as i32);

let iter = SemicircleFilled::<i32>::new(radius)
    .circle_long(-128, 0)
    .offset((radius * 2) as i32, radius as i32);

let iter = SemicircleFilled::<i32>::new(radius)
    .semicircle_top()
    .offset(radius as i32, radius as i32);

let iter = SemicircleFilled::<i32>::new(radius)
    .semicircle_bottom()
    .offset(radius as i32, radius as i32);

let iter = SemicircleFilled::<i32>::new(radius)
    .circle()
    .offset(radius as i32, radius as i32)
    .gradient(radius as i32, radius * 2, Bottom(colorous::BROWN_GREEN));

Installation

Add the following to your Cargo.toml:

[dependencies]
rasterization = "0.2.0"

License

This project is licensed under the MIT License.

Commit count: 0

cargo fmt