24 releases

✓ Uses Rust 2018 edition

0.5.9 Feb 12, 2020
0.5.7 Dec 30, 2019
0.5.6 Jul 28, 2019
0.5.5 Nov 16, 2018
0.5.2 Mar 22, 2018

#6 in Data formats

Download history 68/week @ 2019-11-01 8/week @ 2019-11-08 53/week @ 2019-11-15 28/week @ 2019-11-22 55/week @ 2019-11-29 113/week @ 2019-12-06 784/week @ 2019-12-13 3/week @ 2019-12-20 172/week @ 2019-12-27 13/week @ 2020-01-03 82/week @ 2020-01-10 54/week @ 2020-01-17 12/week @ 2020-01-24 89/week @ 2020-01-31 239/week @ 2020-02-07

537 downloads per month
Used in 7 crates (5 directly)

GPL-3.0 license

57KB
445 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
~96K SLoC