[BMFont] Fix importing fonts with Match char height enabled.

This commit is contained in:
bruvzg 2024-08-14 23:52:19 +03:00
parent 8e666adeed
commit e7f215c2c4
No known key found for this signature in database
GPG Key ID: 7960FCF39844EC38

View File

@ -1482,8 +1482,8 @@ Error FontFile::_load_bitmap_font(const String &p_path, List<String> *r_image_fi
switch (block_type) { switch (block_type) {
case 1: /* info */ { case 1: /* info */ {
ERR_FAIL_COND_V_MSG(block_size < 15, ERR_CANT_CREATE, "Invalid BMFont info block size."); ERR_FAIL_COND_V_MSG(block_size < 15, ERR_CANT_CREATE, "Invalid BMFont info block size.");
base_size = f->get_16(); base_size = ABS(static_cast<int16_t>(f->get_16()));
if (base_size <= 0) { if (base_size == 0) {
base_size = 16; base_size = 16;
} }
uint8_t flags = f->get_8(); uint8_t flags = f->get_8();
@ -1776,7 +1776,10 @@ Error FontFile::_load_bitmap_font(const String &p_path, List<String> *r_image_fi
if (type == "info") { if (type == "info") {
if (keys.has("size")) { if (keys.has("size")) {
base_size = keys["size"].to_int(); base_size = ABS(keys["size"].to_int());
if (base_size == 0) {
base_size = 16;
}
} }
if (keys.has("outline")) { if (keys.has("outline")) {
outline = keys["outline"].to_int(); outline = keys["outline"].to_int();