#barcode #qrcode #scanner #scan #zbar

sys zbar-rust

High-level and low-level ZBar binding for the Rust language

21 releases

0.0.24 Aug 11, 2024
0.0.23 Dec 15, 2023
0.0.21 Nov 29, 2022
0.0.20 Jul 23, 2022
0.0.5 Nov 14, 2018

#880 in Encoding

Download history 278/week @ 2024-08-25 618/week @ 2024-09-01 681/week @ 2024-09-08 695/week @ 2024-09-15 1855/week @ 2024-09-22 477/week @ 2024-09-29 544/week @ 2024-10-06 539/week @ 2024-10-13 313/week @ 2024-10-20 520/week @ 2024-10-27 144/week @ 2024-11-03 199/week @ 2024-11-10 262/week @ 2024-11-17 304/week @ 2024-11-24 620/week @ 2024-12-01 2936/week @ 2024-12-08

4,133 downloads per month
Used in openpgp-paper-backup

LGPL-2.1

24KB
490 lines

ZBar Rust

CI

High-level and low-level ZBar binding for the Rust language.

Compilation

To compile this crate, you need to compile the ZBar library first. You can install ZBar in your operating system, or in somewhere in your file system. As for the latter, you need to set the following environment variables to link the ZBar library:

  • ZBAR_LIB_DIRS: The directories of library files, like -L. Use : to separate.
  • ZBAR_LIBS: The library names that you want to link, like -l. Use : to separate. Typically, it is iconv:zbar.
  • ZBAR_INCLUDE_DIRS: The directories of header files, like -i. Use : to separate.

Examples

use zbar_rust::ZBarImageScanner;

use image::GenericImageView;

let img = image::open(INPUT_IMAGE_PATH).unwrap();

let (width, height) = img.dimensions();

let mut scanner = ZBarImageScanner::new();

let mut results = scanner.scan_y800(img.into_luma8().into_raw(), width, height).unwrap();

for result in results {
    println!("{}", String::from_utf8(result.data).unwrap())
}

More examples are in the examples folder.

Crates.io

https://crates.io/crates/zbar-rust

Documentation

https://docs.rs/zbar-rust

License

LGPL-2.1

Dependencies

~64KB