Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(232)

Side by Side Diff: Source/core/paint/LayerPainter.cpp

Issue 743523005: Remove m_hasBlendMode from BeginTransparencyDisplayItem (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | Source/core/paint/TransparencyDisplayItem.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "config.h" 5 #include "config.h"
6 #include "core/paint/LayerPainter.h" 6 #include "core/paint/LayerPainter.h"
7 7
8 #include "core/frame/Settings.h" 8 #include "core/frame/Settings.h"
9 #include "core/page/Page.h" 9 #include "core/page/Page.h"
10 #include "core/paint/FilterPainter.h" 10 #include "core/paint/FilterPainter.h"
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 } 99 }
100 100
101 paintLayerByApplyingTransform(context, paintingInfo, paintFlags); 101 paintLayerByApplyingTransform(context, paintingInfo, paintFlags);
102 102
103 return; 103 return;
104 } 104 }
105 105
106 paintLayerContentsAndReflection(context, paintingInfo, paintFlags); 106 paintLayerContentsAndReflection(context, paintingInfo, paintFlags);
107 } 107 }
108 108
109 static inline WebBlendMode blendModeForRenderer(const RenderObject& renderer)
110 {
111 // RenderObject::hasBlendMode is gated on RuntimeEnabledFeatures::cssComposi tingEnabled,
112 // otherwise the true-clause alone would suffice.
113 return renderer.hasBlendMode() ? renderer.style()->blendMode() : WebBlendMod eNormal;
Julien - ping for review 2014/11/19 19:16:05 RenderStyle::blendMode() is gated on cssCompositin
chrishtr 2014/11/19 19:24:09 Let's get rid of all of the hasBlendMode() methods
fs 2014/11/20 09:09:46 Ah, but of course... Thanks, fixed.
114 }
115
109 class TransparencyLayerHelper { 116 class TransparencyLayerHelper {
110 public: 117 public:
111 TransparencyLayerHelper(GraphicsContext* context, RenderLayer& renderLayer, const RenderLayer* rootLayer, const LayoutRect& paintDirtyRect, const LayoutSize & subPixelAccumulation, PaintBehavior paintBehavior) 118 TransparencyLayerHelper(GraphicsContext* context, RenderLayer& renderLayer, const RenderLayer* rootLayer, const LayoutRect& paintDirtyRect, const LayoutSize & subPixelAccumulation, PaintBehavior paintBehavior)
112 : m_transparencyLayerInProgress(false) 119 : m_transparencyLayerInProgress(false)
113 , m_context(context) 120 , m_context(context)
114 , m_renderLayer(renderLayer) 121 , m_renderLayer(renderLayer)
115 { 122 {
116 // Blending operations must be performed only with the nearest ancestor stacking context. 123 // Blending operations must be performed only with the nearest ancestor stacking context.
117 // Note that there is no need to create a transparency layer if we're pa inting the root. 124 // Note that there is no need to create a transparency layer if we're pa inting the root.
118 // FIXME: this should be unified further into RenderLayer::paintsWithTra nsparency(). 125 // FIXME: this should be unified further into RenderLayer::paintsWithTra nsparency().
119 bool shouldUseTransparencyLayerForBlendMode = !renderLayer.renderer()->i sDocumentElement() && renderLayer.stackingNode()->isStackingContext() && renderL ayer.hasNonIsolatedDescendantWithBlendMode(); 126 bool shouldUseTransparencyLayerForBlendMode = !renderLayer.renderer()->i sDocumentElement() && renderLayer.stackingNode()->isStackingContext() && renderL ayer.hasNonIsolatedDescendantWithBlendMode();
120 if (!shouldUseTransparencyLayerForBlendMode && !renderLayer.paintsWithTr ansparency(paintBehavior)) 127 if (!shouldUseTransparencyLayerForBlendMode && !renderLayer.paintsWithTr ansparency(paintBehavior))
121 return; 128 return;
122 129
123 OwnPtr<BeginTransparencyDisplayItem> beginTransparencyDisplayItem = adop tPtr(new BeginTransparencyDisplayItem( 130 OwnPtr<BeginTransparencyDisplayItem> beginTransparencyDisplayItem = adop tPtr(new BeginTransparencyDisplayItem(
124 renderLayer.renderer(), DisplayItem::BeginTransparency, renderLayer. paintingExtent(rootLayer, paintDirtyRect, subPixelAccumulation, paintBehavior), 131 renderLayer.renderer(), DisplayItem::BeginTransparency, renderLayer. paintingExtent(rootLayer, paintDirtyRect, subPixelAccumulation, paintBehavior),
125 renderLayer.renderer()->hasBlendMode(), renderLayer.renderer()->styl e()->blendMode(), renderLayer.renderer()->opacity())); 132 blendModeForRenderer(*renderLayer.renderer()), renderLayer.renderer( )->opacity()));
126 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) 133 if (RuntimeEnabledFeatures::slimmingPaintEnabled())
127 renderLayer.renderer()->view()->viewDisplayList().add(beginTranspare ncyDisplayItem.release()); 134 renderLayer.renderer()->view()->viewDisplayList().add(beginTranspare ncyDisplayItem.release());
128 else 135 else
129 beginTransparencyDisplayItem->replay(context); 136 beginTransparencyDisplayItem->replay(context);
130 137
131 m_transparencyLayerInProgress = true; 138 m_transparencyLayerInProgress = true;
132 } 139 }
133 140
134 ~TransparencyLayerHelper() 141 ~TransparencyLayerHelper()
135 { 142 {
(...skipping 618 matching lines...) Expand 10 before | Expand all | Expand 10 after
754 761
755 OwnPtr<ClipRecorder> clipRecorder; 762 OwnPtr<ClipRecorder> clipRecorder;
756 if (needsToClip(paintingInfo, clipRect)) 763 if (needsToClip(paintingInfo, clipRect))
757 clipRecorder = adoptPtr(new ClipRecorder(m_renderLayer.renderer(), c ontext, DisplayItem::ClipLayerFragmentParent, clipRect, &paintingInfo, LayoutPoi nt(), paintFlags)); 764 clipRecorder = adoptPtr(new ClipRecorder(m_renderLayer.renderer(), c ontext, DisplayItem::ClipLayerFragmentParent, clipRect, &paintingInfo, LayoutPoi nt(), paintFlags));
758 765
759 paintLayerByApplyingTransform(context, paintingInfo, paintFlags, fragmen t.paginationOffset); 766 paintLayerByApplyingTransform(context, paintingInfo, paintFlags, fragmen t.paginationOffset);
760 } 767 }
761 } 768 }
762 769
763 } // namespace blink 770 } // namespace blink
OLDNEW
« no previous file with comments | « no previous file | Source/core/paint/TransparencyDisplayItem.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698