Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/ClipRecorder.h" | 6 #include "core/paint/ClipRecorder.h" |
| 7 | 7 |
| 8 #include "core/rendering/RenderLayer.h" | 8 #include "core/rendering/RenderLayer.h" |
| 9 #include "core/rendering/RenderObject.h" | 9 #include "core/rendering/RenderObject.h" |
| 10 #include "core/rendering/RenderView.h" | 10 #include "core/rendering/RenderView.h" |
| 11 #include "platform/RuntimeEnabledFeatures.h" | 11 #include "platform/RuntimeEnabledFeatures.h" |
| 12 #include "platform/graphics/GraphicsContext.h" | 12 #include "platform/graphics/GraphicsContext.h" |
| 13 | 13 |
| 14 namespace blink { | 14 namespace blink { |
| 15 | 15 |
| 16 void ClipDisplayItem::replay(GraphicsContext* context) | 16 void ClipDisplayItem::replay(GraphicsContext* context) |
| 17 { | 17 { |
| 18 context->save(); | 18 context->save(); |
| 19 context->clip(m_clipRect); | 19 context->clip(m_clipRect); |
| 20 for (RoundedRect roundedRect : m_roundedRectClips) | 20 for (RoundedRect roundedRect : m_roundedRectClips) |
| 21 context->clipRoundedRect(roundedRect); | 21 context->clipRoundedRect(roundedRect); |
| 22 } | 22 } |
| 23 | 23 |
| 24 void EndClipDisplayItem::replay(GraphicsContext* context) | 24 void EndClipDisplayItem::replay(GraphicsContext* context) |
| 25 { | 25 { |
| 26 context->restore(); | 26 context->restore(); |
| 27 } | 27 } |
| 28 | 28 |
| 29 ClipRecorder::ClipRecorder(RenderLayer* renderLayer, GraphicsContext* graphicsCo ntext, DisplayItem::Type clipType, const ClipRect& clipRect) | 29 ClipRecorder::ClipRecorder(const RenderObject* renderer, RenderLayer* renderLaye r, GraphicsContext* graphicsContext, DisplayItem::Type clipType, const ClipRect& clipRect) |
| 30 : m_graphicsContext(graphicsContext) | 30 : m_graphicsContext(graphicsContext) |
| 31 , m_renderLayer(renderLayer) | 31 , m_renderLayer(renderLayer) |
| 32 , m_renderer(renderer) | |
| 32 { | 33 { |
| 33 IntRect snappedClipRect = pixelSnappedIntRect(clipRect.rect()); | 34 IntRect snappedClipRect = pixelSnappedIntRect(clipRect.rect()); |
| 34 if (!RuntimeEnabledFeatures::slimmingPaintEnabled()) { | 35 if (!RuntimeEnabledFeatures::slimmingPaintEnabled()) { |
| 35 graphicsContext->save(); | 36 graphicsContext->save(); |
| 36 graphicsContext->clip(snappedClipRect); | 37 graphicsContext->clip(snappedClipRect); |
| 37 } else { | 38 } else { |
| 38 m_clipDisplayItem = new ClipDisplayItem(0, renderLayer, clipType, snappe dClipRect); | 39 m_clipDisplayItem = new ClipDisplayItem(renderer, renderLayer, clipType, snappedClipRect); |
| 39 m_renderLayer->renderer()->view()->viewDisplayList().add(adoptPtr(m_clip DisplayItem)); | 40 m_renderLayer->renderer()->view()->viewDisplayList().add(adoptPtr(m_clip DisplayItem)); |
|
chrishtr
2014/11/13 01:46:11
Just use m_renderLayer->renderer() rather than pas
leviw_travelin_and_unemployed
2014/11/13 01:46:40
Remove m_renderLayer and assert we have a layer.
pdr.
2014/11/13 06:49:28
I switched this to not track the render layer at a
| |
| 40 } | 41 } |
| 41 } | 42 } |
| 42 | 43 |
| 43 void ClipRecorder::addRoundedRectClip(const RoundedRect& roundedRect) | 44 void ClipRecorder::addRoundedRectClip(const RoundedRect& roundedRect) |
| 44 { | 45 { |
| 45 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) | 46 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) |
| 46 m_clipDisplayItem->roundedRectClips().append(roundedRect); | 47 m_clipDisplayItem->roundedRectClips().append(roundedRect); |
| 47 else | 48 else |
| 48 m_graphicsContext->clipRoundedRect(roundedRect); | 49 m_graphicsContext->clipRoundedRect(roundedRect); |
| 49 } | 50 } |
| 50 | 51 |
| 51 ClipRecorder::~ClipRecorder() | 52 ClipRecorder::~ClipRecorder() |
| 52 { | 53 { |
| 53 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) { | 54 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) { |
| 54 OwnPtr<EndClipDisplayItem> endClip = adoptPtr(new EndClipDisplayItem); | 55 OwnPtr<EndClipDisplayItem> endClip = adoptPtr(new EndClipDisplayItem(m_r enderer)); |
| 55 m_renderLayer->renderer()->view()->viewDisplayList().add(endClip.release ()); | 56 m_renderLayer->renderer()->view()->viewDisplayList().add(endClip.release ()); |
| 56 } else { | 57 } else { |
| 57 m_graphicsContext->restore(); | 58 m_graphicsContext->restore(); |
| 58 } | 59 } |
| 59 } | 60 } |
| 60 | 61 |
| 61 #ifndef NDEBUG | 62 #ifndef NDEBUG |
| 62 WTF::String ClipDisplayItem::asDebugString() const | 63 WTF::String ClipDisplayItem::asDebugString() const |
| 63 { | 64 { |
| 64 return String::format("{%s, type: \"%s\", clipRect: [%d,%d,%d,%d]}", | 65 return String::format("{%s, type: \"%s\", clipRect: [%d,%d,%d,%d]}", |
| 65 rendererDebugString(renderer()).utf8().data(), typeAsDebugString(type()) .utf8().data(), | 66 rendererDebugString(renderer()).utf8().data(), typeAsDebugString(type()) .utf8().data(), |
| 66 m_clipRect.x(), m_clipRect.y(), m_clipRect.width(), m_clipRect.height()) ; | 67 m_clipRect.x(), m_clipRect.y(), m_clipRect.width(), m_clipRect.height()) ; |
| 67 } | 68 } |
| 68 #endif | 69 #endif |
| 69 | 70 |
| 70 } // namespace blink | 71 } // namespace blink |
| OLD | NEW |