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

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

Issue 1326183002: Merge ReferenceFilter into Filter (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 5 years, 3 months 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/SVGFilterPainter.h" 6 #include "core/paint/SVGFilterPainter.h"
7 7
8 #include "core/layout/svg/LayoutSVGResourceFilter.h" 8 #include "core/layout/svg/LayoutSVGResourceFilter.h"
9 #include "core/layout/svg/SVGLayoutSupport.h" 9 #include "core/layout/svg/SVGLayoutSupport.h"
10 #include "core/paint/CompositingRecorder.h" 10 #include "core/paint/CompositingRecorder.h"
(...skipping 26 matching lines...) Expand all
37 } 37 }
38 38
39 filterData->m_state = FilterData::RecordingContent; 39 filterData->m_state = FilterData::RecordingContent;
40 return context; 40 return context;
41 } 41 }
42 42
43 void SVGFilterRecordingContext::endContent(FilterData* filterData) 43 void SVGFilterRecordingContext::endContent(FilterData* filterData)
44 { 44 {
45 ASSERT(filterData->m_state == FilterData::RecordingContent); 45 ASSERT(filterData->m_state == FilterData::RecordingContent);
46 46
47 // FIXME: maybe filterData should just hold onto SourceGraphic after creatio n? 47 // FIXME: maybe filterData should just hold onto SourceGraphic after creatio n?
Stephen White 2015/09/14 18:49:34 You can probably get rid of the comment now -- we'
fs 2015/09/15 10:42:56 Done.
48 SourceGraphic* sourceGraphic = static_cast<SourceGraphic*>(filterData->build er->getEffectById(SourceGraphic::effectName())); 48 SourceGraphic* sourceGraphic = filterData->filter->sourceGraphic();
49 ASSERT(sourceGraphic); 49 ASSERT(sourceGraphic);
50 50
51 GraphicsContext* context = paintingContext(); 51 GraphicsContext* context = paintingContext();
52 52
53 // For slimming paint we need to use the context that contains the filtered 53 // For slimming paint we need to use the context that contains the filtered
54 // content. 54 // content.
55 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) { 55 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) {
56 ASSERT(m_displayItemList); 56 ASSERT(m_displayItemList);
57 ASSERT(m_context); 57 ASSERT(m_context);
58 context = m_context.get(); 58 context = m_context.get();
59 context->beginRecording(filterData->filter->filterRegion()); 59 context->beginRecording(filterData->filter->filterRegion());
60 m_displayItemList->commitNewDisplayItemsAndReplay(*context); 60 m_displayItemList->commitNewDisplayItemsAndReplay(*context);
61 } 61 }
62 62
63 sourceGraphic->setPicture(context->endRecording()); 63 sourceGraphic->setPicture(context->endRecording());
64 64
65 // Content is cached by the source graphic so temporaries can be freed. 65 // Content is cached by the source graphic so temporaries can be freed.
66 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) { 66 if (RuntimeEnabledFeatures::slimmingPaintEnabled()) {
67 m_displayItemList = nullptr; 67 m_displayItemList = nullptr;
68 m_context = nullptr; 68 m_context = nullptr;
69 } 69 }
70 70
71 filterData->m_state = FilterData::ReadyToPaint; 71 filterData->m_state = FilterData::ReadyToPaint;
72 } 72 }
73 73
74 static void paintFilteredContent(LayoutObject& object, GraphicsContext* context, FilterData* filterData) 74 static void paintFilteredContent(LayoutObject& object, GraphicsContext* context, FilterData* filterData)
75 { 75 {
76 ASSERT(filterData->m_state == FilterData::ReadyToPaint); 76 ASSERT(filterData->m_state == FilterData::ReadyToPaint);
77 ASSERT(filterData->builder->getEffectById(SourceGraphic::effectName())); 77 ASSERT(filterData->filter->sourceGraphic());
78 78
79 filterData->m_state = FilterData::PaintingFilter; 79 filterData->m_state = FilterData::PaintingFilter;
80 80
81 SkiaImageFilterBuilder builder; 81 SkiaImageFilterBuilder builder;
82 RefPtr<SkImageFilter> imageFilter = builder.build(filterData->builder->lastE ffect(), ColorSpaceDeviceRGB); 82 RefPtr<SkImageFilter> imageFilter = builder.build(filterData->filter->lastEf fect(), ColorSpaceDeviceRGB);
83 FloatRect boundaries = filterData->filter->filterRegion(); 83 FloatRect boundaries = filterData->filter->filterRegion();
84 context->save(); 84 context->save();
85 85
86 // Clip drawing of filtered image to the minimum required paint rect. 86 // Clip drawing of filtered image to the minimum required paint rect.
87 FilterEffect* lastEffect = filterData->builder->lastEffect(); 87 FilterEffect* lastEffect = filterData->filter->lastEffect();
88 context->clipRect(lastEffect->determineAbsolutePaintRect(lastEffect->maxEffe ctRect())); 88 context->clipRect(lastEffect->determineAbsolutePaintRect(lastEffect->maxEffe ctRect()));
89 89
90 #ifdef CHECK_CTM_FOR_TRANSFORMED_IMAGEFILTER 90 #ifdef CHECK_CTM_FOR_TRANSFORMED_IMAGEFILTER
91 // TODO: Remove this workaround once skew/rotation support is added in Skia 91 // TODO: Remove this workaround once skew/rotation support is added in Skia
92 // (https://code.google.com/p/skia/issues/detail?id=3288, crbug.com/446935). 92 // (https://code.google.com/p/skia/issues/detail?id=3288, crbug.com/446935).
93 // If the CTM contains rotation or shearing, apply the filter to 93 // If the CTM contains rotation or shearing, apply the filter to
94 // the unsheared/unrotated matrix, and do the shearing/rotation 94 // the unsheared/unrotated matrix, and do the shearing/rotation
95 // as a final pass. 95 // as a final pass.
96 AffineTransform ctm = SVGLayoutSupport::deprecatedCalculateTransformToLayer( &object); 96 AffineTransform ctm = SVGLayoutSupport::deprecatedCalculateTransformToLayer( &object);
97 if (ctm.b() || ctm.c()) { 97 if (ctm.b() || ctm.c()) {
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after
144 FloatRect drawingRegion = object.strokeBoundingBox(); 144 FloatRect drawingRegion = object.strokeBoundingBox();
145 drawingRegion.intersect(filterRegion); 145 drawingRegion.intersect(filterRegion);
146 bool primitiveBoundingBoxMode = filterElement->primitiveUnits()->currentValu e()->enumValue() == SVGUnitTypes::SVG_UNIT_TYPE_OBJECTBOUNDINGBOX; 146 bool primitiveBoundingBoxMode = filterElement->primitiveUnits()->currentValu e()->enumValue() == SVGUnitTypes::SVG_UNIT_TYPE_OBJECTBOUNDINGBOX;
147 filterData->filter = SVGFilter::create(enclosingIntRect(drawingRegion), targ etBoundingBox, filterRegion, primitiveBoundingBoxMode); 147 filterData->filter = SVGFilter::create(enclosingIntRect(drawingRegion), targ etBoundingBox, filterRegion, primitiveBoundingBoxMode);
148 148
149 // Create all relevant filter primitives. 149 // Create all relevant filter primitives.
150 filterData->builder = m_filter.buildPrimitives(filterData->filter.get()); 150 filterData->builder = m_filter.buildPrimitives(filterData->filter.get());
151 if (!filterData->builder) 151 if (!filterData->builder)
152 return nullptr; 152 return nullptr;
153 153
154 FilterEffect* lastEffect = filterData->builder->lastEffect(); 154 FilterEffect* lastEffect = filterData->filter->lastEffect();
155 if (!lastEffect) 155 if (!lastEffect)
156 return nullptr; 156 return nullptr;
157 157
158 lastEffect->determineFilterPrimitiveSubregion(ClipToFilterRegion); 158 lastEffect->determineFilterPrimitiveSubregion(ClipToFilterRegion);
159 159
160 FilterData* data = filterData.get(); 160 FilterData* data = filterData.get();
161 m_filter.setFilterDataForLayoutObject(&object, filterData.release()); 161 m_filter.setFilterDataForLayoutObject(&object, filterData.release());
162 return recordingContext.beginContent(data); 162 return recordingContext.beginContent(data);
163 } 163 }
164 164
(...skipping 21 matching lines...) Expand all
186 if (LayoutObjectDrawingRecorder::useCachedDrawingIfPossible(*context, object , DisplayItem::SVGFilter, LayoutPoint())) 186 if (LayoutObjectDrawingRecorder::useCachedDrawingIfPossible(*context, object , DisplayItem::SVGFilter, LayoutPoint()))
187 return; 187 return;
188 188
189 // TODO(chrishtr): stop using an infinite rect, and instead bound the filter . 189 // TODO(chrishtr): stop using an infinite rect, and instead bound the filter .
190 LayoutObjectDrawingRecorder recorder(*context, object, DisplayItem::SVGFilte r, LayoutRect::infiniteIntRect(), LayoutPoint()); 190 LayoutObjectDrawingRecorder recorder(*context, object, DisplayItem::SVGFilte r, LayoutRect::infiniteIntRect(), LayoutPoint());
191 if (filterData && filterData->m_state == FilterData::ReadyToPaint) 191 if (filterData && filterData->m_state == FilterData::ReadyToPaint)
192 paintFilteredContent(object, context, filterData); 192 paintFilteredContent(object, context, filterData);
193 } 193 }
194 194
195 } 195 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698