<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED --- - [PATCH] Add support for TextMarkup Annotations in glib frontend"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=51487#c46">Comment # 46</a>
              on <a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED --- - [PATCH] Add support for TextMarkup Annotations in glib frontend"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=51487">bug 51487</a>
              from <span class="vcard"><a class="email" href="mailto:gpoo@gnome.org" title="Germán Poo-Caamaño <gpoo@gnome.org>"> <span class="fn">Germán Poo-Caamaño</span></a>
</span></b>
        <pre>Created <span class=""><a href="attachment.cgi?id=93092" name="attach_93092" title="glib-demo: Fix performance in text markup annotations">attachment 93092</a> <a href="attachment.cgi?id=93092&action=edit" title="glib-demo: Fix performance in text markup annotations">[details]</a></span> <a href='page.cgi?id=splinter.html&bug=51487&attachment=93092'>[review]</a>
glib-demo: Fix performance in text markup annotations

The performance issue is in the following snippet:

     if (ABS(r->y2 - rects[i].y2) > 0.0001) {
        if (i > 0)
             l_rects = g_list_append (l_rects, r);
         r = g_slice_new (PopplerRectangle);
         r->x1 = rects[i].x1;
         r->y1 = height - rects[i].y1;
         r->x2 = rects[i].x2;
         r->y2 = height - rects[i].y2;
         lines++;
     } else {
         r->x1 = MIN(r->x1, rects[i].x1);
         r->y1 = height - MIN(r->y1, rects[i].y1);
         r->x2 = MAX(r->x2, rects[i].x2);
         r->y2 = height - MAX(r->y2, rects[i].y2);
     }

The condition is never FALSE, r->y2 is never close to
rects[i].y2 because r->y2 is now relative to the height.
Therefore, this makes the text markup slow because it
creates a rectangle per glyph (in my test 199 glyphs in
3 lines).

To make it work, we would need something like:

    if (ABS(r->y2 - (height - rects[i].y2)) > 0.0001) {
        if (i > 0)
            l_rects = g_list_append (l_rects, r);
        r = g_slice_new (PopplerRectangle);
        r->x1 = rects[i].x1;
        r->y1 = height - rects[i].y1;
        r->x2 = rects[i].x2;
        r->y2 = height - rects[i].y2;
        lines++;
    } else {
        r->x1 = MIN(r->x1, rects[i].x1);
        r->y1 = MIN(r->y1, height - rects[i].y1 + 14);
        r->x2 = MAX(r->x2, rects[i].x2);
        r->y2 = MAX(r->y2, height - rects[i].y2);
    }

Do you notice the magic 14?  I suspect that that number is
the line height.  Without that number, the quadrilaterals
ends with something that resembles rectangle coordinates
instead of quadrilateral ones, for example:

P1: 114.0, 114.0    P2: 292.0, 553.0
P3: 114.0, 559.0    P4: 292.0, 559.0

instead of the correct one:

P1: 114.0, 114.0    P2: 292.0, 567.0 **
P3: 114.0, 559.0    P4: 292.0, 559.0

The difference between 567 and 553 is 14, the line height
(font size?) in my test.

If there were such API (which I don't know) we could even
set an extra pixel on both top and bottom, that would make
the highlight looks nicer (IMHO). However, the use of API
would become even more complicated than it should be.

I still think that a solution in the line of what
poppler_page_get_selection_region provided would be better.
Because it would make its use simpler, and we could leave
poppler_page_get_text_layout_for_area for special situations.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>