Reviewed by Oliver.
[WebKit-https.git] / WebCore / bindings / js / JSSVGMatrixCustom.cpp
1 /*
2  * Copyright (C) 2006, 2007, 2008 Nikolas Zimmermann <zimmermann@kde.org>
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Library General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Library General Public License for more details.
13  *
14  * You should have received a copy of the GNU Library General Public License
15  * along with this library; see the file COPYING.LIB.  If not, write to
16  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17  * Boston, MA 02110-1301, USA.
18  */
19
20 #include "config.h"
21
22 #if ENABLE(SVG)
23 #include "JSSVGMatrix.h"
24
25 #include "AffineTransform.h"
26 #include "SVGException.h"
27
28 using namespace KJS;
29
30 namespace WebCore {
31
32 JSValue* JSSVGMatrix::multiply(ExecState* exec, const ArgList& args)
33 {
34     AffineTransform imp(*impl());
35
36     AffineTransform secondMatrix = toSVGMatrix(args[0]);    
37     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.multiply(secondMatrix)).get(), m_context.get());
38 }
39
40 JSValue* JSSVGMatrix::inverse(ExecState* exec, const ArgList&)
41 {
42     AffineTransform imp(*impl());
43     KJS::JSValue* result = toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.inverse()).get(), m_context.get());
44
45     if (!imp.isInvertible())
46         setDOMException(exec, SVGException::SVG_MATRIX_NOT_INVERTABLE);
47
48     return result;
49 }
50
51 JSValue* JSSVGMatrix::translate(ExecState* exec, const ArgList& args)
52 {
53     AffineTransform imp(*impl());
54
55     float x = args[0]->toFloat(exec);
56     float y = args[1]->toFloat(exec);
57
58     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.translate(x, y)).get(), m_context.get());
59 }
60
61 JSValue* JSSVGMatrix::scale(ExecState* exec, const ArgList& args)
62 {
63     AffineTransform imp(*impl());
64
65     float scaleFactor = args[0]->toFloat(exec);
66     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.scale(scaleFactor)).get(), m_context.get());
67 }
68
69 JSValue* JSSVGMatrix::scaleNonUniform(ExecState* exec, const ArgList& args)
70 {
71     AffineTransform imp(*impl());
72
73     float scaleFactorX = args[0]->toFloat(exec);
74     float scaleFactorY = args[1]->toFloat(exec);
75
76     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.scaleNonUniform(scaleFactorX, scaleFactorY)).get(), m_context.get());
77 }
78
79 JSValue* JSSVGMatrix::rotate(ExecState* exec, const ArgList& args)
80 {
81     AffineTransform imp(*impl());
82
83     float angle = args[0]->toFloat(exec);
84     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.rotate(angle)).get(), m_context.get());
85 }
86
87 JSValue* JSSVGMatrix::rotateFromVector(ExecState* exec, const ArgList& args)
88 {
89     AffineTransform imp(*impl());
90  
91     float x = args[0]->toFloat(exec);
92     float y = args[1]->toFloat(exec);
93
94     KJS::JSValue* result = toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.rotateFromVector(x, y)).get(), m_context.get());
95
96     if (x == 0.0 || y == 0.0)
97         setDOMException(exec, SVGException::SVG_INVALID_VALUE_ERR);
98
99     return result;
100 }
101
102 JSValue* JSSVGMatrix::flipX(ExecState* exec, const ArgList&)
103 {
104     AffineTransform imp(*impl());
105     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.flipX()).get(), m_context.get());
106 }
107
108 JSValue* JSSVGMatrix::flipY(ExecState* exec, const ArgList&)
109 {
110     AffineTransform imp(*impl());
111     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.flipY()).get(), m_context.get());
112 }
113
114 JSValue* JSSVGMatrix::skewX(ExecState* exec, const ArgList& args)
115 {
116     AffineTransform imp(*impl());
117
118     float angle = args[0]->toFloat(exec);
119     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.skewX(angle)).get(), m_context.get());
120 }
121
122 JSValue* JSSVGMatrix::skewY(ExecState* exec, const ArgList& args)
123 {
124     AffineTransform imp(*impl());
125
126     float angle = args[0]->toFloat(exec);
127     return toJS(exec, JSSVGStaticPODTypeWrapper<AffineTransform>::create(imp.skewY(angle)).get(), m_context.get());
128 }
129
130 }
131
132 #endif // ENABLE(SVG)