From: Andrea Zagli Date: Sun, 9 Oct 2011 09:33:51 +0000 (+0200) Subject: Creating the font from PangoFontDescription and not from string. X-Git-Tag: 0.5.0~26 X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=d6a5971e93d4775130548863e4d456510b1392e1;p=reptool%2Flibreptool Creating the font from PangoFontDescription and not from string. --- diff --git a/src/rptprint.c b/src/rptprint.c index 6e39f8f..dab0b9e 100644 --- a/src/rptprint.c +++ b/src/rptprint.c @@ -774,7 +774,6 @@ rpt_print_text_xml (RptPrint *rpt_print, xmlNode *xnode) gchar *text = (gchar *)xmlNodeGetContent (xnode); gchar *prop; - gchar *str_font; gdouble padding_top = 0.0; gdouble padding_right = 0.0; @@ -834,30 +833,25 @@ rpt_print_text_xml (RptPrint *rpt_print, xmlNode *xnode) pango_layout_set_width (playout, (rpt_common_value_to_points (priv->unit, size->width) - padding_left - padding_right) * PANGO_SCALE); } - str_font = g_strdup (font->name); + /* creating pango font description */ + pfdesc = pango_font_description_new (); + + pango_font_description_set_family (pfdesc, font->name); if (font->bold) { - str_font = g_strconcat (str_font, " bold", NULL); + pango_font_description_set_weight (pfdesc, PANGO_WEIGHT_BOLD); } if (font->italic) { - str_font = g_strconcat (str_font, " italic", NULL); + pango_font_description_set_style (pfdesc, PANGO_STYLE_ITALIC); } if (font->size > 0.0f) { - str_font = g_strconcat (str_font, g_strdup_printf (" %f", font->size), NULL); + pango_font_description_set_size (pfdesc, (int)font->size * PANGO_SCALE); } else { - str_font = g_strconcat (str_font, " 12", NULL); - } - - /* creating pango font description */ - pfdesc = pango_font_description_from_string (str_font); - if (pfdesc == NULL) - { - g_warning ("Unable to create a PangoFontDescription from the string: %s", str_font); - return; + pango_font_description_set_size (pfdesc, 12); } pango_layout_set_font_description (playout, pfdesc);