-
-
Notifications
You must be signed in to change notification settings - Fork 221
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement dynamic font support
/font/<name>/<start>-<end>
This will NOT compile until stadiamaps/sdf_font_tools#13 is merged and published This implements dynamic font protobuf generation, allowing users to request font ranges on the fly, and combining them in any order, e.g. `Font1,Font2,Font3`, same as with sprites and tiles This is a first iteration, without any multithreading support. In theory, this could be done far faster by generating SDFs with multiple threads. Current steps: * during init, figure out all glyphs available in each font, and store them as a bitset * during request: * combine requested bitsets to figure out which glyph should come from which font file * load those glyphs from files (using a single instance of the freetype lib) * convert them to SDFs and package them into a protobuf
- Loading branch information
Showing
11 changed files
with
680 additions
and
4 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
use std::path::PathBuf; | ||
|
||
use log::error; | ||
use pbf_font_tools::freetype::Library; | ||
|
||
fn main() { | ||
let _ = env_logger::builder().is_test(true).try_init(); | ||
error!("abc {}", foo()); | ||
let lib = Library::init().expect("Unable to initialize FreeType"); | ||
visit_dirs(&lib, PathBuf::from("/usr/share/fonts/opentype/noto")); | ||
visit_dirs(&lib, PathBuf::from("/usr/share/fonts")); | ||
} | ||
|
||
fn foo() -> &'static str { | ||
println!("foo"); | ||
"bar" | ||
} | ||
|
||
fn visit_dirs(lib: &Library, path: PathBuf) { | ||
for dir_entry in path | ||
.read_dir() | ||
.expect("Unable to open font directory") | ||
.flatten() | ||
{ | ||
let path = dir_entry.path(); | ||
if path.is_dir() { | ||
visit_dirs(lib, path); | ||
continue; | ||
} | ||
|
||
if !matches!(path.extension(), Some(e) if (["otf", "ttf", "ttc"].contains(&e.to_str().unwrap()))) | ||
{ | ||
continue; | ||
} | ||
|
||
let mut face = lib.new_face(&path, 0).expect("Unable to load face"); | ||
let num_faces = face.num_faces() as usize; | ||
print!("{}: {} faces: ", path.display(), num_faces); | ||
for i in 0..num_faces { | ||
if i > 0 { | ||
face = lib | ||
.new_face(&path, i as isize) | ||
.expect("Unable to load face"); | ||
} | ||
// print!("\n #{}: {:?} ", i, face.raw()); | ||
print!( | ||
" #{}={}-{} face_index={}, num_glyphs={}", | ||
i, | ||
face.family_name() | ||
.as_deref() | ||
// .map(|v| v.as_str()) | ||
.unwrap_or("<family>"), | ||
face.style_name() | ||
.as_deref() | ||
// .map(|v| v.as_str()) | ||
.unwrap_or("<style>"), | ||
face.raw().face_index, | ||
face.num_glyphs(), | ||
); | ||
} | ||
println!(); | ||
} | ||
} |
Oops, something went wrong.