Barcoders is a barcode-encoding library for the Rust programming language.
Barcoders allows you to encode valid data for a chosen barcode symbology into a Vec<u8>
representation of the underlying binary structure. From here, you can take advantage of one of the optional builtin generators (for exporting to SVG, GIF, PNG, etc) or build your own.
For encode-only functionality (e.g if you just want to translate a String
into a Vec<u8>
of binary digits):
toml
[dependencies]
barcoders = "0.5.1"
If you want to generate barcodes into a particular format, turn on the appropriate features:
toml
[dependencies]
barcoders = {version = "0.5.1", features = ["ascii", "svg"]}
Each generator is an optional feature so you only need to compile what you want to use. See below for the feature associated to the generation functionality you desire.
Documentation and examples are available here.
The ultimate goal of Barcoders is to provide encoding support for all major (and many not-so-major) symbologies.
ascii
)svg
)image
)image
)image
)```rust extern crate barcoders;
use barcoders::sym::ean13::*;
// Each encoder accepts a String to be encoded. Valid data is barcode-specific
// and thus constructors return an Result
// The encode
method returns a Vec
```rust extern crate barcoders;
use barcoders::sym::code39::; use barcoders::generators::image::; use std::io::prelude::*; use std::io::BufWriter; use std::fs::File; use std::path::Path;
let barcode = Code39::new("1ISTHELONELIESTNUMBER".to_owned()).unwrap(); let png = Image::PNG{height: 80, xdim: 1, rotation: Rotation::Zero}; let encoded = barcode.encode();
// Image generators return a Result
// Which you can then save to disk. let file = File::create(&Path::new("my_barcode.png")).unwrap(); let mut writer = BufWriter::new(file); writer.write(&bytes[..]).unwrap();
// Generated file ↓ ↓ ↓
```
SVG is similar to the other image types, but I've supplied it as a separate feature as it doesn't require third-party dependencies.
```rust extern crate barcoders;
use barcoders::sym::code39::; use barcoders::generators::svg::; use std::io::prelude::*; use std::io::BufWriter; use std::fs::File; use std::path::Path;
let barcode = Code39::new("56DFU4A777H".to_owned()).unwrap(); let svg = SVG{height: 200, xdim: 3}; let encoded = barcode.encode(); let data: String = svg.generate(&encoded).unwrap();
let file = File::create(&Path::new("mybarcode.svg")).unwrap(); let mut writer = BufWriter::new(file); writer.write(data.asbytes()).unwrap(); ```
```rust extern crate barcoders;
use barcoders::sym::ean13::; use barcoders::generators::ascii::;
let barcode = EAN13::new("750103131130".to_owned()).unwrap(); let encoded = barcode.encode();
// The ASCII generator is useful for testing purposes. let ascii = ASCII::new(); ascii.generate(&encoded[..]);
assert_eq!(ascii.unwrap(), "
".trim().to_owned()); ```
Note, if you want to output actual image/svg files to the filesystem, set the WRITE_TO_FILE
variable in
the appropriate test modules.
Full suite:
$ cargo test --features="image svg ascii"
Encoding only:
$ cargo test
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.