Text rendering bug test (was Re: More features)



On 02/01/2014 02:14 PM, Octavio Alvarez wrote:
* Considering that the only difference between cairo-pdf and
cairo-alpha-png is the cairo_*_surface_create() call and that
cairosimple also renders to a PNG file, I considered cairosimple should
failed too, so I compiled and cairosimple. Text rendered correctly.

I must correct myself. I think I have some useful information.

After reading bug #341481 [1] (pango), I modified cairosimple, the
example from Pango docs, to use a tweakable cairo_scale(). I attach the
resulting code. Here's how to use it:

[1] https://bugzilla.gnome.org/show_bug.cgi?id=341481

Compile it with:

gcc -o cairosimple-scale cairosimple-scale.c \
  `pkg-config --cflags --libs pangocairo` -lm

Run it with:

./cairosimple-scale test-output.png

... and check test-output.png with eog or your favorite visualizer.

Line 11 has a constant called TWEAKABLE_SCALE. In the attachment it is
currently set to 1 to make it equivalent to the original cairosimple.

If you set it to a value lower than 1, like 0.5, 0.1 or even 0.001,
you'll see that the text differs so slightly, I'd say it's more precise.

If you set it to a value higher than 1, but not that much (like 2 or 5)
you'll see that the text is, well, ok... I'd say it's fine.

If you set it to 10, 20, 40, or 60, you'll clearly see how the text
starts to get completely messed up, even its position (but not sure if
that's a bug of mine). Coincidentally enough, values like 10 or 20 shows
kerning bugs (like the ones apperaing in cairo-pdf) and values like 50
or 60 shows overlapping letters, like the bug on topic.

(BTW, when I said cairo-pdf did not fail, I meant that it didn't fully
overlapped all the letters, but still had kerning problems. Now I think
it's the same problem.)

Lines 29 and 30 are two methods of setting the size. I decided to leave
pango_font_description_set_absolute_size() enabled because that's what
Dia uses, but they can be exchanged at will.

When debugging I changed DIAG_NOTES to fprintf(stderr, ...) because I
didn't know how to enable DIAG_NOTES and added some extras.

I noticed pango_font_description_set_absolute_size() was being called
with a value of 866. Curiously enough, in the default cairosimple, it
must be called with about 27 * PANGO_SCALE * DPI / 72.0 where
PANGO_SCALE == 1024 and DPI == 96, so about 36,000 to get the an
equivalent font size. This means a value of 866 would be the equivalent
of 0.6 points. This results in a big precision loss.

So, even though the Pango team clearly has to fix some calculations to
do, Dia also has to find the way to scale back to better font sizes.

I'm not sure my interpretation of the tests are correct, but if they
are, the options for fix/workaround for Dia are:

If there is another internal rendering scaling multiplier, it will be
simpler: to adjust cairo_scale() to bring it back to better values and
use the internal multiplier to adjust the actual sizes of the objects to
render.

If there is not, an implementation of it is in order, but this could
horribly require to modify each rendering calculation, like the
TWEAKABLE_SCALE technique.

I gave it a shot, modifying renderer->scale at diacairo.c:165 but the
image just increases in DPI. Font size is still called with absolute
size of 866. So, no sucess yet.

Octavio.

Attachment: cairosimple-scale.c
Description: Text Data



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]