summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorWu-cheng Li <wuchengli@google.com>2011-08-11 16:46:47 +0800
committerWu-cheng Li <wuchengli@google.com>2011-08-11 18:49:36 +0800
commitd2db70880e6159413932f747eb82df3e925852c1 (patch)
treee626a4edb7f69f5ae21b4191315779beb515c6bc /tests
parent142402d57c1689c1342d096c976b9b0826f8ce1a (diff)
downloadLegacyCamera-d2db70880e6159413932f747eb82df3e925852c1.zip
LegacyCamera-d2db70880e6159413932f747eb82df3e925852c1.tar.gz
LegacyCamera-d2db70880e6159413932f747eb82df3e925852c1.tar.bz2
Use matrix to transform the location of faces.
bug:5141019 Change-Id: Id4bb82cee5fd788689fb18bb199504d963c5d3a2
Diffstat (limited to 'tests')
-rw-r--r--tests/src/com/android/camera/unittest/CameraTest.java39
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/src/com/android/camera/unittest/CameraTest.java b/tests/src/com/android/camera/unittest/CameraTest.java
index b0aa13b..1e17635 100644
--- a/tests/src/com/android/camera/unittest/CameraTest.java
+++ b/tests/src/com/android/camera/unittest/CameraTest.java
@@ -17,8 +17,11 @@
package com.android.camera.unittest;
import com.android.camera.Camera;
+import com.android.camera.Util;
+import android.graphics.Matrix;
import android.graphics.Rect;
+import android.graphics.RectF;
import android.test.suitebuilder.annotation.SmallTest;
import junit.framework.TestCase;
@@ -56,4 +59,40 @@ public class CameraTest extends TestCase {
Camera.convertToFocusArea(860, 620, 100, 100, 960, 720, rect);
assertEquals(new Rect(792, 722, 1000, 1000), rect);
}
+
+ public void testPrepareMatrix() {
+ Matrix matrix = new Matrix();
+ float[] points;
+ int[] expected;
+
+ Util.prepareMatrix(matrix, false, 0, 800, 480);
+ points = new float[] {-1000, -1000, 0, 0, 1000, 1000, 0, 1000, -750, 250};
+ expected = new int[] {0, 0, 400, 240, 800, 480, 400, 480, 100, 300};
+ matrix.mapPoints(points);
+ assertEquals(expected, points);
+
+ Util.prepareMatrix(matrix, false, 90, 800, 480);
+ points = new float[] {-1000, -1000, 0, 0, 1000, 1000, 0, 1000, -750, 250};
+ expected = new int[] {800, 0, 400, 240, 0, 480, 0, 240, 300, 60};
+ matrix.mapPoints(points);
+ assertEquals(expected, points);
+
+ Util.prepareMatrix(matrix, false, 180, 800, 480);
+ points = new float[] {-1000, -1000, 0, 0, 1000, 1000, 0, 1000, -750, 250};
+ expected = new int[] {800, 480, 400, 240, 0, 0, 400, 0, 700, 180};
+ matrix.mapPoints(points);
+ assertEquals(expected, points);
+
+ Util.prepareMatrix(matrix, true, 180, 800, 480);
+ points = new float[] {-1000, -1000, 0, 0, 1000, 1000, 0, 1000, -750, 250};
+ expected = new int[] {0, 480, 400, 240, 800, 0, 400, 0, 100, 180};
+ matrix.mapPoints(points);
+ assertEquals(expected, points);
+ }
+
+ private void assertEquals(int expected[], float[] actual) {
+ for (int i = 0; i < expected.length; i++) {
+ assertEquals("Array index " + i + " mismatch", expected[i], Math.round(actual[i]));
+ }
+ }
}