18e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project/*
206ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen * Copyright (C) 2008, 2010 Apple Inc. All Rights Reserved.
38e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project *
48e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * Redistribution and use in source and binary forms, with or without
58e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * modification, are permitted provided that the following conditions
68e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * are met:
78e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * 1. Redistributions of source code must retain the above copyright
88e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project *    notice, this list of conditions and the following disclaimer.
98e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * 2. Redistributions in binary form must reproduce the above copyright
108e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project *    notice, this list of conditions and the following disclaimer in the
118e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project *    documentation and/or other materials provided with the distribution.
128e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project *
138e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
148e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
158e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
168e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
178e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
188e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
198e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
208e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
218e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
228e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
238e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
248e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project */
258e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project
26635860845790a19bf50bbc51ba8fb66a96dde068The Android Open Source Projectmodule css {
278e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project
28635860845790a19bf50bbc51ba8fb66a96dde068The Android Open Source Project    // Introduced in DOM Level ?:
2906ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen    interface [
3006ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen        CanBeConstructed,
3106ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen        CustomConstructFunction,
3206ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen        ConstructorParameters=1,
3306ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen        V8CustomConstructor
3406ea8e899e48f1f2f396b70e63fae369f2f23232Kristian Monsen    ] WebKitCSSMatrix {
35635860845790a19bf50bbc51ba8fb66a96dde068The Android Open Source Project
368f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // These attributes are simple aliases for certain elements of the 4x4 matrix
378f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double a; // alias for m11
388f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double b; // alias for m12
398f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double c; // alias for m21
408f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double d; // alias for m22
418f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double e; // alias for m41
428f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double f; // alias for m42
43635860845790a19bf50bbc51ba8fb66a96dde068The Android Open Source Project
448f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m11;
458f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m12;
468f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m13;
478f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m14;
488f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m21;
498f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m22;
508f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m23;
518f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m24;
528f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m31;
538f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m32;
548f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m33;
558f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m34;
568f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m41;
578f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m42;
588f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m43;
598f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        attribute double m44;
608f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
618f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        void setMatrixValue(in DOMString string) raises (DOMException);
628f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
638f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Multiply this matrix by secondMatrix, on the right (result = this * secondMatrix)
648f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix multiply(in WebKitCSSMatrix secondMatrix);
658f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
668f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Return the inverse of this matrix. Throw an exception if the matrix is not invertible
678f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix inverse() raises (DOMException);
688f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
698f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Return this matrix translated by the passed values.
708f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Passing a NaN will use a value of 0. This allows the 3D form to used for 2D operations
718f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix translate(in double x, in double y, in double z);
728f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
738f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Returns this matrix scaled by the passed values.
748f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Passing scaleX or scaleZ as NaN uses a value of 1, but passing scaleY of NaN
758f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // makes it the same as scaleX. This allows the 3D form to used for 2D operations
768f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix scale(in double scaleX, in double scaleY, in double scaleZ);
778f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
788f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Returns this matrix rotated by the passed values.
798f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // If rotY and rotZ are NaN, rotate about Z (rotX=0, rotateY=0, rotateZ=rotX).
808f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Otherwise use a rotation value of 0 for any passed NaN.
818f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix rotate(in double rotX, in double rotY, in double rotZ);
828f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian
838f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Returns this matrix rotated about the passed axis by the passed angle.
848f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // Passing a NaN will use a value of 0. If the axis is (0,0,0) use a value
858f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        // of (0,0,1).
868f72e70a9fd78eec56623b3a62e68f16b7b27e28Feng Qian        [Immutable] WebKitCSSMatrix rotateAxisAngle(in double x, in double y, in double z, in double angle);
87cad810f21b803229eb11403f9209855525a25d57Steve Block
88cad810f21b803229eb11403f9209855525a25d57Steve Block        // Returns this matrix skewed along the X axis by the passed values.
89cad810f21b803229eb11403f9209855525a25d57Steve Block        // Passing a NaN will use a value of 0.
90cad810f21b803229eb11403f9209855525a25d57Steve Block        [Immutable] WebKitCSSMatrix skewX(in double angle);
91cad810f21b803229eb11403f9209855525a25d57Steve Block
92cad810f21b803229eb11403f9209855525a25d57Steve Block        // Returns this matrix skewed along the Y axis by the passed values.
93cad810f21b803229eb11403f9209855525a25d57Steve Block        // Passing a NaN will use a value of 0.
94cad810f21b803229eb11403f9209855525a25d57Steve Block        [Immutable] WebKitCSSMatrix skewY(in double angle);
95cad810f21b803229eb11403f9209855525a25d57Steve Block
96635860845790a19bf50bbc51ba8fb66a96dde068The Android Open Source Project        [DontEnum] DOMString toString();
978e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project    };
988e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project
998e35f3cfc7fba1d1c829dc557ebad6409cbe16a2The Android Open Source Project}
100