mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-08 18:09:45 +01:00
Add some more preparation for multi-font support and proper unloading
find_font_by_name() just finds the index of a given font name. This index is supposed to be stored and reused, because the font (for a language/level) won't be changed very often. So this function would only run when getting the language metadata, when loading a level, etc.
This commit is contained in:
parent
83d645c8e3
commit
29a3789dec
2 changed files with 65 additions and 12 deletions
|
@ -161,6 +161,7 @@ static size_t load_font(FontContainer* container, const char* name)
|
|||
SDL_snprintf(name_png, sizeof(name_png), "graphics/%s.png", name);
|
||||
SDL_snprintf(name_txt, sizeof(name_txt), "graphics/%s.txt", name);
|
||||
SDL_snprintf(name_xml, sizeof(name_xml), "graphics/%s.fontmeta", name);
|
||||
SDL_strlcpy(f->name, name, sizeof(f->name));
|
||||
|
||||
f->glyph_w = 8;
|
||||
f->glyph_h = 8;
|
||||
|
@ -323,6 +324,38 @@ static size_t load_font(FontContainer* container, const char* name)
|
|||
return f_idx;
|
||||
}
|
||||
|
||||
static bool find_font_by_name(FontContainer* container, const char* name, size_t* idx)
|
||||
{
|
||||
// Returns true if font found (and idx is set), false if not found
|
||||
|
||||
for (size_t i = 0; i < container->count; i++)
|
||||
{
|
||||
if (SDL_strcmp(name, container->fonts[i].name) == 0)
|
||||
{
|
||||
*idx = i;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
static void set_custom_font(const char* name)
|
||||
{
|
||||
/* Apply the choice for a certain level-specific font */
|
||||
if (find_font_by_name(&fonts_custom, name, &font_idx_custom))
|
||||
{
|
||||
font_idx_custom_is_custom = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
font_idx_custom_is_custom = false;
|
||||
if (!find_font_by_name(&fonts_main, name, &font_idx_custom))
|
||||
{
|
||||
font_idx_custom = font_idx_8x8;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void load_font_filename(bool is_custom, const char* filename)
|
||||
{
|
||||
// Load font.png, and everything that matches *.fontmeta (but not font.fontmeta)
|
||||
|
@ -338,9 +371,9 @@ static void load_font_filename(bool is_custom, const char* filename)
|
|||
}
|
||||
if (is_fontpng || (endsWith(filename, ".fontmeta") && SDL_strcmp(filename, "font.fontmeta") != 0))
|
||||
{
|
||||
char font_name[128];
|
||||
char font_name[64];
|
||||
SDL_strlcpy(font_name, filename, sizeof(font_name));
|
||||
font_name[SDL_min(127, expected_ext_start)] = '\0';
|
||||
font_name[SDL_min(63, expected_ext_start)] = '\0';
|
||||
|
||||
size_t f_idx = load_font(is_custom ? &fonts_custom : &fonts_main, font_name);
|
||||
|
||||
|
@ -375,19 +408,12 @@ void load_custom(void)
|
|||
}
|
||||
FILESYSTEM_freeEnumerate(&handle);
|
||||
|
||||
// TODO: decide font_idx_custom
|
||||
// TODO: here instead of "font", fill in the font chosen by the level
|
||||
set_custom_font("font");
|
||||
}
|
||||
|
||||
void unload_custom(void)
|
||||
void unload_font(Font* f)
|
||||
{
|
||||
/* Unload all custom fonts */
|
||||
|
||||
}
|
||||
|
||||
void destroy(void)
|
||||
{
|
||||
/* Unload all fonts (main and custom) for exiting */
|
||||
Font* f = &fonts_main.fonts[font_idx_8x8]; // TODO!
|
||||
VVV_freefunc(SDL_DestroyTexture, f->image);
|
||||
|
||||
for (int i = 0; i < FONT_N_PAGES; i++)
|
||||
|
@ -396,6 +422,31 @@ void destroy(void)
|
|||
}
|
||||
}
|
||||
|
||||
void unload_font_container(FontContainer* container)
|
||||
{
|
||||
for (size_t i = 0; i < container->count; i++)
|
||||
{
|
||||
unload_font(&container->fonts[i]);
|
||||
}
|
||||
VVV_free(container->fonts);
|
||||
container->fonts = NULL;
|
||||
container->count = 0;
|
||||
}
|
||||
|
||||
void unload_custom(void)
|
||||
{
|
||||
// Unload all custom fonts
|
||||
unload_font_container(&fonts_custom);
|
||||
}
|
||||
|
||||
void destroy(void)
|
||||
{
|
||||
// Unload all fonts (main and custom) for exiting
|
||||
unload_custom();
|
||||
unload_font_container(&fonts_main);
|
||||
}
|
||||
|
||||
|
||||
static bool next_wrap(
|
||||
size_t* start,
|
||||
size_t* len,
|
||||
|
|
|
@ -52,6 +52,8 @@ struct GlyphInfo
|
|||
|
||||
struct Font
|
||||
{
|
||||
char name[64];
|
||||
|
||||
uint8_t glyph_w;
|
||||
uint8_t glyph_h;
|
||||
|
||||
|
|
Loading…
Reference in a new issue