#qrcode #monochrome #bitmap #bmp #codec #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

#600 in Images

Download history 274/week @ 2024-11-21 220/week @ 2024-11-28 347/week @ 2024-12-05 415/week @ 2024-12-12 389/week @ 2024-12-19 66/week @ 2024-12-26 207/week @ 2025-01-02 238/week @ 2025-01-09 329/week @ 2025-01-16 278/week @ 2025-01-23 416/week @ 2025-01-30 285/week @ 2025-02-06 484/week @ 2025-02-13 599/week @ 2025-02-20 402/week @ 2025-02-27 609/week @ 2025-03-06

2,128 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