#codec #qrcode #monochrome #bitmap #bmp #codes #monochromatic

bmp-monochrome

Encode and decode monochromatic bitmaps without additional dependencies, useful for QR codes

17 releases (2 stable)

1.1.0 May 9, 2023
1.0.0 Oct 28, 2020
0.17.0 Oct 25, 2020

#904 in Images

Download history 280/week @ 2024-11-15 239/week @ 2024-11-22 298/week @ 2024-11-29 325/week @ 2024-12-06 433/week @ 2024-12-13 285/week @ 2024-12-20 83/week @ 2024-12-27 224/week @ 2025-01-03 238/week @ 2025-01-10 348/week @ 2025-01-17 259/week @ 2025-01-24 451/week @ 2025-01-31 302/week @ 2025-02-07 458/week @ 2025-02-14 641/week @ 2025-02-21 359/week @ 2025-02-28

1,830 downloads per month
Used in 17 crates (via qr_code)

MIT license

36KB
813 lines

bmp-monochrome

crates.io

Encode and decode monochromatic bitmaps without additional dependencies, useful for QR codes.

Example

use bmp_monochrome::Bmp;
use std::error::Error;
use std::fs::File;

fn main() -> Result<(), Box<dyn Error>> {
    let file_name = "test.bmp";
    let width = 21;
    let data: Vec<bool> = (0..width * width).map(|e| e % 2 == 0).collect();
    let rows: Vec<Vec<bool>> = data.chunks(width).map(|e| e.to_vec()).collect();
    let bmp = Bmp::new(rows)?;
    bmp.write(File::create(file_name)?)?;
    let bmp_read = Bmp::read(File::open(file_name)?)?;
    assert_eq!(bmp, bmp_read);
    Ok(())
}

Generates

test

Minimum Supported Rust Version (MSRV)

Rust 1.34

Use u32::try_from introduced in 1.34.0


lib.rs:

BMP monochrome

This library encode and decode monochromatic bitmap with no extra dependencies. Especially useful to encode QR-codes

Dependencies

~0–610KB
~13K SLoC