6 releases (3 breaking)
0.3.0 | Dec 7, 2024 |
---|---|
0.2.1 | Nov 23, 2024 |
0.2.0 | Oct 31, 2024 |
0.1.0 | Oct 27, 2024 |
0.0.2 | Oct 26, 2024 |
#1171 in Text processing
36KB
528 lines
A very simple and concrete parser for *.spf
(SimplePixelFont) files for Rust. spf.rs provides
simple encoding and decoding for the *.spf
binary representation through a Vec<u8>
. And also
includes optional features to conveniently create a texture from a font rendering, which
can then be used in your favorite game engine or graphics framework.
Example
Creates a new SimplePixelFont
struct and adds the characters o
, w
, and 😊
.
use spf::core::*;
fn main() {
let mut font = SimplePixelFont::new(
ConfigurationFlags {
0: ALIGNMENT_HEIGHT,
..Default::default()
},
ModifierFlags {
..Default::default()
},
4,
);
font.add_character(Character::inferred(
'o',
Bitmap::inferred(&[
true, true, true, true,
true, false, false, true,
true, false, false, true,
true, true, true, true,
]),
));
font.add_character(Character::inferred(
'w',
Bitmap::inferred(&[
true, false, true, false, true,
true, false, true, false, true,
true, false, true, false, true,
true, true, true, true, true,
]),
));
font.add_character(Character::inferred(
'😊',
Bitmap::inferred(&[
false, true, true, false,
false, false, false, false,
true, false, false, true,
false, true, true, false,
]),
));
}
We can then encode the struct and use std::fs
to write to a file:
let mut file = std::fs::OpenOptions::new()
.write(true)
.create(true)
.open("./utf8ToyFont.spf")
.unwrap();
file.write_all(&font.to_vec_u8()).unwrap();
Or we can load an exsisting .spf file using std::fs
aswell:
let mut file = std::fs::OpenOptions::new()
.read(true)
.open("./utf8ToyFont.spf")
.unwrap();
let mut buffer: Vec<u8> = vec![];
file.read_to_end(&mut buffer).unwrap();
let font = SimplePixelFont::from_vec_u8(buffer);
Supported File Properties
Flag | Type | Stability | Notes |
---|---|---|---|
Alignment | Configuration | ⚠️ | Only height-aligned fonts are supported |
Compact | Modifier | ❌ | Planned for v0.4 |
Key:
⚠️
= Work in progress❌
= Not implemented✔
= Stable