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

#4 in Data formats

Download history 20/week @ 2019-04-14 39/week @ 2019-04-21 31/week @ 2019-04-28 28/week @ 2019-05-05 51/week @ 2019-05-12 49/week @ 2019-05-19 44/week @ 2019-05-26 43/week @ 2019-06-02 74/week @ 2019-06-09 62/week @ 2019-06-16 292/week @ 2019-06-23 115/week @ 2019-06-30 97/week @ 2019-07-07 13/week @ 2019-07-14 50/week @ 2019-07-21

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

~4MB
~85K SLoC