mirror of
https://github.com/RGBCube/serenity
synced 2025-05-28 16:05:08 +00:00
More work on the variable-width font support.
Katica is now the default system font, and it looks quite nice. :^) I'm gonna need to refine the GTextBox movement stuff eventually, but it works well-enough for basic editing now.
This commit is contained in:
parent
e53cef02d5
commit
66a5ddd94a
12 changed files with 125 additions and 30 deletions
|
@ -24,8 +24,13 @@ GFontDatabase::GFontDatabase()
|
|||
if (de->d_name[0] == '.')
|
||||
continue;
|
||||
auto path = String::format("/res/fonts/%s", de->d_name);
|
||||
if (auto font = Font::load_from_file(path))
|
||||
m_name_to_path.set(font->name(), path);
|
||||
if (auto font = Font::load_from_file(path)) {
|
||||
Metadata metadata;
|
||||
metadata.path = path;
|
||||
metadata.glyph_height = font->glyph_height();
|
||||
metadata.is_fixed_width = font->is_fixed_width();
|
||||
m_name_to_metadata.set(font->name(), move(metadata));
|
||||
}
|
||||
}
|
||||
closedir(dirp);
|
||||
}
|
||||
|
@ -36,15 +41,23 @@ GFontDatabase::~GFontDatabase()
|
|||
|
||||
void GFontDatabase::for_each_font(Function<void(const String&)> callback)
|
||||
{
|
||||
for (auto& it : m_name_to_path) {
|
||||
for (auto& it : m_name_to_metadata) {
|
||||
callback(it.key);
|
||||
}
|
||||
}
|
||||
|
||||
void GFontDatabase::for_each_fixed_width_font(Function<void(const String&)> callback)
|
||||
{
|
||||
for (auto& it : m_name_to_metadata) {
|
||||
if (it.value.is_fixed_width)
|
||||
callback(it.key);
|
||||
}
|
||||
}
|
||||
|
||||
RetainPtr<Font> GFontDatabase::get_by_name(const String& name)
|
||||
{
|
||||
auto it = m_name_to_path.find(name);
|
||||
if (it == m_name_to_path.end())
|
||||
auto it = m_name_to_metadata.find(name);
|
||||
if (it == m_name_to_metadata.end())
|
||||
return nullptr;
|
||||
return Font::load_from_file((*it).value);
|
||||
return Font::load_from_file((*it).value.path);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue