Upstream version 10.39.225.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / Source / core / svg / graphics / filters / SVGFilter.cpp
1 /*
2  * Copyright (C) 2009 Dirk Schulze <krit@webkit.org>
3  * Copyright (C) Research In Motion Limited 2010. All rights reserved.
4  * Copyright (C) 2013 Google Inc. All rights reserved.
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Library General Public
8  * License as published by the Free Software Foundation; either
9  * version 2 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Library General Public License for more details.
15  *
16  * You should have received a copy of the GNU Library General Public License
17  * along with this library; see the file COPYING.LIB.  If not, write to
18  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19  * Boston, MA 02110-1301, USA.
20  */
21
22 #include "config.h"
23
24 #include "core/svg/graphics/filters/SVGFilter.h"
25
26 namespace blink {
27
28 SVGFilter::SVGFilter(const IntRect& absoluteSourceDrawingRegion, const FloatRect& targetBoundingBox, const FloatRect& filterRegion, bool effectBBoxMode)
29     : Filter(AffineTransform())
30     , m_absoluteSourceDrawingRegion(absoluteSourceDrawingRegion)
31     , m_targetBoundingBox(targetBoundingBox)
32     , m_effectBBoxMode(effectBBoxMode)
33 {
34     setFilterRegion(filterRegion);
35 }
36
37 float SVGFilter::applyHorizontalScale(float value) const
38 {
39     if (m_effectBBoxMode)
40         value *= m_targetBoundingBox.width();
41     return Filter::applyHorizontalScale(value);
42 }
43
44 float SVGFilter::applyVerticalScale(float value) const
45 {
46     if (m_effectBBoxMode)
47         value *= m_targetBoundingBox.height();
48     return Filter::applyVerticalScale(value);
49 }
50
51 FloatPoint3D SVGFilter::resolve3dPoint(const FloatPoint3D& point) const
52 {
53     if (!m_effectBBoxMode)
54         return point;
55     return FloatPoint3D(point.x() * m_targetBoundingBox.width() + m_targetBoundingBox.x(),
56         point.y() * m_targetBoundingBox.height() + m_targetBoundingBox.y(),
57         point.z() * sqrtf(m_targetBoundingBox.size().diagonalLengthSquared() / 2));
58 }
59
60 PassRefPtr<SVGFilter> SVGFilter::create(const IntRect& absoluteSourceDrawingRegion, const FloatRect& targetBoundingBox, const FloatRect& filterRegion, bool effectBBoxMode)
61 {
62     return adoptRef(new SVGFilter(absoluteSourceDrawingRegion, targetBoundingBox, filterRegion, effectBBoxMode));
63 }
64
65 } // namespace blink