27 releases

0.5.12 Mar 8, 2020
0.5.9 Feb 12, 2020
0.5.7 Dec 30, 2019
0.5.6 Jul 28, 2019
0.5.2 Mar 22, 2018

#5 in Data formats

Download history 99/week @ 2020-06-01 6/week @ 2020-06-08 11/week @ 2020-06-15 13/week @ 2020-06-22 45/week @ 2020-06-29 100/week @ 2020-07-06 63/week @ 2020-07-13 24/week @ 2020-07-20 34/week @ 2020-07-27 7/week @ 2020-08-03 105/week @ 2020-08-10 100/week @ 2020-08-17 73/week @ 2020-08-24 53/week @ 2020-08-31 108/week @ 2020-09-07 78/week @ 2020-09-14

907 downloads per month
Used in 8 crates (5 directly)

GPL-3.0 license

61KB
495 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

~5MB
~109K SLoC