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