blob: 438a1a0351b2cd0b6e61cbf10c9ba7ee3aa38b14 [file] [log] [blame]
Jeff Browne839a582010-04-22 18:58:52 -07001/*
2 * Copyright (C) 2010 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef _UI_INPUT_H
18#define _UI_INPUT_H
19
20/**
21 * Native input event structures.
22 */
23
24#include <android/input.h>
25#include <utils/Vector.h>
Jeff Browne57e8952010-07-23 21:28:06 -070026#include <utils/KeyedVector.h>
Jeff Browne839a582010-04-22 18:58:52 -070027#include <utils/Timers.h>
Jeff Browne57e8952010-07-23 21:28:06 -070028#include <utils/RefBase.h>
29#include <utils/String8.h>
Jeff Brownfa773aa2011-03-09 17:39:48 -080030#include <utils/BitSet.h>
Jeff Browne839a582010-04-22 18:58:52 -070031
Jeff Brown3e341462011-02-14 17:03:18 -080032#ifdef HAVE_ANDROID_OS
33class SkMatrix;
34#endif
35
Jeff Browne839a582010-04-22 18:58:52 -070036/*
37 * Additional private constants not defined in ndk/ui/input.h.
38 */
39enum {
Jeff Brown3847f622011-02-28 18:27:14 -080040 /* Private control to determine when an app is tracking a key sequence. */
41 AKEY_EVENT_FLAG_START_TRACKING = 0x40000000,
42
43 /* Key event is inconsistent with previously sent key events. */
44 AKEY_EVENT_FLAG_TAINTED = 0x80000000,
45};
46
47enum {
48 /* Motion event is inconsistent with previously sent motion events. */
49 AMOTION_EVENT_FLAG_TAINTED = 0x80000000,
Jeff Browne839a582010-04-22 18:58:52 -070050};
51
Jeff Brown430c21e2011-01-19 18:41:38 -080052enum {
53 /*
54 * Indicates that an input device has switches.
55 * This input source flag is hidden from the API because switches are only used by the system
56 * and applications have no way to interact with them.
57 */
58 AINPUT_SOURCE_SWITCH = 0x80000000,
59};
60
Jeff Browne839a582010-04-22 18:58:52 -070061/*
Jeff Brown80f3e7c2011-03-02 14:41:58 -080062 * SystemUiVisibility constants from View.
63 */
64enum {
65 ASYSTEM_UI_VISIBILITY_STATUS_BAR_VISIBLE = 0,
66 ASYSTEM_UI_VISIBILITY_STATUS_BAR_HIDDEN = 0x00000001,
67};
68
69/*
Jeff Browne839a582010-04-22 18:58:52 -070070 * Maximum number of pointers supported per motion event.
Jeff Brownd1b0a2b2010-09-26 22:20:12 -070071 * Smallest number of pointers is 1.
Jeff Browneb8b9d82011-01-25 16:02:22 -080072 * (We want at least 10 but some touch controllers obstensibly configured for 10 pointers
73 * will occasionally emit 11. There is not much harm making this constant bigger.)
Jeff Browne839a582010-04-22 18:58:52 -070074 */
Jeff Browneb8b9d82011-01-25 16:02:22 -080075#define MAX_POINTERS 16
Jeff Browne839a582010-04-22 18:58:52 -070076
Dianne Hackborn4d96bb62010-06-18 18:09:33 -070077/*
Jeff Brownd1b0a2b2010-09-26 22:20:12 -070078 * Maximum pointer id value supported in a motion event.
79 * Smallest pointer id is 0.
80 * (This is limited by our use of BitSet32 to track pointer assignments.)
81 */
82#define MAX_POINTER_ID 31
83
84/*
Dianne Hackborn4d96bb62010-06-18 18:09:33 -070085 * Declare a concrete type for the NDK's input event forward declaration.
86 */
Dianne Hackbornce838a22010-07-13 17:48:30 -070087struct AInputEvent {
88 virtual ~AInputEvent() { }
89};
Dianne Hackborn4d96bb62010-06-18 18:09:33 -070090
Jeff Browne839a582010-04-22 18:58:52 -070091/*
Jeff Browne57e8952010-07-23 21:28:06 -070092 * Declare a concrete type for the NDK's input device forward declaration.
Jeff Browne839a582010-04-22 18:58:52 -070093 */
Jeff Browne57e8952010-07-23 21:28:06 -070094struct AInputDevice {
95 virtual ~AInputDevice() { }
Jeff Browne839a582010-04-22 18:58:52 -070096};
97
Jeff Browne57e8952010-07-23 21:28:06 -070098
99namespace android {
100
Jeff Brown3e341462011-02-14 17:03:18 -0800101#ifdef HAVE_ANDROID_OS
102class Parcel;
103#endif
104
Jeff Browne839a582010-04-22 18:58:52 -0700105/*
106 * Flags that flow alongside events in the input dispatch system to help with certain
107 * policy decisions such as waking from device sleep.
Jeff Brown90f0cee2010-10-08 22:31:17 -0700108 *
109 * These flags are also defined in frameworks/base/core/java/android/view/WindowManagerPolicy.java.
Jeff Browne839a582010-04-22 18:58:52 -0700110 */
111enum {
Jeff Brown956c0fb2010-10-01 14:55:30 -0700112 /* These flags originate in RawEvents and are generally set in the key map.
Jeff Brown6a817e22010-09-12 17:55:08 -0700113 * NOTE: If you edit these flags, also edit labels in KeycodeLabels.h. */
Jeff Browne839a582010-04-22 18:58:52 -0700114
115 POLICY_FLAG_WAKE = 0x00000001,
116 POLICY_FLAG_WAKE_DROPPED = 0x00000002,
117 POLICY_FLAG_SHIFT = 0x00000004,
118 POLICY_FLAG_CAPS_LOCK = 0x00000008,
119 POLICY_FLAG_ALT = 0x00000010,
120 POLICY_FLAG_ALT_GR = 0x00000020,
121 POLICY_FLAG_MENU = 0x00000040,
122 POLICY_FLAG_LAUNCHER = 0x00000080,
Jeff Brown956c0fb2010-10-01 14:55:30 -0700123 POLICY_FLAG_VIRTUAL = 0x00000100,
Jeff Brown6a817e22010-09-12 17:55:08 -0700124 POLICY_FLAG_FUNCTION = 0x00000200,
Jeff Browne839a582010-04-22 18:58:52 -0700125
Jeff Brown51d45a72010-06-17 20:52:56 -0700126 POLICY_FLAG_RAW_MASK = 0x0000ffff,
127
Jeff Brownaf30ff62010-09-01 17:01:00 -0700128 /* These flags are set by the input dispatcher. */
129
130 // Indicates that the input event was injected.
131 POLICY_FLAG_INJECTED = 0x01000000,
132
Jeff Brown33d54ce2010-10-11 14:20:19 -0700133 // Indicates that the input event is from a trusted source such as a directly attached
134 // input device or an application with system-wide event injection permission.
135 POLICY_FLAG_TRUSTED = 0x02000000,
136
Jeff Brown37159af2011-03-30 02:25:18 -0700137 // Indicates that the input event has passed through an input filter.
138 POLICY_FLAG_FILTERED = 0x04000000,
139
140 // Disables automatic key repeating behavior.
141 POLICY_FLAG_DISABLE_KEY_REPEAT = 0x08000000,
142
Jeff Brown54bc2812010-06-15 01:31:58 -0700143 /* These flags are set by the input reader policy as it intercepts each event. */
Jeff Browne839a582010-04-22 18:58:52 -0700144
145 // Indicates that the screen was off when the event was received and the event
146 // should wake the device.
147 POLICY_FLAG_WOKE_HERE = 0x10000000,
148
149 // Indicates that the screen was dim when the event was received and the event
150 // should brighten the device.
151 POLICY_FLAG_BRIGHT_HERE = 0x20000000,
Jeff Brown90f0cee2010-10-08 22:31:17 -0700152
153 // Indicates that the event should be dispatched to applications.
154 // The input event should still be sent to the InputDispatcher so that it can see all
155 // input events received include those that it will not deliver.
156 POLICY_FLAG_PASS_TO_USER = 0x40000000,
Jeff Browne839a582010-04-22 18:58:52 -0700157};
158
159/*
Jeff Brown54bc2812010-06-15 01:31:58 -0700160 * Describes the basic configuration of input devices that are present.
161 */
162struct InputConfiguration {
163 enum {
164 TOUCHSCREEN_UNDEFINED = 0,
165 TOUCHSCREEN_NOTOUCH = 1,
166 TOUCHSCREEN_STYLUS = 2,
167 TOUCHSCREEN_FINGER = 3
168 };
169
170 enum {
171 KEYBOARD_UNDEFINED = 0,
172 KEYBOARD_NOKEYS = 1,
173 KEYBOARD_QWERTY = 2,
174 KEYBOARD_12KEY = 3
175 };
176
177 enum {
178 NAVIGATION_UNDEFINED = 0,
179 NAVIGATION_NONAV = 1,
180 NAVIGATION_DPAD = 2,
181 NAVIGATION_TRACKBALL = 3,
182 NAVIGATION_WHEEL = 4
183 };
184
185 int32_t touchScreen;
186 int32_t keyboard;
187 int32_t navigation;
188};
189
190/*
Jeff Browne839a582010-04-22 18:58:52 -0700191 * Pointer coordinate data.
192 */
193struct PointerCoords {
Jeff Brown3ea4de82011-02-19 01:08:02 -0800194 enum { MAX_AXES = 14 }; // 14 so that sizeof(PointerCoords) == 64
Jeff Brown3e341462011-02-14 17:03:18 -0800195
196 // Bitfield of axes that are present in this structure.
Jeff Brown3ea4de82011-02-19 01:08:02 -0800197 uint64_t bits;
Jeff Brown3e341462011-02-14 17:03:18 -0800198
199 // Values of axes that are stored in this structure packed in order by axis id
200 // for each axis that is present in the structure according to 'bits'.
201 float values[MAX_AXES];
202
203 inline void clear() {
204 bits = 0;
205 }
206
Jeff Brown3ea4de82011-02-19 01:08:02 -0800207 float getAxisValue(int32_t axis) const;
208 status_t setAxisValue(int32_t axis, float value);
Jeff Brown3e341462011-02-14 17:03:18 -0800209
Dianne Hackborn16fe3c22011-04-27 18:52:56 -0400210 void scale(float scale);
211
Jeff Brown5873ce42011-07-27 16:04:54 -0700212 inline float getX() const {
213 return getAxisValue(AMOTION_EVENT_AXIS_X);
214 }
215
216 inline float getY() const {
217 return getAxisValue(AMOTION_EVENT_AXIS_Y);
218 }
219
Jeff Brown3e341462011-02-14 17:03:18 -0800220#ifdef HAVE_ANDROID_OS
221 status_t readFromParcel(Parcel* parcel);
222 status_t writeToParcel(Parcel* parcel) const;
223#endif
224
Jeff Brownfa773aa2011-03-09 17:39:48 -0800225 bool operator==(const PointerCoords& other) const;
226 inline bool operator!=(const PointerCoords& other) const {
227 return !(*this == other);
228 }
229
230 void copyFrom(const PointerCoords& other);
231
Jeff Brown3e341462011-02-14 17:03:18 -0800232private:
233 void tooManyAxes(int axis);
Jeff Browne839a582010-04-22 18:58:52 -0700234};
235
236/*
Jeff Browne959ed22011-05-06 18:20:01 -0700237 * Pointer property data.
238 */
239struct PointerProperties {
240 // The id of the pointer.
241 int32_t id;
242
243 // The pointer tool type.
244 int32_t toolType;
245
246 inline void clear() {
247 id = -1;
248 toolType = 0;
249 }
250
251 bool operator==(const PointerProperties& other) const;
252 inline bool operator!=(const PointerProperties& other) const {
253 return !(*this == other);
254 }
255
256 void copyFrom(const PointerProperties& other);
257};
258
259/*
Jeff Browne839a582010-04-22 18:58:52 -0700260 * Input events.
261 */
Dianne Hackborn9c7f8182010-06-28 15:27:30 -0700262class InputEvent : public AInputEvent {
Jeff Browne839a582010-04-22 18:58:52 -0700263public:
264 virtual ~InputEvent() { }
265
266 virtual int32_t getType() const = 0;
267
268 inline int32_t getDeviceId() const { return mDeviceId; }
269
Jeff Brown5c1ed842010-07-14 18:48:53 -0700270 inline int32_t getSource() const { return mSource; }
Jeff Brown3e341462011-02-14 17:03:18 -0800271
272 inline void setSource(int32_t source) { mSource = source; }
273
Jeff Browne839a582010-04-22 18:58:52 -0700274protected:
Jeff Brown5c1ed842010-07-14 18:48:53 -0700275 void initialize(int32_t deviceId, int32_t source);
Dianne Hackborn0e885272010-07-15 17:44:53 -0700276 void initialize(const InputEvent& from);
Jeff Browne839a582010-04-22 18:58:52 -0700277
Jeff Browne839a582010-04-22 18:58:52 -0700278 int32_t mDeviceId;
Jeff Brown5c1ed842010-07-14 18:48:53 -0700279 int32_t mSource;
Jeff Browne839a582010-04-22 18:58:52 -0700280};
281
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700282/*
283 * Key events.
284 */
Jeff Browne839a582010-04-22 18:58:52 -0700285class KeyEvent : public InputEvent {
286public:
287 virtual ~KeyEvent() { }
288
Jeff Brown5c1ed842010-07-14 18:48:53 -0700289 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_KEY; }
Jeff Browne839a582010-04-22 18:58:52 -0700290
291 inline int32_t getAction() const { return mAction; }
292
293 inline int32_t getFlags() const { return mFlags; }
294
295 inline int32_t getKeyCode() const { return mKeyCode; }
296
297 inline int32_t getScanCode() const { return mScanCode; }
298
299 inline int32_t getMetaState() const { return mMetaState; }
300
301 inline int32_t getRepeatCount() const { return mRepeatCount; }
302
303 inline nsecs_t getDownTime() const { return mDownTime; }
304
305 inline nsecs_t getEventTime() const { return mEventTime; }
306
Dianne Hackborn189ed232010-06-29 19:20:40 -0700307 // Return true if this event may have a default action implementation.
308 static bool hasDefaultAction(int32_t keyCode);
309 bool hasDefaultAction() const;
310
311 // Return true if this event represents a system key.
312 static bool isSystemKey(int32_t keyCode);
313 bool isSystemKey() const;
314
Jeff Browne839a582010-04-22 18:58:52 -0700315 void initialize(
316 int32_t deviceId,
Jeff Brown5c1ed842010-07-14 18:48:53 -0700317 int32_t source,
Jeff Browne839a582010-04-22 18:58:52 -0700318 int32_t action,
319 int32_t flags,
320 int32_t keyCode,
321 int32_t scanCode,
322 int32_t metaState,
323 int32_t repeatCount,
324 nsecs_t downTime,
325 nsecs_t eventTime);
Dianne Hackborn0e885272010-07-15 17:44:53 -0700326 void initialize(const KeyEvent& from);
Jeff Browne839a582010-04-22 18:58:52 -0700327
Jeff Brown3e341462011-02-14 17:03:18 -0800328protected:
Jeff Browne839a582010-04-22 18:58:52 -0700329 int32_t mAction;
330 int32_t mFlags;
331 int32_t mKeyCode;
332 int32_t mScanCode;
333 int32_t mMetaState;
334 int32_t mRepeatCount;
335 nsecs_t mDownTime;
336 nsecs_t mEventTime;
337};
338
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700339/*
340 * Motion events.
341 */
Jeff Browne839a582010-04-22 18:58:52 -0700342class MotionEvent : public InputEvent {
343public:
344 virtual ~MotionEvent() { }
345
Jeff Brown5c1ed842010-07-14 18:48:53 -0700346 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_MOTION; }
Jeff Browne839a582010-04-22 18:58:52 -0700347
348 inline int32_t getAction() const { return mAction; }
349
Jeff Brown15933542011-03-14 19:39:54 -0700350 inline int32_t getActionMasked() const { return mAction & AMOTION_EVENT_ACTION_MASK; }
351
352 inline int32_t getActionIndex() const {
353 return (mAction & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK)
354 >> AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
355 }
356
Jeff Brown3e341462011-02-14 17:03:18 -0800357 inline void setAction(int32_t action) { mAction = action; }
358
Jeff Brownaf30ff62010-09-01 17:01:00 -0700359 inline int32_t getFlags() const { return mFlags; }
360
Jeff Brown3847f622011-02-28 18:27:14 -0800361 inline void setFlags(int32_t flags) { mFlags = flags; }
362
Jeff Browne839a582010-04-22 18:58:52 -0700363 inline int32_t getEdgeFlags() const { return mEdgeFlags; }
364
Jeff Brown3e341462011-02-14 17:03:18 -0800365 inline void setEdgeFlags(int32_t edgeFlags) { mEdgeFlags = edgeFlags; }
366
Jeff Browne839a582010-04-22 18:58:52 -0700367 inline int32_t getMetaState() const { return mMetaState; }
368
Jeff Brown3e341462011-02-14 17:03:18 -0800369 inline void setMetaState(int32_t metaState) { mMetaState = metaState; }
370
Jeff Browne959ed22011-05-06 18:20:01 -0700371 inline int32_t getButtonState() const { return mButtonState; }
372
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700373 inline float getXOffset() const { return mXOffset; }
374
375 inline float getYOffset() const { return mYOffset; }
376
Jeff Browne839a582010-04-22 18:58:52 -0700377 inline float getXPrecision() const { return mXPrecision; }
378
379 inline float getYPrecision() const { return mYPrecision; }
380
381 inline nsecs_t getDownTime() const { return mDownTime; }
382
Jeff Browne959ed22011-05-06 18:20:01 -0700383 inline void setDownTime(nsecs_t downTime) { mDownTime = downTime; }
Jeff Browne839a582010-04-22 18:58:52 -0700384
Jeff Browne959ed22011-05-06 18:20:01 -0700385 inline size_t getPointerCount() const { return mPointerProperties.size(); }
386
387 inline const PointerProperties* getPointerProperties(size_t pointerIndex) const {
388 return &mPointerProperties[pointerIndex];
389 }
390
391 inline int32_t getPointerId(size_t pointerIndex) const {
392 return mPointerProperties[pointerIndex].id;
393 }
394
395 inline int32_t getToolType(size_t pointerIndex) const {
396 return mPointerProperties[pointerIndex].toolType;
397 }
Jeff Browne839a582010-04-22 18:58:52 -0700398
399 inline nsecs_t getEventTime() const { return mSampleEventTimes[getHistorySize()]; }
400
Jeff Brown3e341462011-02-14 17:03:18 -0800401 const PointerCoords* getRawPointerCoords(size_t pointerIndex) const;
402
403 float getRawAxisValue(int32_t axis, size_t pointerIndex) const;
404
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700405 inline float getRawX(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800406 return getRawAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700407 }
408
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700409 inline float getRawY(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800410 return getRawAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700411 }
412
Jeff Brown3e341462011-02-14 17:03:18 -0800413 float getAxisValue(int32_t axis, size_t pointerIndex) const;
414
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700415 inline float getX(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800416 return getAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700417 }
418
419 inline float getY(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800420 return getAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700421 }
422
Jeff Browne839a582010-04-22 18:58:52 -0700423 inline float getPressure(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800424 return getAxisValue(AMOTION_EVENT_AXIS_PRESSURE, pointerIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700425 }
426
427 inline float getSize(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800428 return getAxisValue(AMOTION_EVENT_AXIS_SIZE, pointerIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700429 }
430
Jeff Brown5c1ed842010-07-14 18:48:53 -0700431 inline float getTouchMajor(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800432 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700433 }
434
435 inline float getTouchMinor(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800436 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700437 }
438
439 inline float getToolMajor(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800440 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700441 }
442
443 inline float getToolMinor(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800444 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700445 }
446
447 inline float getOrientation(size_t pointerIndex) const {
Jeff Brownb2d44352011-02-17 13:01:34 -0800448 return getAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700449 }
450
Jeff Browne839a582010-04-22 18:58:52 -0700451 inline size_t getHistorySize() const { return mSampleEventTimes.size() - 1; }
452
453 inline nsecs_t getHistoricalEventTime(size_t historicalIndex) const {
454 return mSampleEventTimes[historicalIndex];
455 }
456
Jeff Brown3e341462011-02-14 17:03:18 -0800457 const PointerCoords* getHistoricalRawPointerCoords(
458 size_t pointerIndex, size_t historicalIndex) const;
459
460 float getHistoricalRawAxisValue(int32_t axis, size_t pointerIndex,
461 size_t historicalIndex) const;
462
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700463 inline float getHistoricalRawX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800464 return getHistoricalRawAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800465 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700466 }
467
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700468 inline float getHistoricalRawY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800469 return getHistoricalRawAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800470 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700471 }
472
Jeff Brown3e341462011-02-14 17:03:18 -0800473 float getHistoricalAxisValue(int32_t axis, size_t pointerIndex, size_t historicalIndex) const;
474
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700475 inline float getHistoricalX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800476 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800477 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700478 }
479
480 inline float getHistoricalY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800481 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800482 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700483 }
484
Jeff Browne839a582010-04-22 18:58:52 -0700485 inline float getHistoricalPressure(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800486 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800487 AMOTION_EVENT_AXIS_PRESSURE, pointerIndex, historicalIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700488 }
489
490 inline float getHistoricalSize(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800491 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800492 AMOTION_EVENT_AXIS_SIZE, pointerIndex, historicalIndex);
Jeff Browne839a582010-04-22 18:58:52 -0700493 }
494
Jeff Brown5c1ed842010-07-14 18:48:53 -0700495 inline float getHistoricalTouchMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800496 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800497 AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex, historicalIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700498 }
499
500 inline float getHistoricalTouchMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800501 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800502 AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex, historicalIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700503 }
504
505 inline float getHistoricalToolMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800506 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800507 AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex, historicalIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700508 }
509
510 inline float getHistoricalToolMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800511 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800512 AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex, historicalIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700513 }
514
515 inline float getHistoricalOrientation(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown3e341462011-02-14 17:03:18 -0800516 return getHistoricalAxisValue(
Jeff Brownb2d44352011-02-17 13:01:34 -0800517 AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex, historicalIndex);
Jeff Brown5c1ed842010-07-14 18:48:53 -0700518 }
519
Jeff Brown15933542011-03-14 19:39:54 -0700520 ssize_t findPointerIndex(int32_t pointerId) const;
521
Jeff Browne839a582010-04-22 18:58:52 -0700522 void initialize(
523 int32_t deviceId,
Jeff Brown5c1ed842010-07-14 18:48:53 -0700524 int32_t source,
Jeff Browne839a582010-04-22 18:58:52 -0700525 int32_t action,
Jeff Brownaf30ff62010-09-01 17:01:00 -0700526 int32_t flags,
Jeff Browne839a582010-04-22 18:58:52 -0700527 int32_t edgeFlags,
528 int32_t metaState,
Jeff Browne959ed22011-05-06 18:20:01 -0700529 int32_t buttonState,
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700530 float xOffset,
531 float yOffset,
Jeff Browne839a582010-04-22 18:58:52 -0700532 float xPrecision,
533 float yPrecision,
534 nsecs_t downTime,
535 nsecs_t eventTime,
536 size_t pointerCount,
Jeff Browne959ed22011-05-06 18:20:01 -0700537 const PointerProperties* pointerProperties,
Jeff Browne839a582010-04-22 18:58:52 -0700538 const PointerCoords* pointerCoords);
539
Jeff Brown3e341462011-02-14 17:03:18 -0800540 void copyFrom(const MotionEvent* other, bool keepHistory);
541
Jeff Browne839a582010-04-22 18:58:52 -0700542 void addSample(
543 nsecs_t eventTime,
544 const PointerCoords* pointerCoords);
545
546 void offsetLocation(float xOffset, float yOffset);
547
Jeff Brown3e341462011-02-14 17:03:18 -0800548 void scale(float scaleFactor);
549
550#ifdef HAVE_ANDROID_OS
551 void transform(const SkMatrix* matrix);
552
553 status_t readFromParcel(Parcel* parcel);
554 status_t writeToParcel(Parcel* parcel) const;
555#endif
556
Jeff Brownd5ed2852011-03-02 19:23:13 -0800557 static bool isTouchEvent(int32_t source, int32_t action);
558 inline bool isTouchEvent() const {
559 return isTouchEvent(mSource, mAction);
560 }
561
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700562 // Low-level accessors.
Jeff Browne959ed22011-05-06 18:20:01 -0700563 inline const PointerProperties* getPointerProperties() const {
564 return mPointerProperties.array();
565 }
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700566 inline const nsecs_t* getSampleEventTimes() const { return mSampleEventTimes.array(); }
567 inline const PointerCoords* getSamplePointerCoords() const {
568 return mSamplePointerCoords.array();
569 }
570
Jeff Brown3e341462011-02-14 17:03:18 -0800571protected:
Jeff Browne839a582010-04-22 18:58:52 -0700572 int32_t mAction;
Jeff Brownaf30ff62010-09-01 17:01:00 -0700573 int32_t mFlags;
Jeff Browne839a582010-04-22 18:58:52 -0700574 int32_t mEdgeFlags;
575 int32_t mMetaState;
Jeff Browne959ed22011-05-06 18:20:01 -0700576 int32_t mButtonState;
Jeff Brownf4a4ec22010-06-16 01:53:36 -0700577 float mXOffset;
578 float mYOffset;
Jeff Browne839a582010-04-22 18:58:52 -0700579 float mXPrecision;
580 float mYPrecision;
581 nsecs_t mDownTime;
Jeff Browne959ed22011-05-06 18:20:01 -0700582 Vector<PointerProperties> mPointerProperties;
Jeff Browne839a582010-04-22 18:58:52 -0700583 Vector<nsecs_t> mSampleEventTimes;
584 Vector<PointerCoords> mSamplePointerCoords;
Jeff Browne839a582010-04-22 18:58:52 -0700585};
586
587/*
588 * Input event factory.
589 */
590class InputEventFactoryInterface {
591protected:
592 virtual ~InputEventFactoryInterface() { }
593
594public:
595 InputEventFactoryInterface() { }
596
597 virtual KeyEvent* createKeyEvent() = 0;
598 virtual MotionEvent* createMotionEvent() = 0;
599};
600
601/*
602 * A simple input event factory implementation that uses a single preallocated instance
603 * of each type of input event that are reused for each request.
604 */
605class PreallocatedInputEventFactory : public InputEventFactoryInterface {
606public:
607 PreallocatedInputEventFactory() { }
608 virtual ~PreallocatedInputEventFactory() { }
609
610 virtual KeyEvent* createKeyEvent() { return & mKeyEvent; }
611 virtual MotionEvent* createMotionEvent() { return & mMotionEvent; }
612
613private:
614 KeyEvent mKeyEvent;
615 MotionEvent mMotionEvent;
616};
617
Jeff Browne57e8952010-07-23 21:28:06 -0700618/*
Jeff Brown15933542011-03-14 19:39:54 -0700619 * Calculates the velocity of pointer movements over time.
Jeff Brownfa773aa2011-03-09 17:39:48 -0800620 */
621class VelocityTracker {
622public:
Jeff Brown73aaf0d2011-09-14 10:53:18 -0700623 // Default polynomial degree. (used by getVelocity)
624 static const uint32_t DEFAULT_DEGREE = 2;
625
626 // Default sample horizon. (used by getVelocity)
627 // We don't use too much history by default since we want to react to quick
628 // changes in direction.
629 static const nsecs_t DEFAULT_HORIZON = 100 * 1000000; // 100 ms
630
Jeff Brownfa773aa2011-03-09 17:39:48 -0800631 struct Position {
632 float x, y;
633 };
634
Jeff Brown73aaf0d2011-09-14 10:53:18 -0700635 struct Estimator {
636 static const size_t MAX_DEGREE = 2;
637
638 // Polynomial coefficients describing motion in X and Y.
639 float xCoeff[MAX_DEGREE + 1], yCoeff[MAX_DEGREE + 1];
640
641 // Polynomial degree (number of coefficients), or zero if no information is
642 // available.
643 uint32_t degree;
644
645 // Confidence (coefficient of determination), between 0 (no fit) and 1 (perfect fit).
646 float confidence;
647
648 inline void clear() {
649 degree = 0;
650 confidence = 0;
651 for (size_t i = 0; i <= MAX_DEGREE; i++) {
652 xCoeff[i] = 0;
653 yCoeff[i] = 0;
654 }
655 }
656 };
657
Jeff Brownfa773aa2011-03-09 17:39:48 -0800658 VelocityTracker();
659
660 // Resets the velocity tracker state.
661 void clear();
662
Jeff Brown15933542011-03-14 19:39:54 -0700663 // Resets the velocity tracker state for specific pointers.
664 // Call this method when some pointers have changed and may be reusing
665 // an id that was assigned to a different pointer earlier.
666 void clearPointers(BitSet32 idBits);
667
Jeff Brownfa773aa2011-03-09 17:39:48 -0800668 // Adds movement information for a set of pointers.
669 // The idBits bitfield specifies the pointer ids of the pointers whose positions
670 // are included in the movement.
671 // The positions array contains position information for each pointer in order by
672 // increasing id. Its size should be equal to the number of one bits in idBits.
673 void addMovement(nsecs_t eventTime, BitSet32 idBits, const Position* positions);
674
Jeff Brown15933542011-03-14 19:39:54 -0700675 // Adds movement information for all pointers in a MotionEvent, including historical samples.
676 void addMovement(const MotionEvent* event);
677
Jeff Brownfa773aa2011-03-09 17:39:48 -0800678 // Gets the velocity of the specified pointer id in position units per second.
Jeff Brown73aaf0d2011-09-14 10:53:18 -0700679 // Returns false and sets the velocity components to zero if there is
680 // insufficient movement information for the pointer.
Jeff Brownfa773aa2011-03-09 17:39:48 -0800681 bool getVelocity(uint32_t id, float* outVx, float* outVy) const;
682
Jeff Brown73aaf0d2011-09-14 10:53:18 -0700683 // Gets a quadratic estimator for the movements of the specified pointer id.
684 // Returns false and clears the estimator if there is no information available
685 // about the pointer.
686 bool getEstimator(uint32_t id, uint32_t degree, nsecs_t horizon,
687 Estimator* outEstimator) const;
688
Jeff Brown15933542011-03-14 19:39:54 -0700689 // Gets the active pointer id, or -1 if none.
690 inline int32_t getActivePointerId() const { return mActivePointerId; }
691
692 // Gets a bitset containing all pointer ids from the most recent movement.
693 inline BitSet32 getCurrentPointerIdBits() const { return mMovements[mIndex].idBits; }
694
Jeff Brownfa773aa2011-03-09 17:39:48 -0800695private:
696 // Number of samples to keep.
Jeff Brown73aaf0d2011-09-14 10:53:18 -0700697 static const uint32_t HISTORY_SIZE = 20;
Jeff Brownfa773aa2011-03-09 17:39:48 -0800698
699 struct Movement {
700 nsecs_t eventTime;
701 BitSet32 idBits;
702 Position positions[MAX_POINTERS];
Jeff Brown137c3c52011-09-09 15:39:35 -0700703
704 inline const Position& getPosition(uint32_t id) const {
705 return positions[idBits.getIndexOfBit(id)];
706 }
Jeff Brownfa773aa2011-03-09 17:39:48 -0800707 };
708
709 uint32_t mIndex;
710 Movement mMovements[HISTORY_SIZE];
Jeff Brown15933542011-03-14 19:39:54 -0700711 int32_t mActivePointerId;
Jeff Brownfa773aa2011-03-09 17:39:48 -0800712};
713
Jeff Brownadab6202011-06-01 12:33:19 -0700714
715/*
716 * Specifies parameters that govern pointer or wheel acceleration.
717 */
718struct VelocityControlParameters {
719 // A scale factor that is multiplied with the raw velocity deltas
720 // prior to applying any other velocity control factors. The scale
721 // factor should be used to adapt the input device resolution
722 // (eg. counts per inch) to the output device resolution (eg. pixels per inch).
723 //
724 // Must be a positive value.
725 // Default is 1.0 (no scaling).
726 float scale;
727
728 // The scaled speed at which acceleration begins to be applied.
729 // This value establishes the upper bound of a low speed regime for
730 // small precise motions that are performed without any acceleration.
731 //
732 // Must be a non-negative value.
733 // Default is 0.0 (no low threshold).
734 float lowThreshold;
735
736 // The scaled speed at which maximum acceleration is applied.
737 // The difference between highThreshold and lowThreshold controls
738 // the range of speeds over which the acceleration factor is interpolated.
739 // The wider the range, the smoother the acceleration.
740 //
741 // Must be a non-negative value greater than or equal to lowThreshold.
742 // Default is 0.0 (no high threshold).
743 float highThreshold;
744
745 // The acceleration factor.
746 // When the speed is above the low speed threshold, the velocity will scaled
747 // by an interpolated value between 1.0 and this amount.
748 //
749 // Must be a positive greater than or equal to 1.0.
750 // Default is 1.0 (no acceleration).
751 float acceleration;
752
753 VelocityControlParameters() :
754 scale(1.0f), lowThreshold(0.0f), highThreshold(0.0f), acceleration(1.0f) {
755 }
756
757 VelocityControlParameters(float scale, float lowThreshold,
758 float highThreshold, float acceleration) :
759 scale(scale), lowThreshold(lowThreshold),
760 highThreshold(highThreshold), acceleration(acceleration) {
761 }
762};
763
764/*
765 * Implements mouse pointer and wheel speed control and acceleration.
766 */
767class VelocityControl {
768public:
769 VelocityControl();
770
771 /* Sets the various parameters. */
772 void setParameters(const VelocityControlParameters& parameters);
773
774 /* Resets the current movement counters to zero.
775 * This has the effect of nullifying any acceleration. */
776 void reset();
777
778 /* Translates a raw movement delta into an appropriately
779 * scaled / accelerated delta based on the current velocity. */
780 void move(nsecs_t eventTime, float* deltaX, float* deltaY);
781
782private:
783 // If no movements are received within this amount of time,
784 // we assume the movement has stopped and reset the movement counters.
785 static const nsecs_t STOP_TIME = 500 * 1000000; // 500 ms
786
787 VelocityControlParameters mParameters;
788
789 nsecs_t mLastMovementTime;
790 VelocityTracker::Position mRawPosition;
791 VelocityTracker mVelocityTracker;
792};
793
794
Jeff Brownfa773aa2011-03-09 17:39:48 -0800795/*
Jeff Browne57e8952010-07-23 21:28:06 -0700796 * Describes the characteristics and capabilities of an input device.
797 */
798class InputDeviceInfo {
799public:
800 InputDeviceInfo();
801 InputDeviceInfo(const InputDeviceInfo& other);
802 ~InputDeviceInfo();
803
804 struct MotionRange {
Jeff Brown46689da2011-03-08 15:13:06 -0800805 int32_t axis;
806 uint32_t source;
Jeff Browne57e8952010-07-23 21:28:06 -0700807 float min;
808 float max;
809 float flat;
810 float fuzz;
811 };
812
813 void initialize(int32_t id, const String8& name);
814
815 inline int32_t getId() const { return mId; }
816 inline const String8 getName() const { return mName; }
817 inline uint32_t getSources() const { return mSources; }
818
Jeff Brown46689da2011-03-08 15:13:06 -0800819 const MotionRange* getMotionRange(int32_t axis, uint32_t source) const;
Jeff Browne57e8952010-07-23 21:28:06 -0700820
821 void addSource(uint32_t source);
Jeff Brown46689da2011-03-08 15:13:06 -0800822 void addMotionRange(int32_t axis, uint32_t source,
823 float min, float max, float flat, float fuzz);
824 void addMotionRange(const MotionRange& range);
Jeff Browne57e8952010-07-23 21:28:06 -0700825
826 inline void setKeyboardType(int32_t keyboardType) { mKeyboardType = keyboardType; }
827 inline int32_t getKeyboardType() const { return mKeyboardType; }
828
Jeff Brown46689da2011-03-08 15:13:06 -0800829 inline const Vector<MotionRange>& getMotionRanges() const {
Jeff Brown38a7fab2010-08-30 03:02:23 -0700830 return mMotionRanges;
831 }
832
Jeff Browne57e8952010-07-23 21:28:06 -0700833private:
834 int32_t mId;
835 String8 mName;
836 uint32_t mSources;
837 int32_t mKeyboardType;
838
Jeff Brown46689da2011-03-08 15:13:06 -0800839 Vector<MotionRange> mMotionRanges;
Jeff Browne57e8952010-07-23 21:28:06 -0700840};
841
Jeff Browndb360642010-12-02 13:50:46 -0800842/*
843 * Identifies a device.
844 */
845struct InputDeviceIdentifier {
846 inline InputDeviceIdentifier() :
847 bus(0), vendor(0), product(0), version(0) {
848 }
849
850 String8 name;
851 String8 location;
852 String8 uniqueId;
853 uint16_t bus;
854 uint16_t vendor;
855 uint16_t product;
856 uint16_t version;
857};
858
Jeff Brown66888372010-11-29 17:37:49 -0800859/* Types of input device configuration files. */
860enum InputDeviceConfigurationFileType {
861 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_CONFIGURATION = 0, /* .idc file */
862 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_LAYOUT = 1, /* .kl file */
863 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_CHARACTER_MAP = 2, /* .kcm file */
864};
865
866/*
Jeff Browndb360642010-12-02 13:50:46 -0800867 * Gets the path of an input device configuration file, if one is available.
Jeff Brown53c16642010-11-18 20:53:46 -0800868 * Considers both system provided and user installed configuration files.
Jeff Brown66888372010-11-29 17:37:49 -0800869 *
Jeff Browndb360642010-12-02 13:50:46 -0800870 * The device identifier is used to construct several default configuration file
871 * names to try based on the device name, vendor, product, and version.
872 *
Jeff Brown66888372010-11-29 17:37:49 -0800873 * Returns an empty string if not found.
874 */
Jeff Browndb360642010-12-02 13:50:46 -0800875extern String8 getInputDeviceConfigurationFilePathByDeviceIdentifier(
876 const InputDeviceIdentifier& deviceIdentifier,
877 InputDeviceConfigurationFileType type);
878
879/*
880 * Gets the path of an input device configuration file, if one is available.
881 * Considers both system provided and user installed configuration files.
882 *
883 * The name is case-sensitive and is used to construct the filename to resolve.
884 * All characters except 'a'-'z', 'A'-'Z', '0'-'9', '-', and '_' are replaced by underscores.
885 *
886 * Returns an empty string if not found.
887 */
888extern String8 getInputDeviceConfigurationFilePathByName(
Jeff Brown66888372010-11-29 17:37:49 -0800889 const String8& name, InputDeviceConfigurationFileType type);
Jeff Browne839a582010-04-22 18:58:52 -0700890
891} // namespace android
892
893#endif // _UI_INPUT_H