blob: f1385a039492bcb70f96700af172839f239c65c0 [file] [log] [blame]
Jeff Brown46b9ac02010-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 Brown6d0fec22010-07-23 21:28:06 -070026#include <utils/KeyedVector.h>
Jeff Brown46b9ac02010-04-22 18:58:52 -070027#include <utils/Timers.h>
Jeff Brown6d0fec22010-07-23 21:28:06 -070028#include <utils/RefBase.h>
29#include <utils/String8.h>
Jeff Brownace13b12011-03-09 17:39:48 -080030#include <utils/BitSet.h>
Jeff Brown46b9ac02010-04-22 18:58:52 -070031
Jeff Brown91c69ab2011-02-14 17:03:18 -080032#ifdef HAVE_ANDROID_OS
33class SkMatrix;
34#endif
35
Jeff Brown46b9ac02010-04-22 18:58:52 -070036/*
37 * Additional private constants not defined in ndk/ui/input.h.
38 */
39enum {
Jeff Brown21bc5c92011-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 Brown46b9ac02010-04-22 18:58:52 -070050};
51
Jeff Brown89de57a2011-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 Brown46b9ac02010-04-22 18:58:52 -070061/*
Jeff Brown05dc66a2011-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 Brown46b9ac02010-04-22 18:58:52 -070070 * Maximum number of pointers supported per motion event.
Jeff Brown01ce2e92010-09-26 22:20:12 -070071 * Smallest number of pointers is 1.
Jeff Brown58a2da82011-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 Brown46b9ac02010-04-22 18:58:52 -070074 */
Jeff Brown58a2da82011-01-25 16:02:22 -080075#define MAX_POINTERS 16
Jeff Brown46b9ac02010-04-22 18:58:52 -070076
Dianne Hackborna95e4cb2010-06-18 18:09:33 -070077/*
Jeff Brown01ce2e92010-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 Hackborna95e4cb2010-06-18 18:09:33 -070085 * Declare a concrete type for the NDK's input event forward declaration.
86 */
Dianne Hackbornd76b67c2010-07-13 17:48:30 -070087struct AInputEvent {
88 virtual ~AInputEvent() { }
89};
Dianne Hackborna95e4cb2010-06-18 18:09:33 -070090
Jeff Brown46b9ac02010-04-22 18:58:52 -070091/*
Jeff Brown6d0fec22010-07-23 21:28:06 -070092 * Declare a concrete type for the NDK's input device forward declaration.
Jeff Brown46b9ac02010-04-22 18:58:52 -070093 */
Jeff Brown6d0fec22010-07-23 21:28:06 -070094struct AInputDevice {
95 virtual ~AInputDevice() { }
Jeff Brown46b9ac02010-04-22 18:58:52 -070096};
97
Jeff Brown6d0fec22010-07-23 21:28:06 -070098
99namespace android {
100
Jeff Brown91c69ab2011-02-14 17:03:18 -0800101#ifdef HAVE_ANDROID_OS
102class Parcel;
103#endif
104
Jeff Brown46b9ac02010-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 Brownb6997262010-10-08 22:31:17 -0700108 *
109 * These flags are also defined in frameworks/base/core/java/android/view/WindowManagerPolicy.java.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700110 */
111enum {
Jeff Brown0eaf3932010-10-01 14:55:30 -0700112 /* These flags originate in RawEvents and are generally set in the key map.
Jeff Brown497a92c2010-09-12 17:55:08 -0700113 * NOTE: If you edit these flags, also edit labels in KeycodeLabels.h. */
Jeff Brown46b9ac02010-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 Brown0eaf3932010-10-01 14:55:30 -0700123 POLICY_FLAG_VIRTUAL = 0x00000100,
Jeff Brown497a92c2010-09-12 17:55:08 -0700124 POLICY_FLAG_FUNCTION = 0x00000200,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700125
Jeff Brown7fbdc842010-06-17 20:52:56 -0700126 POLICY_FLAG_RAW_MASK = 0x0000ffff,
127
Jeff Brown85a31762010-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 Browne20c9e02010-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 Brown0029c662011-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 Brown9c3cda02010-06-15 01:31:58 -0700143 /* These flags are set by the input reader policy as it intercepts each event. */
Jeff Brown46b9ac02010-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 Brownb6997262010-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 Brown46b9ac02010-04-22 18:58:52 -0700157};
158
159/*
Jeff Brown9c3cda02010-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 Brown46b9ac02010-04-22 18:58:52 -0700191 * Pointer coordinate data.
192 */
193struct PointerCoords {
Jeff Brown6f2fba42011-02-19 01:08:02 -0800194 enum { MAX_AXES = 14 }; // 14 so that sizeof(PointerCoords) == 64
Jeff Brown91c69ab2011-02-14 17:03:18 -0800195
196 // Bitfield of axes that are present in this structure.
Jeff Brown6f2fba42011-02-19 01:08:02 -0800197 uint64_t bits;
Jeff Brown91c69ab2011-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 Brown6f2fba42011-02-19 01:08:02 -0800207 float getAxisValue(int32_t axis) const;
208 status_t setAxisValue(int32_t axis, float value);
Jeff Brown91c69ab2011-02-14 17:03:18 -0800209
Dianne Hackborne2515ee2011-04-27 18:52:56 -0400210 void scale(float scale);
211
Jeff Brownbe1aa822011-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 Brown91c69ab2011-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 Brownace13b12011-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 Brown91c69ab2011-02-14 17:03:18 -0800232private:
233 void tooManyAxes(int axis);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700234};
235
236/*
Jeff Brownfe9f8ab2011-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 Brown46b9ac02010-04-22 18:58:52 -0700260 * Input events.
261 */
Dianne Hackborn2e9f93e2010-06-28 15:27:30 -0700262class InputEvent : public AInputEvent {
Jeff Brown46b9ac02010-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 Brownc5ed5912010-07-14 18:48:53 -0700270 inline int32_t getSource() const { return mSource; }
Jeff Brown91c69ab2011-02-14 17:03:18 -0800271
272 inline void setSource(int32_t source) { mSource = source; }
273
Jeff Brown46b9ac02010-04-22 18:58:52 -0700274protected:
Jeff Brownc5ed5912010-07-14 18:48:53 -0700275 void initialize(int32_t deviceId, int32_t source);
Dianne Hackborn2c6081c2010-07-15 17:44:53 -0700276 void initialize(const InputEvent& from);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700277
Jeff Brown46b9ac02010-04-22 18:58:52 -0700278 int32_t mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -0700279 int32_t mSource;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700280};
281
Jeff Brown5c225b12010-06-16 01:53:36 -0700282/*
283 * Key events.
284 */
Jeff Brown46b9ac02010-04-22 18:58:52 -0700285class KeyEvent : public InputEvent {
286public:
287 virtual ~KeyEvent() { }
288
Jeff Brownc5ed5912010-07-14 18:48:53 -0700289 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_KEY; }
Jeff Brown46b9ac02010-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 Hackborn3c80a4a2010-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 Brown46b9ac02010-04-22 18:58:52 -0700315 void initialize(
316 int32_t deviceId,
Jeff Brownc5ed5912010-07-14 18:48:53 -0700317 int32_t source,
Jeff Brown46b9ac02010-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 Hackborn2c6081c2010-07-15 17:44:53 -0700326 void initialize(const KeyEvent& from);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700327
Jeff Brown91c69ab2011-02-14 17:03:18 -0800328protected:
Jeff Brown46b9ac02010-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 Brown5c225b12010-06-16 01:53:36 -0700339/*
340 * Motion events.
341 */
Jeff Brown46b9ac02010-04-22 18:58:52 -0700342class MotionEvent : public InputEvent {
343public:
344 virtual ~MotionEvent() { }
345
Jeff Brownc5ed5912010-07-14 18:48:53 -0700346 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_MOTION; }
Jeff Brown46b9ac02010-04-22 18:58:52 -0700347
348 inline int32_t getAction() const { return mAction; }
349
Jeff Brown2ed24622011-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 Brown91c69ab2011-02-14 17:03:18 -0800357 inline void setAction(int32_t action) { mAction = action; }
358
Jeff Brown85a31762010-09-01 17:01:00 -0700359 inline int32_t getFlags() const { return mFlags; }
360
Jeff Brown21bc5c92011-02-28 18:27:14 -0800361 inline void setFlags(int32_t flags) { mFlags = flags; }
362
Jeff Brown46b9ac02010-04-22 18:58:52 -0700363 inline int32_t getEdgeFlags() const { return mEdgeFlags; }
364
Jeff Brown91c69ab2011-02-14 17:03:18 -0800365 inline void setEdgeFlags(int32_t edgeFlags) { mEdgeFlags = edgeFlags; }
366
Jeff Brown46b9ac02010-04-22 18:58:52 -0700367 inline int32_t getMetaState() const { return mMetaState; }
368
Jeff Brown91c69ab2011-02-14 17:03:18 -0800369 inline void setMetaState(int32_t metaState) { mMetaState = metaState; }
370
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700371 inline int32_t getButtonState() const { return mButtonState; }
372
Jeff Brown5c225b12010-06-16 01:53:36 -0700373 inline float getXOffset() const { return mXOffset; }
374
375 inline float getYOffset() const { return mYOffset; }
376
Jeff Brown46b9ac02010-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 Brownfe9f8ab2011-05-06 18:20:01 -0700383 inline void setDownTime(nsecs_t downTime) { mDownTime = downTime; }
Jeff Brown46b9ac02010-04-22 18:58:52 -0700384
Jeff Brownfe9f8ab2011-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 Brown46b9ac02010-04-22 18:58:52 -0700398
399 inline nsecs_t getEventTime() const { return mSampleEventTimes[getHistorySize()]; }
400
Jeff Brown91c69ab2011-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 Brown5c225b12010-06-16 01:53:36 -0700405 inline float getRawX(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800406 return getRawAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700407 }
408
Jeff Brown5c225b12010-06-16 01:53:36 -0700409 inline float getRawY(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800410 return getRawAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700411 }
412
Jeff Brown91c69ab2011-02-14 17:03:18 -0800413 float getAxisValue(int32_t axis, size_t pointerIndex) const;
414
Jeff Brown5c225b12010-06-16 01:53:36 -0700415 inline float getX(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800416 return getAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700417 }
418
419 inline float getY(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800420 return getAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700421 }
422
Jeff Brown46b9ac02010-04-22 18:58:52 -0700423 inline float getPressure(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800424 return getAxisValue(AMOTION_EVENT_AXIS_PRESSURE, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700425 }
426
427 inline float getSize(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800428 return getAxisValue(AMOTION_EVENT_AXIS_SIZE, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700429 }
430
Jeff Brownc5ed5912010-07-14 18:48:53 -0700431 inline float getTouchMajor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800432 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700433 }
434
435 inline float getTouchMinor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800436 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700437 }
438
439 inline float getToolMajor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800440 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700441 }
442
443 inline float getToolMinor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800444 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700445 }
446
447 inline float getOrientation(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800448 return getAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700449 }
450
Jeff Brown46b9ac02010-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 Brown91c69ab2011-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 Brown5c225b12010-06-16 01:53:36 -0700463 inline float getHistoricalRawX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800464 return getHistoricalRawAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800465 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700466 }
467
Jeff Brown5c225b12010-06-16 01:53:36 -0700468 inline float getHistoricalRawY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800469 return getHistoricalRawAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800470 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700471 }
472
Jeff Brown91c69ab2011-02-14 17:03:18 -0800473 float getHistoricalAxisValue(int32_t axis, size_t pointerIndex, size_t historicalIndex) const;
474
Jeff Brown5c225b12010-06-16 01:53:36 -0700475 inline float getHistoricalX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800476 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800477 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700478 }
479
480 inline float getHistoricalY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800481 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800482 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700483 }
484
Jeff Brown46b9ac02010-04-22 18:58:52 -0700485 inline float getHistoricalPressure(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800486 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800487 AMOTION_EVENT_AXIS_PRESSURE, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700488 }
489
490 inline float getHistoricalSize(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800491 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800492 AMOTION_EVENT_AXIS_SIZE, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700493 }
494
Jeff Brownc5ed5912010-07-14 18:48:53 -0700495 inline float getHistoricalTouchMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800496 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800497 AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700498 }
499
500 inline float getHistoricalTouchMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800501 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800502 AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700503 }
504
505 inline float getHistoricalToolMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800506 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800507 AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700508 }
509
510 inline float getHistoricalToolMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800511 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800512 AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700513 }
514
515 inline float getHistoricalOrientation(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800516 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800517 AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700518 }
519
Jeff Brown2ed24622011-03-14 19:39:54 -0700520 ssize_t findPointerIndex(int32_t pointerId) const;
521
Jeff Brown46b9ac02010-04-22 18:58:52 -0700522 void initialize(
523 int32_t deviceId,
Jeff Brownc5ed5912010-07-14 18:48:53 -0700524 int32_t source,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700525 int32_t action,
Jeff Brown85a31762010-09-01 17:01:00 -0700526 int32_t flags,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700527 int32_t edgeFlags,
528 int32_t metaState,
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700529 int32_t buttonState,
Jeff Brown5c225b12010-06-16 01:53:36 -0700530 float xOffset,
531 float yOffset,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700532 float xPrecision,
533 float yPrecision,
534 nsecs_t downTime,
535 nsecs_t eventTime,
536 size_t pointerCount,
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700537 const PointerProperties* pointerProperties,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700538 const PointerCoords* pointerCoords);
539
Jeff Brown91c69ab2011-02-14 17:03:18 -0800540 void copyFrom(const MotionEvent* other, bool keepHistory);
541
Jeff Brown46b9ac02010-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 Brown91c69ab2011-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 Brown56194eb2011-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 Brown5c225b12010-06-16 01:53:36 -0700562 // Low-level accessors.
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700563 inline const PointerProperties* getPointerProperties() const {
564 return mPointerProperties.array();
565 }
Jeff Brown5c225b12010-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 Brown91c69ab2011-02-14 17:03:18 -0800571protected:
Jeff Brown46b9ac02010-04-22 18:58:52 -0700572 int32_t mAction;
Jeff Brown85a31762010-09-01 17:01:00 -0700573 int32_t mFlags;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700574 int32_t mEdgeFlags;
575 int32_t mMetaState;
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700576 int32_t mButtonState;
Jeff Brown5c225b12010-06-16 01:53:36 -0700577 float mXOffset;
578 float mYOffset;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700579 float mXPrecision;
580 float mYPrecision;
581 nsecs_t mDownTime;
Jeff Brownfe9f8ab2011-05-06 18:20:01 -0700582 Vector<PointerProperties> mPointerProperties;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700583 Vector<nsecs_t> mSampleEventTimes;
584 Vector<PointerCoords> mSamplePointerCoords;
Jeff Brown46b9ac02010-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 Brown6d0fec22010-07-23 21:28:06 -0700618/*
Jeff Brown2ed24622011-03-14 19:39:54 -0700619 * Calculates the velocity of pointer movements over time.
Jeff Brownace13b12011-03-09 17:39:48 -0800620 */
621class VelocityTracker {
622public:
623 struct Position {
624 float x, y;
625 };
626
627 VelocityTracker();
628
629 // Resets the velocity tracker state.
630 void clear();
631
Jeff Brown2ed24622011-03-14 19:39:54 -0700632 // Resets the velocity tracker state for specific pointers.
633 // Call this method when some pointers have changed and may be reusing
634 // an id that was assigned to a different pointer earlier.
635 void clearPointers(BitSet32 idBits);
636
Jeff Brownace13b12011-03-09 17:39:48 -0800637 // Adds movement information for a set of pointers.
638 // The idBits bitfield specifies the pointer ids of the pointers whose positions
639 // are included in the movement.
640 // The positions array contains position information for each pointer in order by
641 // increasing id. Its size should be equal to the number of one bits in idBits.
642 void addMovement(nsecs_t eventTime, BitSet32 idBits, const Position* positions);
643
Jeff Brown2ed24622011-03-14 19:39:54 -0700644 // Adds movement information for all pointers in a MotionEvent, including historical samples.
645 void addMovement(const MotionEvent* event);
646
Jeff Brownace13b12011-03-09 17:39:48 -0800647 // Gets the velocity of the specified pointer id in position units per second.
648 // Returns false and sets the velocity components to zero if there is no movement
649 // information for the pointer.
650 bool getVelocity(uint32_t id, float* outVx, float* outVy) const;
651
Jeff Brown2ed24622011-03-14 19:39:54 -0700652 // Gets the active pointer id, or -1 if none.
653 inline int32_t getActivePointerId() const { return mActivePointerId; }
654
655 // Gets a bitset containing all pointer ids from the most recent movement.
656 inline BitSet32 getCurrentPointerIdBits() const { return mMovements[mIndex].idBits; }
657
Jeff Brownace13b12011-03-09 17:39:48 -0800658private:
659 // Number of samples to keep.
660 static const uint32_t HISTORY_SIZE = 10;
661
662 // Oldest sample to consider when calculating the velocity.
663 static const nsecs_t MAX_AGE = 200 * 1000000; // 200 ms
664
665 // The minimum duration between samples when estimating velocity.
Jeff Brown2ed24622011-03-14 19:39:54 -0700666 static const nsecs_t MIN_DURATION = 10 * 1000000; // 10 ms
Jeff Brownace13b12011-03-09 17:39:48 -0800667
668 struct Movement {
669 nsecs_t eventTime;
670 BitSet32 idBits;
671 Position positions[MAX_POINTERS];
672 };
673
674 uint32_t mIndex;
675 Movement mMovements[HISTORY_SIZE];
Jeff Brown2ed24622011-03-14 19:39:54 -0700676 int32_t mActivePointerId;
Jeff Brownace13b12011-03-09 17:39:48 -0800677};
678
Jeff Brown19c97d462011-06-01 12:33:19 -0700679
680/*
681 * Specifies parameters that govern pointer or wheel acceleration.
682 */
683struct VelocityControlParameters {
684 // A scale factor that is multiplied with the raw velocity deltas
685 // prior to applying any other velocity control factors. The scale
686 // factor should be used to adapt the input device resolution
687 // (eg. counts per inch) to the output device resolution (eg. pixels per inch).
688 //
689 // Must be a positive value.
690 // Default is 1.0 (no scaling).
691 float scale;
692
693 // The scaled speed at which acceleration begins to be applied.
694 // This value establishes the upper bound of a low speed regime for
695 // small precise motions that are performed without any acceleration.
696 //
697 // Must be a non-negative value.
698 // Default is 0.0 (no low threshold).
699 float lowThreshold;
700
701 // The scaled speed at which maximum acceleration is applied.
702 // The difference between highThreshold and lowThreshold controls
703 // the range of speeds over which the acceleration factor is interpolated.
704 // The wider the range, the smoother the acceleration.
705 //
706 // Must be a non-negative value greater than or equal to lowThreshold.
707 // Default is 0.0 (no high threshold).
708 float highThreshold;
709
710 // The acceleration factor.
711 // When the speed is above the low speed threshold, the velocity will scaled
712 // by an interpolated value between 1.0 and this amount.
713 //
714 // Must be a positive greater than or equal to 1.0.
715 // Default is 1.0 (no acceleration).
716 float acceleration;
717
718 VelocityControlParameters() :
719 scale(1.0f), lowThreshold(0.0f), highThreshold(0.0f), acceleration(1.0f) {
720 }
721
722 VelocityControlParameters(float scale, float lowThreshold,
723 float highThreshold, float acceleration) :
724 scale(scale), lowThreshold(lowThreshold),
725 highThreshold(highThreshold), acceleration(acceleration) {
726 }
727};
728
729/*
730 * Implements mouse pointer and wheel speed control and acceleration.
731 */
732class VelocityControl {
733public:
734 VelocityControl();
735
736 /* Sets the various parameters. */
737 void setParameters(const VelocityControlParameters& parameters);
738
739 /* Resets the current movement counters to zero.
740 * This has the effect of nullifying any acceleration. */
741 void reset();
742
743 /* Translates a raw movement delta into an appropriately
744 * scaled / accelerated delta based on the current velocity. */
745 void move(nsecs_t eventTime, float* deltaX, float* deltaY);
746
747private:
748 // If no movements are received within this amount of time,
749 // we assume the movement has stopped and reset the movement counters.
750 static const nsecs_t STOP_TIME = 500 * 1000000; // 500 ms
751
752 VelocityControlParameters mParameters;
753
754 nsecs_t mLastMovementTime;
755 VelocityTracker::Position mRawPosition;
756 VelocityTracker mVelocityTracker;
757};
758
759
Jeff Brownace13b12011-03-09 17:39:48 -0800760/*
Jeff Brown6d0fec22010-07-23 21:28:06 -0700761 * Describes the characteristics and capabilities of an input device.
762 */
763class InputDeviceInfo {
764public:
765 InputDeviceInfo();
766 InputDeviceInfo(const InputDeviceInfo& other);
767 ~InputDeviceInfo();
768
769 struct MotionRange {
Jeff Brownefd32662011-03-08 15:13:06 -0800770 int32_t axis;
771 uint32_t source;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700772 float min;
773 float max;
774 float flat;
775 float fuzz;
776 };
777
778 void initialize(int32_t id, const String8& name);
779
780 inline int32_t getId() const { return mId; }
781 inline const String8 getName() const { return mName; }
782 inline uint32_t getSources() const { return mSources; }
783
Jeff Brownefd32662011-03-08 15:13:06 -0800784 const MotionRange* getMotionRange(int32_t axis, uint32_t source) const;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700785
786 void addSource(uint32_t source);
Jeff Brownefd32662011-03-08 15:13:06 -0800787 void addMotionRange(int32_t axis, uint32_t source,
788 float min, float max, float flat, float fuzz);
789 void addMotionRange(const MotionRange& range);
Jeff Brown6d0fec22010-07-23 21:28:06 -0700790
791 inline void setKeyboardType(int32_t keyboardType) { mKeyboardType = keyboardType; }
792 inline int32_t getKeyboardType() const { return mKeyboardType; }
793
Jeff Brownefd32662011-03-08 15:13:06 -0800794 inline const Vector<MotionRange>& getMotionRanges() const {
Jeff Brown8d608662010-08-30 03:02:23 -0700795 return mMotionRanges;
796 }
797
Jeff Brown6d0fec22010-07-23 21:28:06 -0700798private:
799 int32_t mId;
800 String8 mName;
801 uint32_t mSources;
802 int32_t mKeyboardType;
803
Jeff Brownefd32662011-03-08 15:13:06 -0800804 Vector<MotionRange> mMotionRanges;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700805};
806
Jeff Brown90655042010-12-02 13:50:46 -0800807/*
808 * Identifies a device.
809 */
810struct InputDeviceIdentifier {
811 inline InputDeviceIdentifier() :
812 bus(0), vendor(0), product(0), version(0) {
813 }
814
815 String8 name;
816 String8 location;
817 String8 uniqueId;
818 uint16_t bus;
819 uint16_t vendor;
820 uint16_t product;
821 uint16_t version;
822};
823
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800824/* Types of input device configuration files. */
825enum InputDeviceConfigurationFileType {
826 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_CONFIGURATION = 0, /* .idc file */
827 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_LAYOUT = 1, /* .kl file */
828 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_CHARACTER_MAP = 2, /* .kcm file */
829};
830
831/*
Jeff Brown90655042010-12-02 13:50:46 -0800832 * Gets the path of an input device configuration file, if one is available.
Jeff Brown1f245102010-11-18 20:53:46 -0800833 * Considers both system provided and user installed configuration files.
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800834 *
Jeff Brown90655042010-12-02 13:50:46 -0800835 * The device identifier is used to construct several default configuration file
836 * names to try based on the device name, vendor, product, and version.
837 *
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800838 * Returns an empty string if not found.
839 */
Jeff Brown90655042010-12-02 13:50:46 -0800840extern String8 getInputDeviceConfigurationFilePathByDeviceIdentifier(
841 const InputDeviceIdentifier& deviceIdentifier,
842 InputDeviceConfigurationFileType type);
843
844/*
845 * Gets the path of an input device configuration file, if one is available.
846 * Considers both system provided and user installed configuration files.
847 *
848 * The name is case-sensitive and is used to construct the filename to resolve.
849 * All characters except 'a'-'z', 'A'-'Z', '0'-'9', '-', and '_' are replaced by underscores.
850 *
851 * Returns an empty string if not found.
852 */
853extern String8 getInputDeviceConfigurationFilePathByName(
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800854 const String8& name, InputDeviceConfigurationFileType type);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700855
856} // namespace android
857
858#endif // _UI_INPUT_H