mirror of
https://git.checksum.fail/alec/erythros
synced 2025-12-11 13:39:55 +02:00
System/Libraries/Html/Renderer: Calculate text underline position more precisely
This commit is contained in:
@@ -1596,6 +1596,7 @@ U0 @render_node_text(@html_dom_node* node, HtmlRenderer* renderer)
|
|||||||
stream[i] = NULL;
|
stream[i] = NULL;
|
||||||
fragment_base = i + 1;
|
fragment_base = i + 1;
|
||||||
|
|
||||||
|
I64 baseline;
|
||||||
I64 text_width;
|
I64 text_width;
|
||||||
Context2DWidget* fragment_widget;
|
Context2DWidget* fragment_widget;
|
||||||
|
|
||||||
@@ -1618,8 +1619,10 @@ U0 @render_node_text(@html_dom_node* node, HtmlRenderer* renderer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (node->parentNode->underlineColor) {
|
if (node->parentNode->underlineColor) {
|
||||||
if (underline_y_pos < 0)
|
if (underline_y_pos < 0) {
|
||||||
underline_y_pos = @get_truetype_baseline(font_name, node->parentNode->fontSize) + 3;
|
baseline = ToF64(@get_truetype_baseline(font_name, node->parentNode->fontSize));
|
||||||
|
underline_y_pos = ToI64(baseline + ((ToF64(fragment_widget->ctx->height) - baseline) / 3));
|
||||||
|
}
|
||||||
if (!(underline_y_pos < 0)) {
|
if (!(underline_y_pos < 0)) {
|
||||||
fragment_widget->ctx->line(0, underline_y_pos, fragment_widget->ctx->width - 1, underline_y_pos, node->parentNode->color);
|
fragment_widget->ctx->line(0, underline_y_pos, fragment_widget->ctx->width - 1, underline_y_pos, node->parentNode->color);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user