1 /* libs/android_runtime/android/graphics/Matrix.cpp
2 **
3 ** Copyright 2006, The Android Open Source Project
4 **
5 ** Licensed under the Apache License, Version 2.0 (the "License");
6 ** you may not use this file except in compliance with the License.
7 ** You may obtain a copy of the License at
8 **
9 ** http://www.apache.org/licenses/LICENSE-2.0
10 **
11 ** Unless required by applicable law or agreed to in writing, software
12 ** distributed under the License is distributed on an "AS IS" BASIS,
13 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ** See the License for the specific language governing permissions and
15 ** limitations under the License.
16 */
17
18 #include "jni.h"
19 #include "GraphicsJNI.h"
20 #include <android_runtime/AndroidRuntime.h>
21
22 #include "SkMatrix.h"
23 #include "SkTemplates.h"
24
25 #include "Matrix.h"
26
27 #include <Caches.h>
28
29 namespace android {
30
31 class SkMatrixGlue {
32 public:
33
finalizer(JNIEnv * env,jobject clazz,SkMatrix * obj)34 static void finalizer(JNIEnv* env, jobject clazz, SkMatrix* obj) {
35 delete obj;
36 }
37
create(JNIEnv * env,jobject clazz,const SkMatrix * src)38 static SkMatrix* create(JNIEnv* env, jobject clazz, const SkMatrix* src) {
39 SkMatrix* obj = new SkMatrix();
40 if (src)
41 *obj = *src;
42 else
43 obj->reset();
44 return obj;
45 }
46
isIdentity(JNIEnv * env,jobject clazz,SkMatrix * obj)47 static jboolean isIdentity(JNIEnv* env, jobject clazz, SkMatrix* obj) {
48 return obj->isIdentity();
49 }
50
rectStaysRect(JNIEnv * env,jobject clazz,SkMatrix * obj)51 static jboolean rectStaysRect(JNIEnv* env, jobject clazz, SkMatrix* obj) {
52 return obj->rectStaysRect();
53 }
54
reset(JNIEnv * env,jobject clazz,SkMatrix * obj)55 static void reset(JNIEnv* env, jobject clazz, SkMatrix* obj) {
56 obj->reset();
57 }
58
set(JNIEnv * env,jobject clazz,SkMatrix * obj,SkMatrix * other)59 static void set(JNIEnv* env, jobject clazz, SkMatrix* obj, SkMatrix* other) {
60 *obj = *other;
61 }
62
setTranslate(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat dx,jfloat dy)63 static void setTranslate(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat dx, jfloat dy) {
64 SkScalar dx_ = SkFloatToScalar(dx);
65 SkScalar dy_ = SkFloatToScalar(dy);
66 obj->setTranslate(dx_, dy_);
67 }
68
setScale__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy,jfloat px,jfloat py)69 static void setScale__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy, jfloat px, jfloat py) {
70 SkScalar sx_ = SkFloatToScalar(sx);
71 SkScalar sy_ = SkFloatToScalar(sy);
72 SkScalar px_ = SkFloatToScalar(px);
73 SkScalar py_ = SkFloatToScalar(py);
74 obj->setScale(sx_, sy_, px_, py_);
75 }
76
setScale__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy)77 static void setScale__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy) {
78 SkScalar sx_ = SkFloatToScalar(sx);
79 SkScalar sy_ = SkFloatToScalar(sy);
80 obj->setScale(sx_, sy_);
81 }
82
setRotate__FFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees,jfloat px,jfloat py)83 static void setRotate__FFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees, jfloat px, jfloat py) {
84 SkScalar degrees_ = SkFloatToScalar(degrees);
85 SkScalar px_ = SkFloatToScalar(px);
86 SkScalar py_ = SkFloatToScalar(py);
87 obj->setRotate(degrees_, px_, py_);
88 }
89
setRotate__F(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees)90 static void setRotate__F(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees) {
91 SkScalar degrees_ = SkFloatToScalar(degrees);
92 obj->setRotate(degrees_);
93 }
94
setSinCos__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sinValue,jfloat cosValue,jfloat px,jfloat py)95 static void setSinCos__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sinValue, jfloat cosValue, jfloat px, jfloat py) {
96 SkScalar sinValue_ = SkFloatToScalar(sinValue);
97 SkScalar cosValue_ = SkFloatToScalar(cosValue);
98 SkScalar px_ = SkFloatToScalar(px);
99 SkScalar py_ = SkFloatToScalar(py);
100 obj->setSinCos(sinValue_, cosValue_, px_, py_);
101 }
102
setSinCos__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sinValue,jfloat cosValue)103 static void setSinCos__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sinValue, jfloat cosValue) {
104 SkScalar sinValue_ = SkFloatToScalar(sinValue);
105 SkScalar cosValue_ = SkFloatToScalar(cosValue);
106 obj->setSinCos(sinValue_, cosValue_);
107 }
108
setSkew__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat kx,jfloat ky,jfloat px,jfloat py)109 static void setSkew__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat kx, jfloat ky, jfloat px, jfloat py) {
110 SkScalar kx_ = SkFloatToScalar(kx);
111 SkScalar ky_ = SkFloatToScalar(ky);
112 SkScalar px_ = SkFloatToScalar(px);
113 SkScalar py_ = SkFloatToScalar(py);
114 obj->setSkew(kx_, ky_, px_, py_);
115 }
116
setSkew__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat kx,jfloat ky)117 static void setSkew__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat kx, jfloat ky) {
118 SkScalar kx_ = SkFloatToScalar(kx);
119 SkScalar ky_ = SkFloatToScalar(ky);
120 obj->setSkew(kx_, ky_);
121 }
122
setConcat(JNIEnv * env,jobject clazz,SkMatrix * obj,SkMatrix * a,SkMatrix * b)123 static jboolean setConcat(JNIEnv* env, jobject clazz, SkMatrix* obj, SkMatrix* a, SkMatrix* b) {
124 return obj->setConcat(*a, *b);
125 }
126
preTranslate(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat dx,jfloat dy)127 static jboolean preTranslate(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat dx, jfloat dy) {
128 SkScalar dx_ = SkFloatToScalar(dx);
129 SkScalar dy_ = SkFloatToScalar(dy);
130 return obj->preTranslate(dx_, dy_);
131 }
132
preScale__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy,jfloat px,jfloat py)133 static jboolean preScale__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy, jfloat px, jfloat py) {
134 SkScalar sx_ = SkFloatToScalar(sx);
135 SkScalar sy_ = SkFloatToScalar(sy);
136 SkScalar px_ = SkFloatToScalar(px);
137 SkScalar py_ = SkFloatToScalar(py);
138 return obj->preScale(sx_, sy_, px_, py_);
139 }
140
preScale__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy)141 static jboolean preScale__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy) {
142 SkScalar sx_ = SkFloatToScalar(sx);
143 SkScalar sy_ = SkFloatToScalar(sy);
144 return obj->preScale(sx_, sy_);
145 }
146
preRotate__FFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees,jfloat px,jfloat py)147 static jboolean preRotate__FFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees, jfloat px, jfloat py) {
148 SkScalar degrees_ = SkFloatToScalar(degrees);
149 SkScalar px_ = SkFloatToScalar(px);
150 SkScalar py_ = SkFloatToScalar(py);
151 return obj->preRotate(degrees_, px_, py_);
152 }
153
preRotate__F(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees)154 static jboolean preRotate__F(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees) {
155 SkScalar degrees_ = SkFloatToScalar(degrees);
156 return obj->preRotate(degrees_);
157 }
158
preSkew__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat kx,jfloat ky,jfloat px,jfloat py)159 static jboolean preSkew__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat kx, jfloat ky, jfloat px, jfloat py) {
160 SkScalar kx_ = SkFloatToScalar(kx);
161 SkScalar ky_ = SkFloatToScalar(ky);
162 SkScalar px_ = SkFloatToScalar(px);
163 SkScalar py_ = SkFloatToScalar(py);
164 return obj->preSkew(kx_, ky_, px_, py_);
165 }
166
preSkew__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat kx,jfloat ky)167 static jboolean preSkew__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat kx, jfloat ky) {
168 SkScalar kx_ = SkFloatToScalar(kx);
169 SkScalar ky_ = SkFloatToScalar(ky);
170 return obj->preSkew(kx_, ky_);
171 }
172
preConcat(JNIEnv * env,jobject clazz,SkMatrix * obj,SkMatrix * other)173 static jboolean preConcat(JNIEnv* env, jobject clazz, SkMatrix* obj, SkMatrix* other) {
174 return obj->preConcat(*other);
175 }
176
postTranslate(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat dx,jfloat dy)177 static jboolean postTranslate(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat dx, jfloat dy) {
178 SkScalar dx_ = SkFloatToScalar(dx);
179 SkScalar dy_ = SkFloatToScalar(dy);
180 return obj->postTranslate(dx_, dy_);
181 }
182
postScale__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy,jfloat px,jfloat py)183 static jboolean postScale__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy, jfloat px, jfloat py) {
184 SkScalar sx_ = SkFloatToScalar(sx);
185 SkScalar sy_ = SkFloatToScalar(sy);
186 SkScalar px_ = SkFloatToScalar(px);
187 SkScalar py_ = SkFloatToScalar(py);
188 return obj->postScale(sx_, sy_, px_, py_);
189 }
190
postScale__FF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat sx,jfloat sy)191 static jboolean postScale__FF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat sx, jfloat sy) {
192 SkScalar sx_ = SkFloatToScalar(sx);
193 SkScalar sy_ = SkFloatToScalar(sy);
194 return obj->postScale(sx_, sy_);
195 }
196
postRotate__FFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees,jfloat px,jfloat py)197 static jboolean postRotate__FFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees, jfloat px, jfloat py) {
198 SkScalar degrees_ = SkFloatToScalar(degrees);
199 SkScalar px_ = SkFloatToScalar(px);
200 SkScalar py_ = SkFloatToScalar(py);
201 return obj->postRotate(degrees_, px_, py_);
202 }
203
postRotate__F(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat degrees)204 static jboolean postRotate__F(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat degrees) {
205 SkScalar degrees_ = SkFloatToScalar(degrees);
206 return obj->postRotate(degrees_);
207 }
208
postSkew__FFFF(JNIEnv * env,jobject clazz,SkMatrix * obj,jfloat kx,jfloat ky,jfloat px,jfloat py)209 static jboolean postSkew__FFFF(JNIEnv* env, jobject clazz, SkMatrix* obj, jfloat kx, jfloat ky, jfloat px, jfloat py) {
210 SkScalar kx_ = SkFloatToScalar(kx);
211 SkScalar ky_ = SkFloatToScalar(ky);
212 SkScalar px_ = SkFloatToScalar(px);
213 SkScalar py_ = SkFloatToScalar(py);
214 return obj->postSkew(kx_, ky_, px_, py_);
215 }
216
postSkew__FF(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloat kx,jfloat ky)217 static jboolean postSkew__FF(JNIEnv* env, jobject clazz, SkMatrix* matrix, jfloat kx, jfloat ky) {
218 SkScalar kx_ = SkFloatToScalar(kx);
219 SkScalar ky_ = SkFloatToScalar(ky);
220 return matrix->postSkew(kx_, ky_);
221 }
222
postConcat(JNIEnv * env,jobject clazz,SkMatrix * matrix,SkMatrix * other)223 static jboolean postConcat(JNIEnv* env, jobject clazz, SkMatrix* matrix, SkMatrix* other) {
224 return matrix->postConcat(*other);
225 }
226
setRectToRect(JNIEnv * env,jobject clazz,SkMatrix * matrix,jobject src,jobject dst,SkMatrix::ScaleToFit stf)227 static jboolean setRectToRect(JNIEnv* env, jobject clazz, SkMatrix* matrix, jobject src, jobject dst, SkMatrix::ScaleToFit stf) {
228 SkRect src_;
229 GraphicsJNI::jrectf_to_rect(env, src, &src_);
230 SkRect dst_;
231 GraphicsJNI::jrectf_to_rect(env, dst, &dst_);
232 return matrix->setRectToRect(src_, dst_, stf);
233 }
234
setPolyToPoly(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloatArray jsrc,int srcIndex,jfloatArray jdst,int dstIndex,int ptCount)235 static jboolean setPolyToPoly(JNIEnv* env, jobject clazz, SkMatrix* matrix,
236 jfloatArray jsrc, int srcIndex,
237 jfloatArray jdst, int dstIndex, int ptCount) {
238 SkASSERT(srcIndex >= 0);
239 SkASSERT(dstIndex >= 0);
240 SkASSERT((unsigned)ptCount <= 4);
241
242 AutoJavaFloatArray autoSrc(env, jsrc, srcIndex + (ptCount << 1));
243 AutoJavaFloatArray autoDst(env, jdst, dstIndex + (ptCount << 1));
244 float* src = autoSrc.ptr() + srcIndex;
245 float* dst = autoDst.ptr() + dstIndex;
246
247 #ifdef SK_SCALAR_IS_FIXED
248 SkPoint srcPt[4], dstPt[4];
249 for (int i = 0; i < ptCount; i++) {
250 int x = i << 1;
251 int y = x + 1;
252 srcPt[i].set(SkFloatToScalar(src[x]), SkFloatToScalar(src[y]));
253 dstPt[i].set(SkFloatToScalar(dst[x]), SkFloatToScalar(dst[y]));
254 }
255 return matrix->setPolyToPoly(srcPt, dstPt, ptCount);
256 #else
257 return matrix->setPolyToPoly((const SkPoint*)src, (const SkPoint*)dst,
258 ptCount);
259 #endif
260 }
261
invert(JNIEnv * env,jobject clazz,SkMatrix * matrix,SkMatrix * inverse)262 static jboolean invert(JNIEnv* env, jobject clazz, SkMatrix* matrix, SkMatrix* inverse) {
263 return matrix->invert(inverse);
264 }
265
mapPoints(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloatArray dst,int dstIndex,jfloatArray src,int srcIndex,int ptCount,bool isPts)266 static void mapPoints(JNIEnv* env, jobject clazz, SkMatrix* matrix,
267 jfloatArray dst, int dstIndex,
268 jfloatArray src, int srcIndex,
269 int ptCount, bool isPts) {
270 SkASSERT(ptCount >= 0);
271 AutoJavaFloatArray autoSrc(env, src, srcIndex + (ptCount << 1));
272 AutoJavaFloatArray autoDst(env, dst, dstIndex + (ptCount << 1));
273 float* srcArray = autoSrc.ptr() + srcIndex;
274 float* dstArray = autoDst.ptr() + dstIndex;
275
276 #ifdef SK_SCALAR_IS_FIXED
277 // we allocate twice the count, 1 set for src, 1 for dst
278 SkAutoSTMalloc<32, SkPoint> storage(ptCount * 2);
279 SkPoint* pts = storage.get();
280 SkPoint* srcPt = pts;
281 SkPoint* dstPt = pts + ptCount;
282
283 int i;
284 for (i = 0; i < ptCount; i++) {
285 srcPt[i].set(SkFloatToScalar(srcArray[i << 1]),
286 SkFloatToScalar(srcArray[(i << 1) + 1]));
287 }
288
289 if (isPts)
290 matrix->mapPoints(dstPt, srcPt, ptCount);
291 else
292 matrix->mapVectors(dstPt, srcPt, ptCount);
293
294 for (i = 0; i < ptCount; i++) {
295 dstArray[i << 1] = SkScalarToFloat(dstPt[i].fX);
296 dstArray[(i << 1) + 1] = SkScalarToFloat(dstPt[i].fY);
297 }
298 #else
299 if (isPts)
300 matrix->mapPoints((SkPoint*)dstArray, (const SkPoint*)srcArray,
301 ptCount);
302 else
303 matrix->mapVectors((SkVector*)dstArray, (const SkVector*)srcArray,
304 ptCount);
305 #endif
306 }
307
mapRect__RectFRectF(JNIEnv * env,jobject clazz,SkMatrix * matrix,jobjectArray dst,jobject src)308 static jboolean mapRect__RectFRectF(JNIEnv* env, jobject clazz, SkMatrix* matrix, jobjectArray dst, jobject src) {
309 SkRect dst_, src_;
310 GraphicsJNI::jrectf_to_rect(env, src, &src_);
311 jboolean rectStaysRect = matrix->mapRect(&dst_, src_);
312 GraphicsJNI::rect_to_jrectf(dst_, env, dst);
313 return rectStaysRect;
314 }
315
mapRadius(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloat radius)316 static jfloat mapRadius(JNIEnv* env, jobject clazz, SkMatrix* matrix, jfloat radius) {
317 return SkScalarToFloat(matrix->mapRadius(SkFloatToScalar(radius)));
318 }
319
getValues(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloatArray values)320 static void getValues(JNIEnv* env, jobject clazz, SkMatrix* matrix, jfloatArray values) {
321 AutoJavaFloatArray autoValues(env, values, 9);
322 float* dst = autoValues.ptr();
323
324 #ifdef SK_SCALAR_IS_FIXED
325 for (int i = 0; i < 6; i++) {
326 dst[i] = SkFixedToFloat(matrix->get(i));
327 }
328 for (int j = 6; j < 9; j++) {
329 dst[j] = SkFractToFloat(matrix->get(j));
330 }
331 #else
332 for (int i = 0; i < 9; i++) {
333 dst[i] = matrix->get(i);
334 }
335 #endif
336 }
337
setValues(JNIEnv * env,jobject clazz,SkMatrix * matrix,jfloatArray values)338 static void setValues(JNIEnv* env, jobject clazz, SkMatrix* matrix, jfloatArray values) {
339 AutoJavaFloatArray autoValues(env, values, 9);
340 const float* src = autoValues.ptr();
341
342 #ifdef SK_SCALAR_IS_FIXED
343 for (int i = 0; i < 6; i++) {
344 matrix->set(i, SkFloatToFixed(src[i]));
345 }
346 for (int j = 6; j < 9; j++) {
347 matrix->set(j, SkFloatToFract(src[j]));
348 }
349 #else
350 for (int i = 0; i < 9; i++) {
351 matrix->set(i, src[i]);
352 }
353 #endif
354 }
355
equals(JNIEnv * env,jobject clazz,const SkMatrix * a,const SkMatrix * b)356 static jboolean equals(JNIEnv* env, jobject clazz, const SkMatrix* a, const SkMatrix* b) {
357 return *a == *b;
358 }
359 };
360
361 static JNINativeMethod methods[] = {
362 {"finalizer", "(I)V", (void*) SkMatrixGlue::finalizer},
363 {"native_create","(I)I", (void*) SkMatrixGlue::create},
364 {"native_isIdentity","(I)Z", (void*) SkMatrixGlue::isIdentity},
365 {"native_rectStaysRect","(I)Z", (void*) SkMatrixGlue::rectStaysRect},
366 {"native_reset","(I)V", (void*) SkMatrixGlue::reset},
367 {"native_set","(II)V", (void*) SkMatrixGlue::set},
368 {"native_setTranslate","(IFF)V", (void*) SkMatrixGlue::setTranslate},
369 {"native_setScale","(IFFFF)V", (void*) SkMatrixGlue::setScale__FFFF},
370 {"native_setScale","(IFF)V", (void*) SkMatrixGlue::setScale__FF},
371 {"native_setRotate","(IFFF)V", (void*) SkMatrixGlue::setRotate__FFF},
372 {"native_setRotate","(IF)V", (void*) SkMatrixGlue::setRotate__F},
373 {"native_setSinCos","(IFFFF)V", (void*) SkMatrixGlue::setSinCos__FFFF},
374 {"native_setSinCos","(IFF)V", (void*) SkMatrixGlue::setSinCos__FF},
375 {"native_setSkew","(IFFFF)V", (void*) SkMatrixGlue::setSkew__FFFF},
376 {"native_setSkew","(IFF)V", (void*) SkMatrixGlue::setSkew__FF},
377 {"native_setConcat","(III)Z", (void*) SkMatrixGlue::setConcat},
378 {"native_preTranslate","(IFF)Z", (void*) SkMatrixGlue::preTranslate},
379 {"native_preScale","(IFFFF)Z", (void*) SkMatrixGlue::preScale__FFFF},
380 {"native_preScale","(IFF)Z", (void*) SkMatrixGlue::preScale__FF},
381 {"native_preRotate","(IFFF)Z", (void*) SkMatrixGlue::preRotate__FFF},
382 {"native_preRotate","(IF)Z", (void*) SkMatrixGlue::preRotate__F},
383 {"native_preSkew","(IFFFF)Z", (void*) SkMatrixGlue::preSkew__FFFF},
384 {"native_preSkew","(IFF)Z", (void*) SkMatrixGlue::preSkew__FF},
385 {"native_preConcat","(II)Z", (void*) SkMatrixGlue::preConcat},
386 {"native_postTranslate","(IFF)Z", (void*) SkMatrixGlue::postTranslate},
387 {"native_postScale","(IFFFF)Z", (void*) SkMatrixGlue::postScale__FFFF},
388 {"native_postScale","(IFF)Z", (void*) SkMatrixGlue::postScale__FF},
389 {"native_postRotate","(IFFF)Z", (void*) SkMatrixGlue::postRotate__FFF},
390 {"native_postRotate","(IF)Z", (void*) SkMatrixGlue::postRotate__F},
391 {"native_postSkew","(IFFFF)Z", (void*) SkMatrixGlue::postSkew__FFFF},
392 {"native_postSkew","(IFF)Z", (void*) SkMatrixGlue::postSkew__FF},
393 {"native_postConcat","(II)Z", (void*) SkMatrixGlue::postConcat},
394 {"native_setRectToRect","(ILandroid/graphics/RectF;Landroid/graphics/RectF;I)Z", (void*) SkMatrixGlue::setRectToRect},
395 {"native_setPolyToPoly","(I[FI[FII)Z", (void*) SkMatrixGlue::setPolyToPoly},
396 {"native_invert","(II)Z", (void*) SkMatrixGlue::invert},
397 {"native_mapPoints","(I[FI[FIIZ)V", (void*) SkMatrixGlue::mapPoints},
398 {"native_mapRect","(ILandroid/graphics/RectF;Landroid/graphics/RectF;)Z", (void*) SkMatrixGlue::mapRect__RectFRectF},
399 {"native_mapRadius","(IF)F", (void*) SkMatrixGlue::mapRadius},
400 {"native_getValues","(I[F)V", (void*) SkMatrixGlue::getValues},
401 {"native_setValues","(I[F)V", (void*) SkMatrixGlue::setValues},
402 {"native_equals", "(II)Z", (void*) SkMatrixGlue::equals}
403 };
404
405 static jfieldID sNativeInstanceField;
406
register_android_graphics_Matrix(JNIEnv * env)407 int register_android_graphics_Matrix(JNIEnv* env) {
408 int result = AndroidRuntime::registerNativeMethods(env, "android/graphics/Matrix", methods,
409 sizeof(methods) / sizeof(methods[0]));
410
411 jclass clazz = env->FindClass("android/graphics/Matrix");
412 sNativeInstanceField = env->GetFieldID(clazz, "native_instance", "I");
413
414 return result;
415 }
416
android_graphics_Matrix_getSkMatrix(JNIEnv * env,jobject matrixObj)417 SkMatrix* android_graphics_Matrix_getSkMatrix(JNIEnv* env, jobject matrixObj) {
418 return reinterpret_cast<SkMatrix*>(env->GetIntField(matrixObj, sNativeInstanceField));
419 }
420
421 }
422