aboutsummaryrefslogtreecommitdiff
path: root/src/graphics
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2025-02-05 20:14:43 +0100
committerdec05eba <dec05eba@protonmail.com>2025-02-05 20:14:43 +0100
commit7498535a49042dc58c6dfc9ef4df6e7e77ab93fa (patch)
treeada48d2e1b939a2ac2c4844ac9d34c0dfdb81c56 /src/graphics
parentddc745dab8b03e25e77e143aafb8e26a7af299d1 (diff)
Fix incorrect height for multiline text in bounds calculationHEADmaster
Diffstat (limited to 'src/graphics')
-rw-r--r--src/graphics/text.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/graphics/text.c b/src/graphics/text.c
index 2aa3bb4..3385667 100644
--- a/src/graphics/text.c
+++ b/src/graphics/text.c
@@ -94,12 +94,13 @@ static void mgl_text_for_each_codepoint(const mgl_text *self, codepoint_loop_cal
typedef struct {
mgl_vec2f bounds;
+ mgl_font *font;
} CalculateBoundsUserdata;
static bool calculate_bounds_callback(codepoint_loop_callback_data callback_data, void *userdata) {
CalculateBoundsUserdata *calculate_bounds_userdata = userdata;
calculate_bounds_userdata->bounds.x = max_float(calculate_bounds_userdata->bounds.x, callback_data.glyph_offset.x + callback_data.glyph_width);
- calculate_bounds_userdata->bounds.y = max_float(calculate_bounds_userdata->bounds.y, callback_data.glyph_offset.y + callback_data.glyph->size.y);
+ calculate_bounds_userdata->bounds.y = max_float(calculate_bounds_userdata->bounds.y, callback_data.glyph_offset.y + calculate_bounds_userdata->font->character_size);
return true;
}
@@ -107,6 +108,7 @@ static mgl_vec2f mgl_text_calculate_bounds(mgl_text *self) {
CalculateBoundsUserdata calculate_bounds_userdata;
calculate_bounds_userdata.bounds.x = 0.0f;
calculate_bounds_userdata.bounds.y = self->font->character_size;
+ calculate_bounds_userdata.font = self->font;
mgl_text_for_each_codepoint(self, calculate_bounds_callback, &calculate_bounds_userdata);
return calculate_bounds_userdata.bounds;
}