20 releases

0.5.5 Nov 16, 2018
0.5.4 May 16, 2018
0.5.2 Mar 22, 2018

#40 in Images

Download history 16/week @ 2019-01-18 17/week @ 2019-01-25 6/week @ 2019-02-01 17/week @ 2019-02-08 15/week @ 2019-02-15 35/week @ 2019-02-22 50/week @ 2019-03-01 21/week @ 2019-03-08 27/week @ 2019-03-15 306/week @ 2019-03-22 13/week @ 2019-03-29 34/week @ 2019-04-05 19/week @ 2019-04-12 41/week @ 2019-04-19 9/week @ 2019-04-26

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

GPL-3.0 license

50KB
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

~4MB
~83K SLoC