aboutsummaryrefslogtreecommitdiff
path: root/common/pango.c
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2018-09-22 15:33:01 -0700
committerFurkan Sahin <furkan-dev@proton.me>2018-09-22 15:33:01 -0700
commitfed1f63774aa33cec9bae7fce4d6787cf5b57a25 (patch)
treecb3ef76852a2022092fa3e34aa24178ee21ed95b /common/pango.c
parent93fb0b08af6b7beeba7c35473e60c55b922b1afb (diff)
Call pango_cairo_context_set_font_options().
Call pango_cairo_context_set_font_options() before pango_cairo_update_layout() and pango_cairo_show_layout(). By default, Pango "merges" the Cario font options with its own, which doesn't enable full hinting.
Diffstat (limited to 'common/pango.c')
-rw-r--r--common/pango.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/common/pango.c b/common/pango.c
index 5afd72d8..ba74692e 100644
--- a/common/pango.c
+++ b/common/pango.c
@@ -6,6 +6,7 @@
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include "cairo.h"
#include "log.h"
#include "stringop.h"
@@ -113,6 +114,10 @@ void pango_printf(cairo_t *cairo, const char *font,
va_end(args);
PangoLayout *layout = get_pango_layout(cairo, font, buf, scale, markup);
+ cairo_font_options_t *fo = cairo_font_options_create();
+ cairo_get_font_options(cairo, fo);
+ pango_cairo_context_set_font_options(pango_layout_get_context(layout), fo);
+ cairo_font_options_destroy(fo);
pango_cairo_update_layout(cairo, layout);
pango_cairo_show_layout(cairo, layout);
g_object_unref(layout);