OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2011 Apple Inc. All rights reserved. | 2 * Copyright (C) 2011 Apple Inc. All rights reserved. |
3 * Copyright (C) 2013 Google Inc. All rights reserved. | 3 * Copyright (C) 2013 Google Inc. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
11 * notice, this list of conditions and the following disclaimer in the | 11 * notice, this list of conditions and the following disclaimer in the |
12 * documentation and/or other materials provided with the distribution. | 12 * documentation and/or other materials provided with the distribution. |
13 * | 13 * |
14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY | 14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY |
15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR | 17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR |
18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
25 */ | 25 */ |
26 | 26 |
27 #include "core/paint/FilterEffectBuilder.h" | 27 #include "core/paint/FilterEffectBuilder.h" |
28 | 28 |
29 #include "core/layout/svg/ReferenceFilterBuilder.h" | |
30 #include "core/style/FilterOperations.h" | 29 #include "core/style/FilterOperations.h" |
| 30 #include "core/svg/SVGElementProxy.h" |
31 #include "core/svg/SVGFilterElement.h" | 31 #include "core/svg/SVGFilterElement.h" |
32 #include "core/svg/SVGLengthContext.h" | 32 #include "core/svg/SVGLengthContext.h" |
33 #include "core/svg/graphics/filters/SVGFilterBuilder.h" | 33 #include "core/svg/graphics/filters/SVGFilterBuilder.h" |
34 #include "platform/LengthFunctions.h" | 34 #include "platform/LengthFunctions.h" |
35 #include "platform/graphics/ColorSpace.h" | 35 #include "platform/graphics/ColorSpace.h" |
36 #include "platform/graphics/CompositorFilterOperations.h" | 36 #include "platform/graphics/CompositorFilterOperations.h" |
37 #include "platform/graphics/filters/FEBoxReflect.h" | 37 #include "platform/graphics/filters/FEBoxReflect.h" |
38 #include "platform/graphics/filters/FEColorMatrix.h" | 38 #include "platform/graphics/filters/FEColorMatrix.h" |
39 #include "platform/graphics/filters/FEComponentTransfer.h" | 39 #include "platform/graphics/filters/FEComponentTransfer.h" |
40 #include "platform/graphics/filters/FEDropShadow.h" | 40 #include "platform/graphics/filters/FEDropShadow.h" |
(...skipping 355 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
396 sk_sp<SkImageFilter> filter = SkiaImageFilterBuilder::transformColorSpace( | 396 sk_sp<SkImageFilter> filter = SkiaImageFilterBuilder::transformColorSpace( |
397 nullptr, currentColorSpace, ColorSpaceDeviceRGB); | 397 nullptr, currentColorSpace, ColorSpaceDeviceRGB); |
398 filters.appendReferenceFilter(std::move(filter)); | 398 filters.appendReferenceFilter(std::move(filter)); |
399 } | 399 } |
400 return filters; | 400 return filters; |
401 } | 401 } |
402 | 402 |
403 Filter* FilterEffectBuilder::buildReferenceFilter( | 403 Filter* FilterEffectBuilder::buildReferenceFilter( |
404 const ReferenceFilterOperation& referenceOperation, | 404 const ReferenceFilterOperation& referenceOperation, |
405 FilterEffect* previousEffect) const { | 405 FilterEffect* previousEffect) const { |
406 DCHECK(m_targetContext && m_targetContext->isElementNode()); | 406 DCHECK(m_targetContext); |
407 SVGFilterElement* filterElement = | 407 Element* filterElement = |
408 ReferenceFilterBuilder::resolveFilterReference( | 408 referenceOperation.elementProxy().element(m_targetContext->treeScope()); |
409 referenceOperation, toElement(*m_targetContext)); | 409 if (!isSVGFilterElement(filterElement)) |
410 if (!filterElement) | |
411 return nullptr; | 410 return nullptr; |
412 return buildReferenceFilter(*filterElement, previousEffect); | 411 return buildReferenceFilter(toSVGFilterElement(*filterElement), |
| 412 previousEffect); |
413 } | 413 } |
414 | 414 |
415 Filter* FilterEffectBuilder::buildReferenceFilter( | 415 Filter* FilterEffectBuilder::buildReferenceFilter( |
416 SVGFilterElement& filterElement, | 416 SVGFilterElement& filterElement, |
417 FilterEffect* previousEffect, | 417 FilterEffect* previousEffect, |
418 SVGFilterGraphNodeMap* nodeMap) const { | 418 SVGFilterGraphNodeMap* nodeMap) const { |
419 FloatRect filterRegion = SVGLengthContext::resolveRectangle<SVGFilterElement>( | 419 FloatRect filterRegion = SVGLengthContext::resolveRectangle<SVGFilterElement>( |
420 &filterElement, filterElement.filterUnits()->currentValue()->enumValue(), | 420 &filterElement, filterElement.filterUnits()->currentValue()->enumValue(), |
421 m_referenceBox); | 421 m_referenceBox); |
422 // TODO(fs): We rely on the presence of a node map here to opt-in to the | 422 // TODO(fs): We rely on the presence of a node map here to opt-in to the |
(...skipping 11 matching lines...) Expand all Loading... |
434 Filter::create(m_referenceBox, filterRegion, m_zoom, unitScaling); | 434 Filter::create(m_referenceBox, filterRegion, m_zoom, unitScaling); |
435 if (!previousEffect) | 435 if (!previousEffect) |
436 previousEffect = result->getSourceGraphic(); | 436 previousEffect = result->getSourceGraphic(); |
437 SVGFilterBuilder builder(previousEffect, nodeMap, m_fillPaint, m_strokePaint); | 437 SVGFilterBuilder builder(previousEffect, nodeMap, m_fillPaint, m_strokePaint); |
438 builder.buildGraph(result, filterElement, m_referenceBox); | 438 builder.buildGraph(result, filterElement, m_referenceBox); |
439 result->setLastEffect(builder.lastEffect()); | 439 result->setLastEffect(builder.lastEffect()); |
440 return result; | 440 return result; |
441 } | 441 } |
442 | 442 |
443 } // namespace blink | 443 } // namespace blink |
OLD | NEW |