summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDake Gu <dake@google.com>2013-02-06 15:01:17 -0800
committerAndroid Git Automerger <android-git-automerger@android.com>2013-02-06 15:01:17 -0800
commitbfb64e85e608889f18f4273b0f07a3d91d4082bd (patch)
treeea9cc5f955908cacd56db4f499cecb6d4ccdda5a
parent044a4c3e4a42aae4faac8b92ea05f122cdf45f7c (diff)
parent96111ddff7af61ce37fa8d9020d8e1eeba9095e8 (diff)
am 96111ddf: Merge "SimulatdDpad: fix NPE for event without device" into jb-mr1-aah-dev
# Via Android (Google) Code Review (1) and Dake Gu (1) * commit '96111ddff7af61ce37fa8d9020d8e1eeba9095e8': SimulatdDpad: fix NPE for event without device
-rw-r--r--core/java/android/view/SimulatedDpad.java8
1 files changed, 6 insertions, 2 deletions
diff --git a/core/java/android/view/SimulatedDpad.java b/core/java/android/view/SimulatedDpad.java
index 0a37fddfa805..b03e4c71ec06 100644
--- a/core/java/android/view/SimulatedDpad.java
+++ b/core/java/android/view/SimulatedDpad.java
@@ -145,6 +145,10 @@ class SimulatedDpad {
if (!synthesizeNewKeys) {
mHandler.removeMessages(MSG_FLICK);
}
+ InputDevice device = event.getDevice();
+ if (device == null) {
+ return;
+ }
// Store what time the touchpad event occurred
final long time = SystemClock.uptimeMillis();
switch (event.getAction()) {
@@ -157,7 +161,7 @@ class SimulatedDpad {
mAccumulatedY = 0;
mLastMoveX = 0;
mLastMoveY = 0;
- if (event.getDevice().getMotionRange(MotionEvent.AXIS_Y).getMax()
+ if (device.getMotionRange(MotionEvent.AXIS_Y).getMax()
* EDGE_SWIPE_THRESHOLD < event.getY()) {
// Did the swipe begin in a valid region
mEdgeSwipePossible = true;
@@ -176,7 +180,7 @@ class SimulatedDpad {
}
// Checks if the swipe has crossed the midpoint
// and if our swipe gesture is complete
- if (event.getY() < (event.getDevice().getMotionRange(MotionEvent.AXIS_Y).getMax()
+ if (event.getY() < (device.getMotionRange(MotionEvent.AXIS_Y).getMax()
* .5) && mEdgeSwipePossible) {
mEdgeSwipePossible = false;