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

Side by Side Diff: third_party/WebKit/Source/core/dom/DOMMatrixReadOnly.cpp

Issue 2260393002: add FlipX() and FlipY() funtion in DOMMatrixReadOnly. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: add flipY function Created 4 years, 4 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "core/dom/DOMMatrix.h" 5 #include "core/dom/DOMMatrix.h"
6 6
7 namespace blink { 7 namespace blink {
8 8
9 DOMMatrixReadOnly* DOMMatrixReadOnly::create(Vector<double> sequence, ExceptionS tate& exceptionState) 9 DOMMatrixReadOnly* DOMMatrixReadOnly::create(Vector<double> sequence, ExceptionS tate& exceptionState)
10 { 10 {
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
67 { 67 {
68 return DOMMatrix::create(this)->scale3dSelf(scale, ox, oy, oz); 68 return DOMMatrix::create(this)->scale3dSelf(scale, ox, oy, oz);
69 } 69 }
70 70
71 DOMMatrix* DOMMatrixReadOnly::scaleNonUniform(double sx, double sy, double sz, 71 DOMMatrix* DOMMatrixReadOnly::scaleNonUniform(double sx, double sy, double sz,
72 double ox, double oy, double oz) 72 double ox, double oy, double oz)
73 { 73 {
74 return DOMMatrix::create(this)->scaleNonUniformSelf(sx, sy, sz, ox, oy, oz); 74 return DOMMatrix::create(this)->scaleNonUniformSelf(sx, sy, sz, ox, oy, oz);
75 } 75 }
76 76
77 DOMMatrix* DOMMatrixReadOnly::flipX()
zino 2016/08/20 11:47:16 IMHO, this function is simplified like this: ctm =
Hwanseung Lee 2016/08/20 13:13:12 Done.
78 {
79 DOMMatrix* filpX = DOMMatrix::create();
zino 2016/08/20 11:47:16 At this time, flipX is identity matrix. So, setA(-
80 filpX->setA(-1);
81 filpX->setB(0);
82 filpX->setC(0);
83 filpX->setD(1);
84 filpX->setE(0);
85 filpX->setF(0);
86 return DOMMatrix::create(this)->multiplySelf(filpX);
87 }
88
89 DOMMatrix* DOMMatrixReadOnly::flipY()
90 {
91 DOMMatrix* filpY = DOMMatrix::create();
92 filpY->setA(1);
93 filpY->setB(0);
94 filpY->setC(0);
95 filpY->setD(-1);
zino 2016/08/20 11:47:16 ditto
96 filpY->setE(0);
97 filpY->setF(0);
98 return DOMMatrix::create(this)->multiplySelf(filpY);
99 }
100
77 DOMFloat32Array* DOMMatrixReadOnly::toFloat32Array() const 101 DOMFloat32Array* DOMMatrixReadOnly::toFloat32Array() const
78 { 102 {
79 float array[] = { 103 float array[] = {
80 static_cast<float>(m_matrix->m11()), static_cast<float>(m_matrix->m12()) , static_cast<float>(m_matrix->m13()), static_cast<float>(m_matrix->m14()), 104 static_cast<float>(m_matrix->m11()), static_cast<float>(m_matrix->m12()) , static_cast<float>(m_matrix->m13()), static_cast<float>(m_matrix->m14()),
81 static_cast<float>(m_matrix->m21()), static_cast<float>(m_matrix->m22()) , static_cast<float>(m_matrix->m23()), static_cast<float>(m_matrix->m24()), 105 static_cast<float>(m_matrix->m21()), static_cast<float>(m_matrix->m22()) , static_cast<float>(m_matrix->m23()), static_cast<float>(m_matrix->m24()),
82 static_cast<float>(m_matrix->m31()), static_cast<float>(m_matrix->m32()) , static_cast<float>(m_matrix->m33()), static_cast<float>(m_matrix->m34()), 106 static_cast<float>(m_matrix->m31()), static_cast<float>(m_matrix->m32()) , static_cast<float>(m_matrix->m33()), static_cast<float>(m_matrix->m34()),
83 static_cast<float>(m_matrix->m41()), static_cast<float>(m_matrix->m42()) , static_cast<float>(m_matrix->m43()), static_cast<float>(m_matrix->m44()) 107 static_cast<float>(m_matrix->m41()), static_cast<float>(m_matrix->m42()) , static_cast<float>(m_matrix->m43()), static_cast<float>(m_matrix->m44())
84 }; 108 };
85 109
86 return DOMFloat32Array::create(array, 16); 110 return DOMFloat32Array::create(array, 16);
87 } 111 }
88 112
89 DOMFloat64Array* DOMMatrixReadOnly::toFloat64Array() const 113 DOMFloat64Array* DOMMatrixReadOnly::toFloat64Array() const
90 { 114 {
91 double array[] = { 115 double array[] = {
92 m_matrix->m11(), m_matrix->m12(), m_matrix->m13(), m_matrix->m14(), 116 m_matrix->m11(), m_matrix->m12(), m_matrix->m13(), m_matrix->m14(),
93 m_matrix->m21(), m_matrix->m22(), m_matrix->m23(), m_matrix->m24(), 117 m_matrix->m21(), m_matrix->m22(), m_matrix->m23(), m_matrix->m24(),
94 m_matrix->m31(), m_matrix->m32(), m_matrix->m33(), m_matrix->m34(), 118 m_matrix->m31(), m_matrix->m32(), m_matrix->m33(), m_matrix->m34(),
95 m_matrix->m41(), m_matrix->m42(), m_matrix->m43(), m_matrix->m44() 119 m_matrix->m41(), m_matrix->m42(), m_matrix->m43(), m_matrix->m44()
96 }; 120 };
97 121
98 return DOMFloat64Array::create(array, 16); 122 return DOMFloat64Array::create(array, 16);
99 } 123 }
100 124
101 } // namespace blink 125 } // namespace blink
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/core/dom/DOMMatrixReadOnly.h ('k') | third_party/WebKit/Source/core/dom/DOMMatrixReadOnly.idl » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698