Bug 45335

Summary: Scrollbars fail to render in composited iframes.
Product: WebKit Reporter: Simon Fraser (smfr) <simon.fraser>
Component: FramesAssignee: Simon Fraser (smfr) <simon.fraser>
Status: RESOLVED FIXED    
Severity: Normal CC: abarth, aroben, cmarrin, eric, nduca, vangelis, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: Windows 7   
Attachments:
Description Flags
Patch aroben: review+

Simon Fraser (smfr)
Reported 2010-09-07 16:38:26 PDT
On Windows, scrollbars don't render in iframes that fall into compositing layers. For example, see LayoutTests/compositing/iframes/composited-parent-iframe.html
Attachments
Patch (17.87 KB, patch)
2010-09-09 14:08 PDT, Simon Fraser (smfr)
aroben: review+
Nat Duca
Comment 1 2010-09-07 17:08:18 PDT
Nat Duca
Comment 2 2010-09-07 17:09:40 PDT
Or rather, that's just a potentially related bug. :)
Simon Fraser (smfr)
Comment 3 2010-09-07 18:17:09 PDT
It looks like the ScrollbarThemeWIn is drawing the scrollbar using the HDC from the window, rather than the compositing layer.
Simon Fraser (smfr)
Comment 4 2010-09-09 14:08:12 PDT
Adam Roben (:aroben)
Comment 5 2010-09-09 14:16:06 PDT
Comment on attachment 67095 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=67095&action=prettypatch It would be nice to split this into two patches: one to add and use LocalWindowsContext, and one to fix get/releaseWindowsContext to work when there's no HDC. You also need to patch the releaseWindowsContext implementation in GraphicsContextCairoWin.cpp. > WebCore/platform/graphics/GraphicsContext.h:360 > + class LocalWindowsContext { It seems a little unfortunate to put this in GraphicsContext.h, since very few files will use this class but lots and lots of files will use GraphicsContext. Putting it in its own header file would drastically reduce the number of files that have to recompile when we change this class. Should this class be Noncopyable? > WebCore/platform/graphics/GraphicsContext.h:369 > + LocalWindowsContext(GraphicsContext* graphicsContext, const IntRect& rect, bool supportAlphaBlend = true, bool mayCreateBitmap = true) > + : m_graphicsContext(graphicsContext) > + , m_hdc(0) > + , m_rect(rect) > + , m_supportAlphaBlend(supportAlphaBlend) > + , m_mayCreateBitmap(mayCreateBitmap) > + { > + m_hdc = m_graphicsContext->getWindowsContext(m_rect, m_supportAlphaBlend, m_mayCreateBitmap); We usually try not to set members twice in constructors. You could either use the parameters to call getWindowsContext, or move m_hdc after the other members and use the members to call getWindowsContext. The code changes seem fine, so r+. But do consider these comments.
Simon Fraser (smfr)
Comment 6 2010-09-09 16:32:22 PDT
WebKit Review Bot
Comment 7 2010-09-09 17:03:19 PDT
Note You need to log in before you can comment on or make changes to this bug.