summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Zixuan Qu <zixuanqu@google.com> 2023-02-22 18:59:31 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2023-02-22 18:59:31 +0000
commiteaef40dc0abfbbfaf0c1c13e891dc3ad98d09247 (patch)
treeb9aa88b6ef107b4544d7e54d4cf0dd47e6876e85
parent6b7a9c8c119e9ff421fd98654655791022cd4199 (diff)
parenteb60a2559f47b35ba0b5973b61d87948409c6e7f (diff)
Merge "Add int range for touchscreen pointer id." into udc-dev
-rw-r--r--core/api/system-current.txt2
-rw-r--r--core/java/android/hardware/input/VirtualTouchEvent.java15
2 files changed, 15 insertions, 2 deletions
diff --git a/core/api/system-current.txt b/core/api/system-current.txt
index c14de7029a16..8c0a9175fe94 100644
--- a/core/api/system-current.txt
+++ b/core/api/system-current.txt
@@ -5117,7 +5117,7 @@ package android.hardware.input {
method @NonNull public android.hardware.input.VirtualTouchEvent build();
method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setAction(int);
method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setMajorAxisSize(@FloatRange(from=0.0f) float);
- method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setPointerId(int);
+ method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setPointerId(@IntRange(from=0, to=0x10 - 1) int);
method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setPressure(@FloatRange(from=0.0f) float);
method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setToolType(int);
method @NonNull public android.hardware.input.VirtualTouchEvent.Builder setX(float);
diff --git a/core/java/android/hardware/input/VirtualTouchEvent.java b/core/java/android/hardware/input/VirtualTouchEvent.java
index 9b1e6e84a022..a2bb382e9950 100644
--- a/core/java/android/hardware/input/VirtualTouchEvent.java
+++ b/core/java/android/hardware/input/VirtualTouchEvent.java
@@ -18,6 +18,7 @@ package android.hardware.input;
import android.annotation.FloatRange;
import android.annotation.IntDef;
+import android.annotation.IntRange;
import android.annotation.NonNull;
import android.annotation.SystemApi;
import android.os.Parcel;
@@ -82,6 +83,10 @@ public final class VirtualTouchEvent implements Parcelable {
@Retention(RetentionPolicy.SOURCE)
public @interface Action {}
+ // The maximum number of pointers that can be touching the screen at once. (See MAX_POINTERS
+ // in frameworks/native/include/input/Input.h)
+ private static final int MAX_POINTERS = 16;
+
private final int mPointerId;
private final @ToolType int mToolType;
private final @Action int mAction;
@@ -214,9 +219,17 @@ public final class VirtualTouchEvent implements Parcelable {
/**
* Sets the pointer id of the event.
*
+ * <p>A Valid pointer id need to be in the range of 0 to 15.
+ *
* @return this builder, to allow for chaining of calls
*/
- public @NonNull Builder setPointerId(int pointerId) {
+ public @NonNull Builder setPointerId(
+ @IntRange(from = 0, to = MAX_POINTERS - 1) int pointerId) {
+ if (pointerId < 0 || pointerId > 15) {
+ throw new IllegalArgumentException(
+ "The pointer id must be in the range 0 - " + (MAX_POINTERS - 1)
+ + "inclusive, but was: " + pointerId);
+ }
mPointerId = pointerId;
return this;
}