nanachi

Crates.ionanachi
lib.rsnanachi
version0.0.4
sourcesrc
created_at2020-08-02 09:56:00.373613
updated_at2020-11-19 18:48:02.168405
description2D graphics library
homepage
repositoryhttps://github.com/carrotflakes/nanachi
max_upload_size
id272180
size14,179,512
carrotflakes (carrotflakes)

documentation

README

Nanachi - pure Rust 2D graphics library

Build Status Crates.io Documentation

NOTE: Nanachi is still buggy and the API will changed!

nanachi

Generated by cargo run --release --example nanachi

Features

  • path filling and stroking
  • color with: linear gradients, radial gradients and patterns
  • 24 composition types
  • anti-aliasing (can be disabled)
  • path transformation: translation, scaling and rotation

Example

Basic usage example is following:

use image::RgbaImage;
use nanachi::{
    compositor,
    context::{Context, FillStyle},
    fill_color, fill_rule,
    path_builder::PathBuilder,
    pixel::Rgba,
};

let (width, height) = (512, 512);

// Make a Context
let mut context = Context::from_pixel(width, height, Rgba([1.0, 1.0, 1.0, 1.0])).high_quality();

// Make a Path
let mut builder = PathBuilder::new();
builder.move_to(100.0, 100.0);
builder.line_to(200.0, 100.0);
builder.line_to(200.0, 200.0);
builder.line_to(100.0, 200.0);
builder.close();
let path = builder.end();

// Make a FillStyle for filling
let fill_style = FillStyle::new(
    fill_color::Solid::new(Rgba([1.0, 0.0, 0.0, 0.7])),
    compositor::SrcOver,
    fill_rule::NonZero,
);

// Fill the path
context.fill(&path, &fill_style);

// Make a FillStyle for stroking
let fill_style = FillStyle::new(
    fill_color::Solid::new(Rgba([0.0, 0.0, 1.0, 1.0])),
    compositor::SrcOver,
    fill_rule::NonZero,
);

// Stroke the path
context.stroke(&path, &fill_style, 8.0);

// Save the image
let img: RgbaImage = (&context.image).into();
img.save("./basic.png").unwrap();

Author

Copyright

Copyright (c) 2020 carrotflakes (carrotflakes@gmail.com)

License

Licensed under the MIT License.

Commit count: 381

cargo fmt