diff options
author | Android (Google) Code Review <android-gerrit@google.com> | 2009-05-28 14:34:28 -0700 |
---|---|---|
committer | The Android Open Source Project <initial-contribution@android.com> | 2009-05-28 14:34:28 -0700 |
commit | 96cdc61c69aa735e65295a50e3e2922425b3c877 (patch) | |
tree | 7d88100a2f15856e87086c6dee8a85cad656e1a4 /core/java | |
parent | aebadd2cf489948847f262d917ee39cb285815b3 (diff) | |
parent | 1e2e44e900cb9a25d548e27a20d65292a7f321bc (diff) | |
download | frameworks_base-96cdc61c69aa735e65295a50e3e2922425b3c877.zip frameworks_base-96cdc61c69aa735e65295a50e3e2922425b3c877.tar.gz frameworks_base-96cdc61c69aa735e65295a50e3e2922425b3c877.tar.bz2 |
am 1e2e44e9: Merge change 2365 into donut
Merge commit '1e2e44e900cb9a25d548e27a20d65292a7f321bc'
* commit '1e2e44e900cb9a25d548e27a20d65292a7f321bc':
Fix wifi multicast API for public use.
Revert "Bug fixes and performance improvements"
Diffstat (limited to 'core/java')
-rw-r--r-- | core/java/android/gesture/GestureLibrary.java | 10 | ||||
-rw-r--r-- | core/java/android/gesture/GestureStroke.java | 11 | ||||
-rwxr-xr-x | core/java/android/gesture/GestureUtilities.java | 44 | ||||
-rwxr-xr-x | core/java/android/gesture/Instance.java | 32 | ||||
-rw-r--r-- | core/java/android/gesture/InstanceLearner.java | 9 |
5 files changed, 41 insertions, 65 deletions
diff --git a/core/java/android/gesture/GestureLibrary.java b/core/java/android/gesture/GestureLibrary.java index 9020d2b..1cf192e 100644 --- a/core/java/android/gesture/GestureLibrary.java +++ b/core/java/android/gesture/GestureLibrary.java @@ -136,7 +136,7 @@ public class GestureLibrary { * @return a list of predictions of possible entries for a given gesture */ public ArrayList<Prediction> recognize(Gesture gesture) { - Instance instance = Instance.createInstance(mSequenceType, mOrientationStyle, gesture, null); + Instance instance = Instance.createInstance(mSequenceType, gesture, null); return mClassifier.classify(mSequenceType, instance.vector); } @@ -156,7 +156,7 @@ public class GestureLibrary { mNamedGestures.put(entryName, gestures); } gestures.add(gesture); - mClassifier.addInstance(Instance.createInstance(mSequenceType, mOrientationStyle, gesture, entryName)); + mClassifier.addInstance(Instance.createInstance(mSequenceType, gesture, entryName)); mChanged = true; } @@ -337,14 +337,10 @@ public class GestureLibrary { for (int j = 0; j < gestureCount; j++) { final Gesture gesture = Gesture.deserialize(in); gestures.add(gesture); - classifier.addInstance(Instance.createInstance(mSequenceType, mOrientationStyle, gesture, name)); + classifier.addInstance(Instance.createInstance(mSequenceType, gesture, name)); } namedGestures.put(name, gestures); } } - - Learner getLearner() { - return mClassifier; - } } diff --git a/core/java/android/gesture/GestureStroke.java b/core/java/android/gesture/GestureStroke.java index 90faaed..0d7bc2d 100644 --- a/core/java/android/gesture/GestureStroke.java +++ b/core/java/android/gesture/GestureStroke.java @@ -17,6 +17,7 @@ package android.gesture; import android.graphics.Canvas; +import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.Path; import android.graphics.RectF; @@ -146,12 +147,10 @@ public class GestureStroke { final float[] pts = GestureUtilities.temporalSampling(this, numSample); final RectF rect = boundingBox; - GestureUtilities.translate(pts, -rect.left, -rect.top); - - float sx = width / rect.width(); - float sy = height / rect.height(); - float scale = sx > sy ? sy : sx; - GestureUtilities.scale(pts, scale, scale); + final Matrix matrix = new Matrix(); + matrix.setTranslate(-rect.left, -rect.top); + matrix.postScale(width / rect.width(), height / rect.height()); + matrix.mapPoints(pts); float mX = 0; float mY = 0; diff --git a/core/java/android/gesture/GestureUtilities.java b/core/java/android/gesture/GestureUtilities.java index 3e8a3c8..4a3144c 100755 --- a/core/java/android/gesture/GestureUtilities.java +++ b/core/java/android/gesture/GestureUtilities.java @@ -17,6 +17,7 @@ package android.gesture; import android.graphics.RectF; +import android.graphics.Matrix; import android.util.Log; import java.util.ArrayList; @@ -379,17 +380,22 @@ final class GestureUtilities { } static OrientedBoundingBox computeOrientedBoundingBox(float[] points, float[] centroid) { - translate(points, -centroid[0], -centroid[1]); + Matrix tr = new Matrix(); + tr.setTranslate(-centroid[0], -centroid[1]); + tr.mapPoints(points); double[][] array = computeCoVariance(points); double[] targetVector = computeOrientation(array); float angle; if (targetVector[0] == 0 && targetVector[1] == 0) { - angle = (float) -Math.PI/2; + angle = -90; } else { // -PI<alpha<PI angle = (float) Math.atan2(targetVector[1], targetVector[0]); - rotate(points, -angle); + angle = (float) (180 * angle / Math.PI); + Matrix trans = new Matrix(); + trans.setRotate(-angle); + trans.mapPoints(points); } float minx = Float.MAX_VALUE; @@ -440,36 +446,4 @@ final class GestureUtilities { } return targetVector; } - - - static float[] rotate(float[] points, double angle) { - double cos = Math.cos(angle); - double sin = Math.sin(angle); - int size = points.length; - for (int i = 0; i < size; i += 2) { - float x = (float) (points[i] * cos - points[i + 1] * sin); - float y = (float) (points[i] * sin + points[i + 1] * cos); - points[i] = x; - points[i + 1] = y; - } - return points; - } - - static float[] translate(float[] points, float dx, float dy) { - int size = points.length; - for (int i = 0; i < size; i += 2) { - points[i] += dx; - points[i + 1] += dy; - } - return points; - } - - static float[] scale(float[] points, float sx, float sy) { - int size = points.length; - for (int i = 0; i < size; i += 2) { - points[i] *= sx; - points[i + 1] *= sy; - } - return points; - } } diff --git a/core/java/android/gesture/Instance.java b/core/java/android/gesture/Instance.java index 9ac0a96..7922fab 100755 --- a/core/java/android/gesture/Instance.java +++ b/core/java/android/gesture/Instance.java @@ -16,6 +16,7 @@ package android.gesture; +import android.graphics.Matrix; /** * An instance represents a sample if the label is available or a query if the @@ -27,9 +28,7 @@ class Instance { private static final int PATCH_SAMPLE_SIZE = 16; private final static float[] ORIENTATIONS = { - 0, (float) (Math.PI / 4), (float) (Math.PI / 2), (float) (Math.PI * 3 / 4), - (float) Math.PI, -0, (float) (-Math.PI / 4), (float) (-Math.PI / 2), - (float) (-Math.PI * 3 / 4), (float) -Math.PI + 0, 45, 90, 135, 180, -0, -45, -90, -135, -180 }; // the feature vector @@ -40,13 +39,13 @@ class Instance { // the id of the instance final long id; - + private Instance(long id, float[] sample, String sampleName) { this.id = id; vector = sample; label = sampleName; } - + private void normalize() { float[] sample = vector; float sum = 0; @@ -56,7 +55,7 @@ class Instance { sum += sample[i] * sample[i]; } - float magnitude = (float)Math.sqrt(sum); + float magnitude = (float) Math.sqrt(sum); for (int i = 0; i < size; i++) { sample[i] /= magnitude; } @@ -69,11 +68,11 @@ class Instance { * @param label * @return the instance */ - static Instance createInstance(int sequenceType, int orientationType, Gesture gesture, String label) { + static Instance createInstance(int samplingType, Gesture gesture, String label) { float[] pts; Instance instance; - if (sequenceType == GestureLibrary.SEQUENCE_SENSITIVE) { - pts = temporalSampler(orientationType, gesture); + if (samplingType == GestureLibrary.SEQUENCE_SENSITIVE) { + pts = temporalSampler(samplingType, gesture); instance = new Instance(gesture.getID(), pts, label); instance.normalize(); } else { @@ -82,19 +81,20 @@ class Instance { } return instance; } - + private static float[] spatialSampler(Gesture gesture) { return GestureUtilities.spatialSampling(gesture, PATCH_SAMPLE_SIZE); } - private static float[] temporalSampler(int orientationType, Gesture gesture) { + private static float[] temporalSampler(int samplingType, Gesture gesture) { float[] pts = GestureUtilities.temporalSampling(gesture.getStrokes().get(0), SEQUENCE_SAMPLE_SIZE); float[] center = GestureUtilities.computeCentroid(pts); - float orientation = (float)Math.atan2(pts[1] - center[1], pts[0] - center[0]); + float orientation = (float) Math.atan2(pts[1] - center[1], pts[0] - center[0]); + orientation *= 180 / Math.PI; float adjustment = -orientation; - if (orientationType == GestureLibrary.ORIENTATION_SENSITIVE) { + if (samplingType == GestureLibrary.ORIENTATION_SENSITIVE) { int count = ORIENTATIONS.length; for (int i = 0; i < count; i++) { float delta = ORIENTATIONS[i] - orientation; @@ -104,8 +104,10 @@ class Instance { } } - GestureUtilities.translate(pts, -center[0], -center[1]); - GestureUtilities.rotate(pts, adjustment); + Matrix m = new Matrix(); + m.setTranslate(-center[0], -center[1]); + m.postRotate(adjustment); + m.mapPoints(pts); return pts; } diff --git a/core/java/android/gesture/InstanceLearner.java b/core/java/android/gesture/InstanceLearner.java index b6feb64..1739cdc 100644 --- a/core/java/android/gesture/InstanceLearner.java +++ b/core/java/android/gesture/InstanceLearner.java @@ -16,9 +16,14 @@ package android.gesture; +import android.util.Config; +import android.util.Log; +import static android.gesture.GestureConstants.*; + import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; +import java.util.Iterator; import java.util.TreeMap; /** @@ -27,7 +32,7 @@ import java.util.TreeMap; class InstanceLearner extends Learner { @Override - ArrayList<Prediction> classify(int sequenceType, float[] vector) { + ArrayList<Prediction> classify(int gestureType, float[] vector) { ArrayList<Prediction> predictions = new ArrayList<Prediction>(); ArrayList<Instance> instances = getInstances(); int count = instances.size(); @@ -38,7 +43,7 @@ class InstanceLearner extends Learner { continue; } double distance; - if (sequenceType == GestureLibrary.SEQUENCE_SENSITIVE) { + if (gestureType == GestureLibrary.SEQUENCE_SENSITIVE) { distance = GestureUtilities.cosineDistance(sample.vector, vector); } else { distance = GestureUtilities.squaredEuclideanDistance(sample.vector, vector); |