21 releases

0.5.6 Jul 28, 2019
0.5.5 Nov 16, 2018
0.5.4 May 16, 2018
0.5.2 Mar 22, 2018

#7 in Data formats

Download history 7/week @ 2019-08-13 28/week @ 2019-08-20 71/week @ 2019-08-27 77/week @ 2019-09-03 28/week @ 2019-09-10 291/week @ 2019-09-17 86/week @ 2019-09-24 39/week @ 2019-10-01 13/week @ 2019-10-08 29/week @ 2019-10-15 172/week @ 2019-10-22 29/week @ 2019-10-29 46/week @ 2019-11-05 9/week @ 2019-11-12 72/week @ 2019-11-19

316 downloads per month
Used in 4 crates (3 directly)

GPL-3.0 license

56KB
384 lines

blit

A Rust library for blitting 2D sprites

Build Status Cargo License: GPL-3.0 Downloads

Documentation

Usage

Add this to your Cargo.toml:

[dependencies]
blit = "0.5"

And this to your crate root:

extern crate blit;

Run the example

On Linux you need the xorg-dev package as required by minifb. sudo apt install xorg-dev

cargo run --example smiley

This should produce the following window:

Example

Examples

extern crate image;

use blit::*;

const WIDTH: usize = 180;
const HEIGHT: usize = 180;
const MASK_COLOR: u32 = 0xFF00FF;

let mut buffer: Vec<u32> = vec![0xFFFFFFFF; WIDTH * HEIGHT];

let img = image::open("examples/smiley.png").unwrap();
let img_rgb = img.as_rgb8().unwrap();

// Blit directly to the buffer
let pos = (0, 0);
img_rgb.blit(&mut buffer, WIDTH, pos, Color::from_u32(MASK_COLOR));

// Blit by creating a special blitting buffer first, this has some initial
// overhead but is a lot faster after multiple calls
let blit_buffer = img_rgb.to_blit_buffer(Color::from_u32(MASK_COLOR));

let pos = (10, 10);
blit_buffer.blit(&mut buffer, WIDTH, pos);
let pos = (20, 20);
blit_buffer.blit(&mut buffer, WIDTH, pos);

// Save the blit buffer to a file
blit_buffer.save("smiley.blit");

Dependencies

~4.5MB
~92K SLoC