Fix repaint issues when resizing a window with centered content, for platforms with...
[WebKit-https.git] / Source / WebCore / rendering / RenderLayerBacking.h
1 /*
2  * Copyright (C) 2009, 2010, 2011 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #ifndef RenderLayerBacking_h
27 #define RenderLayerBacking_h
28
29 #if USE(ACCELERATED_COMPOSITING)
30
31 #include "FloatPoint.h"
32 #include "FloatPoint3D.h"
33 #include "GraphicsLayer.h"
34 #include "GraphicsLayerClient.h"
35 #include "RenderLayer.h"
36 #include "TransformationMatrix.h"
37
38 namespace WebCore {
39
40 class KeyframeList;
41 class RenderLayerCompositor;
42 class TiledBacking;
43
44 enum CompositingLayerType {
45     NormalCompositingLayer, // non-tiled layer with backing store
46     TiledCompositingLayer, // tiled layer (always has backing store)
47     MediaCompositingLayer, // layer that contains an image, video, webGL or plugin
48     ContainerCompositingLayer // layer with no backing store
49 };
50
51 // RenderLayerBacking controls the compositing behavior for a single RenderLayer.
52 // It holds the various GraphicsLayers, and makes decisions about intra-layer rendering
53 // optimizations.
54 // 
55 // There is one RenderLayerBacking for each RenderLayer that is composited.
56
57 class RenderLayerBacking : public GraphicsLayerClient {
58     WTF_MAKE_NONCOPYABLE(RenderLayerBacking); WTF_MAKE_FAST_ALLOCATED;
59 public:
60     RenderLayerBacking(RenderLayer*);
61     ~RenderLayerBacking();
62
63     RenderLayer* owningLayer() const { return m_owningLayer; }
64
65     enum UpdateAfterLayoutFlag {
66         CompositingChildrenOnly = 1 << 0,
67         NeedsFullRepaint = 1 << 1,
68         IsUpdateRoot = 1 << 2
69     };
70     typedef unsigned UpdateAfterLayoutFlags;
71     void updateAfterLayout(UpdateAfterLayoutFlags);
72     
73     // Returns true if layer configuration changed.
74     bool updateGraphicsLayerConfiguration();
75     // Update graphics layer position and bounds.
76     void updateGraphicsLayerGeometry(); // make private
77     // Update contents and clipping structure.
78     void updateDrawsContent();
79     
80     GraphicsLayer* graphicsLayer() const { return m_graphicsLayer.get(); }
81
82     // Layer to clip children
83     bool hasClippingLayer() const { return (m_containmentLayer && !m_usingTiledCacheLayer); }
84     GraphicsLayer* clippingLayer() const { return !m_usingTiledCacheLayer ? m_containmentLayer.get() : 0; }
85
86     // Layer to get clipped by ancestor
87     bool hasAncestorClippingLayer() const { return m_ancestorClippingLayer != 0; }
88     GraphicsLayer* ancestorClippingLayer() const { return m_ancestorClippingLayer.get(); }
89
90     bool hasContentsLayer() const { return m_foregroundLayer != 0; }
91     GraphicsLayer* foregroundLayer() const { return m_foregroundLayer.get(); }
92
93     bool hasScrollingLayer() const { return m_scrollingLayer; }
94     GraphicsLayer* scrollingLayer() const { return m_scrollingLayer.get(); }
95     GraphicsLayer* scrollingContentsLayer() const { return m_scrollingContentsLayer.get(); }
96
97     void attachToScrollingCoordinator(RenderLayerBacking* parent);
98     void detachFromScrollingCoordinator();
99     uint64_t scrollLayerID() const { return m_scrollLayerID; }
100     
101     bool hasMaskLayer() const { return m_maskLayer != 0; }
102
103     GraphicsLayer* parentForSublayers() const;
104     GraphicsLayer* childForSuperlayers() const { return m_ancestorClippingLayer ? m_ancestorClippingLayer.get() : m_graphicsLayer.get(); }
105
106     // RenderLayers with backing normally short-circuit paintLayer() because
107     // their content is rendered via callbacks from GraphicsLayer. However, the document
108     // layer is special, because it has a GraphicsLayer to act as a container for the GraphicsLayers
109     // for descendants, but its contents usually render into the window (in which case this returns true).
110     // This returns false for other layers, and when the document layer actually needs to paint into its backing store
111     // for some reason.
112     bool paintsIntoWindow() const;
113     
114     // Returns true for a composited layer that has no backing store of its own, so
115     // paints into some ancestor layer.
116     bool paintsIntoCompositedAncestor() const { return !m_requiresOwnBackingStore; }
117
118     void setRequiresOwnBackingStore(bool);
119
120     void setContentsNeedDisplay();
121     // r is in the coordinate space of the layer's render object
122     void setContentsNeedDisplayInRect(const IntRect&);
123
124     // Notification from the renderer that its content changed.
125     void contentChanged(ContentChangeType);
126
127     // Interface to start, finish, suspend and resume animations and transitions
128     bool startTransition(double, CSSPropertyID, const RenderStyle* fromStyle, const RenderStyle* toStyle);
129     void transitionPaused(double timeOffset, CSSPropertyID);
130     void transitionFinished(CSSPropertyID);
131
132     bool startAnimation(double timeOffset, const Animation* anim, const KeyframeList& keyframes);
133     void animationPaused(double timeOffset, const String& name);
134     void animationFinished(const String& name);
135
136     void suspendAnimations(double time = 0);
137     void resumeAnimations();
138
139     IntRect compositedBounds() const;
140     void setCompositedBounds(const IntRect&);
141     void updateCompositedBounds();
142     
143     void updateAfterWidgetResize();
144     void positionOverflowControlsLayers(const IntSize& offsetFromRoot);
145
146     bool usingTileCache() const { return m_usingTiledCacheLayer; }
147     TiledBacking* tiledBacking() const;
148     void adjustTileCacheCoverage();
149     
150     void updateDebugIndicators(bool showBorder, bool showRepaintCounter);
151     
152     // GraphicsLayerClient interface
153     virtual bool shouldUseTileCache(const GraphicsLayer*) const OVERRIDE;
154     virtual void notifyAnimationStarted(const GraphicsLayer*, double startTime) OVERRIDE;
155     virtual void notifyFlushRequired(const GraphicsLayer*) OVERRIDE;
156     virtual void notifyFlushBeforeDisplayRefresh(const GraphicsLayer*) OVERRIDE;
157
158     virtual void paintContents(const GraphicsLayer*, GraphicsContext&, GraphicsLayerPaintingPhase, const IntRect& clip) OVERRIDE;
159
160     virtual float deviceScaleFactor() const OVERRIDE;
161     virtual float pageScaleFactor() const OVERRIDE;
162     virtual void didCommitChangesForLayer(const GraphicsLayer*) const OVERRIDE;
163     virtual bool getCurrentTransform(const GraphicsLayer*, TransformationMatrix&) const OVERRIDE;
164
165     virtual bool isTrackingRepaints() const OVERRIDE;
166
167 #ifndef NDEBUG
168     virtual void verifyNotPainting();
169 #endif
170
171     IntRect contentsBox() const;
172     IntRect backgroundBox() const;
173     
174     // For informative purposes only.
175     CompositingLayerType compositingLayerType() const;
176     
177     GraphicsLayer* layerForHorizontalScrollbar() const { return m_layerForHorizontalScrollbar.get(); }
178     GraphicsLayer* layerForVerticalScrollbar() const { return m_layerForVerticalScrollbar.get(); }
179     GraphicsLayer* layerForScrollCorner() const { return m_layerForScrollCorner.get(); }
180
181 #if ENABLE(CSS_FILTERS)
182     bool canCompositeFilters() const { return m_canCompositeFilters; }
183 #endif
184
185     // Return an estimate of the backing store area (in pixels) allocated by this object's GraphicsLayers.
186     double backingStoreMemoryEstimate() const;
187
188     String nameForLayer() const;
189     
190 #if ENABLE(CSS_COMPOSITING)
191     void setBlendMode(BlendMode);
192 #endif
193     void reportMemoryUsage(MemoryObjectInfo*) const;
194
195 private:
196     void createPrimaryGraphicsLayer();
197     void destroyGraphicsLayers();
198     
199     PassOwnPtr<GraphicsLayer> createGraphicsLayer(const String&);
200
201     RenderLayerModelObject* renderer() const { return m_owningLayer->renderer(); }
202     RenderLayerCompositor* compositor() const { return m_owningLayer->compositor(); }
203
204     void updateInternalHierarchy();
205     bool updateClippingLayers(bool needsAncestorClip, bool needsDescendantClip);
206     bool updateOverflowControlsLayers(bool needsHorizontalScrollbarLayer, bool needsVerticalScrollbarLayer, bool needsScrollCornerLayer);
207     bool updateForegroundLayer(bool needsForegroundLayer);
208     bool updateMaskLayer(bool needsMaskLayer);
209     bool requiresHorizontalScrollbarLayer() const;
210     bool requiresVerticalScrollbarLayer() const;
211     bool requiresScrollCornerLayer() const;
212     bool updateScrollingLayers(bool scrollingLayers);
213     void updateDrawsContent(bool isSimpleContainer);
214
215     GraphicsLayerPaintingPhase paintingPhaseForPrimaryLayer() const;
216     
217     IntSize contentOffsetInCompostingLayer() const;
218     // Result is transform origin in pixels.
219     FloatPoint3D computeTransformOrigin(const IntRect& borderBox) const;
220     // Result is perspective origin in pixels.
221     FloatPoint computePerspectiveOrigin(const IntRect& borderBox) const;
222
223     void updateOpacity(const RenderStyle*);
224     void updateTransform(const RenderStyle*);
225 #if ENABLE(CSS_FILTERS)
226     void updateFilters(const RenderStyle*);
227 #endif
228 #if ENABLE(CSS_COMPOSITING)
229     void updateLayerBlendMode(const RenderStyle*);
230 #endif
231     // Return the opacity value that this layer should use for compositing.
232     float compositingOpacity(float rendererOpacity) const;
233     
234     bool isMainFrameRenderViewLayer() const;
235     
236     bool paintsBoxDecorations() const;
237     bool paintsChildren() const;
238
239     // Returns true if this compositing layer has no visible content.
240     bool isSimpleContainerCompositingLayer() const;
241     // Returns true if this layer has content that needs to be rendered by painting into the backing store.
242     bool containsPaintedContent() const;
243     // Returns true if the RenderLayer just contains an image that we can composite directly.
244     bool isDirectlyCompositedImage() const;
245     void updateImageContents();
246
247     Color rendererBackgroundColor() const;
248     void updateBackgroundColor(bool isSimpleContainer);
249     void updateContentsRect(bool isSimpleContainer);
250
251     bool containsNonEmptyRenderers() const;
252     bool hasVisibleNonCompositingDescendantLayers() const;
253
254     bool shouldClipCompositedBounds() const;
255
256     bool hasTileCacheFlatteningLayer() const { return (m_containmentLayer && m_usingTiledCacheLayer); }
257     GraphicsLayer* tileCacheFlatteningLayer() const { return m_usingTiledCacheLayer ? m_containmentLayer.get() : 0; }
258
259     void paintIntoLayer(RenderLayer* rootLayer, GraphicsContext*, const IntRect& paintDirtyRect, PaintBehavior, GraphicsLayerPaintingPhase);
260
261     static CSSPropertyID graphicsLayerToCSSProperty(AnimatedPropertyID);
262     static AnimatedPropertyID cssToGraphicsLayerProperty(CSSPropertyID);
263
264     RenderLayer* m_owningLayer;
265
266     OwnPtr<GraphicsLayer> m_ancestorClippingLayer; // only used if we are clipped by an ancestor which is not a stacking context
267     OwnPtr<GraphicsLayer> m_graphicsLayer;
268     OwnPtr<GraphicsLayer> m_foregroundLayer;       // only used in cases where we need to draw the foreground separately
269     OwnPtr<GraphicsLayer> m_containmentLayer; // Only used if we have clipping on a stacking context with compositing children, or if the layer has a tile cache.
270     OwnPtr<GraphicsLayer> m_maskLayer;             // only used if we have a mask
271
272     OwnPtr<GraphicsLayer> m_layerForHorizontalScrollbar;
273     OwnPtr<GraphicsLayer> m_layerForVerticalScrollbar;
274     OwnPtr<GraphicsLayer> m_layerForScrollCorner;
275
276     OwnPtr<GraphicsLayer> m_scrollingLayer; // only used if the layer is using composited scrolling.
277     OwnPtr<GraphicsLayer> m_scrollingContentsLayer; // only used if the layer is using composited scrolling.
278
279     uint64_t m_scrollLayerID;
280
281     IntRect m_compositedBounds;
282
283     bool m_artificiallyInflatedBounds; // bounds had to be made non-zero to make transform-origin work
284     bool m_boundsConstrainedByClipping;
285     bool m_isMainFrameRenderViewLayer;
286     bool m_usingTiledCacheLayer;
287     bool m_requiresOwnBackingStore;
288 #if ENABLE(CSS_FILTERS)
289     bool m_canCompositeFilters;
290 #endif
291
292     static bool m_creatingPrimaryGraphicsLayer;
293 };
294
295 } // namespace WebCore
296
297 #endif // USE(ACCELERATED_COMPOSITING)
298
299 #endif // RenderLayerBacking_h