Bug 45597

Summary: [GTK] Complex text does not have full CSS text-shadow support
Product: WebKit Reporter: Martin Robinson <mrobinson>
Component: WebKitGTKAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: abarth, eric, webkit.review.bot
Priority: P3 Keywords: Gtk
Version: 528+ (Nightly build)   
Hardware: PC   
OS: Linux   
Attachments:
Description Flags
Use ContextShadow in FontGtk
none
Patch incorporating Alex's suggestions none

Martin Robinson
Reported 2010-09-11 11:54:59 PDT
The complex text path only support solid CSS shadows currently.
Attachments
Use ContextShadow in FontGtk (48.16 KB, patch)
2010-10-19 15:31 PDT, Martin Robinson
no flags
Patch incorporating Alex's suggestions (48.10 KB, patch)
2010-10-23 08:42 PDT, Martin Robinson
no flags
Martin Robinson
Comment 1 2010-10-19 15:31:35 PDT
Created attachment 71211 [details] Use ContextShadow in FontGtk
Alejandro G. Castro
Comment 2 2010-10-21 11:37:02 PDT
Comment on attachment 71211 [details] Use ContextShadow in FontGtk View in context: https://bugs.webkit.org/attachment.cgi?id=71211&action=review > WebCore/platform/graphics/gtk/FontGtk.cpp:66 > +typedef GdkRegion* cairo_region_t*; I think this definition is not correct, it should be: typedef cairo_region_t* PangoRegionType; > WebCore/platform/graphics/gtk/FontGtk.cpp:224 > + FloatPoint totalOffset(point + shadow->m_offset); Doesn't point include the shadow offset already? > WebCore/platform/graphics/gtk/FontGtk.cpp:236 > + cairo_translate(context, -totalOffset.x(), -totalOffset.y()); Is this required after doing the cairo_restore in the next line? > WebCore/platform/graphics/gtk/FontGtk.cpp:-213 > - if (to - from != run.length()) { > - // Clip the region of the run to be rendered Before we were doing the clip just in case run does cover the whole line, is this intended?
Martin Robinson
Comment 3 2010-10-21 11:42:54 PDT
(In reply to comment #2) > (From update of attachment 71211 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=71211&action=review > > > WebCore/platform/graphics/gtk/FontGtk.cpp:66 > > +typedef GdkRegion* cairo_region_t*; > I think this definition is not correct, it should be: Nice catch. I'll fix that. > > WebCore/platform/graphics/gtk/FontGtk.cpp:224 > > + FloatPoint totalOffset(point + shadow->m_offset); > Doesn't point include the shadow offset already? It doesn't. The point passed in is the origin of the baseline of the first solid character. > > WebCore/platform/graphics/gtk/FontGtk.cpp:236 > > + cairo_translate(context, -totalOffset.x(), -totalOffset.y()); > Is this required after doing the cairo_restore in the next line? It isn't! I'll fix that. > > WebCore/platform/graphics/gtk/FontGtk.cpp:-213 > > - if (to - from != run.length()) { > > - // Clip the region of the run to be rendered > Before we were doing the clip just in case run does cover the whole line, is this intended? Doing the clipping unconditionally shouldn't hurt anything, but if performance is a concern I can re-add the condition.
Martin Robinson
Comment 4 2010-10-23 08:42:06 PDT
Created attachment 71643 [details] Patch incorporating Alex's suggestions
Martin Robinson
Comment 5 2010-11-10 09:59:27 PST
Comment on attachment 71643 [details] Patch incorporating Alex's suggestions Clearing flags on attachment: 71643 Committed r71750: <http://trac.webkit.org/changeset/71750>
Martin Robinson
Comment 6 2010-11-10 09:59:31 PST
All reviewed patches have been landed. Closing bug.
WebKit Review Bot
Comment 7 2010-11-10 10:57:58 PST
http://trac.webkit.org/changeset/71750 might have broken GTK Linux 64-bit Debug
Note You need to log in before you can comment on or make changes to this bug.