blob: 0dc29c8e0b9883e0d10055f8ac0f469aa03c46a7 [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 Brownefd32662011-03-08 15:13:06 -0800160 * Button state.
161 */
162enum {
163 // Primary button pressed (left mouse button).
164 BUTTON_STATE_PRIMARY = 1 << 0,
165};
166
167/*
Jeff Brown9c3cda02010-06-15 01:31:58 -0700168 * Describes the basic configuration of input devices that are present.
169 */
170struct InputConfiguration {
171 enum {
172 TOUCHSCREEN_UNDEFINED = 0,
173 TOUCHSCREEN_NOTOUCH = 1,
174 TOUCHSCREEN_STYLUS = 2,
175 TOUCHSCREEN_FINGER = 3
176 };
177
178 enum {
179 KEYBOARD_UNDEFINED = 0,
180 KEYBOARD_NOKEYS = 1,
181 KEYBOARD_QWERTY = 2,
182 KEYBOARD_12KEY = 3
183 };
184
185 enum {
186 NAVIGATION_UNDEFINED = 0,
187 NAVIGATION_NONAV = 1,
188 NAVIGATION_DPAD = 2,
189 NAVIGATION_TRACKBALL = 3,
190 NAVIGATION_WHEEL = 4
191 };
192
193 int32_t touchScreen;
194 int32_t keyboard;
195 int32_t navigation;
196};
197
198/*
Jeff Brown46b9ac02010-04-22 18:58:52 -0700199 * Pointer coordinate data.
200 */
201struct PointerCoords {
Jeff Brown6f2fba42011-02-19 01:08:02 -0800202 enum { MAX_AXES = 14 }; // 14 so that sizeof(PointerCoords) == 64
Jeff Brown91c69ab2011-02-14 17:03:18 -0800203
204 // Bitfield of axes that are present in this structure.
Jeff Brown6f2fba42011-02-19 01:08:02 -0800205 uint64_t bits;
Jeff Brown91c69ab2011-02-14 17:03:18 -0800206
207 // Values of axes that are stored in this structure packed in order by axis id
208 // for each axis that is present in the structure according to 'bits'.
209 float values[MAX_AXES];
210
211 inline void clear() {
212 bits = 0;
213 }
214
Jeff Brown6f2fba42011-02-19 01:08:02 -0800215 float getAxisValue(int32_t axis) const;
216 status_t setAxisValue(int32_t axis, float value);
217 float* editAxisValue(int32_t axis);
Jeff Brown91c69ab2011-02-14 17:03:18 -0800218
219#ifdef HAVE_ANDROID_OS
220 status_t readFromParcel(Parcel* parcel);
221 status_t writeToParcel(Parcel* parcel) const;
222#endif
223
Jeff Brownace13b12011-03-09 17:39:48 -0800224 bool operator==(const PointerCoords& other) const;
225 inline bool operator!=(const PointerCoords& other) const {
226 return !(*this == other);
227 }
228
229 void copyFrom(const PointerCoords& other);
230
Jeff Brown91c69ab2011-02-14 17:03:18 -0800231private:
232 void tooManyAxes(int axis);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700233};
234
235/*
236 * Input events.
237 */
Dianne Hackborn2e9f93e2010-06-28 15:27:30 -0700238class InputEvent : public AInputEvent {
Jeff Brown46b9ac02010-04-22 18:58:52 -0700239public:
240 virtual ~InputEvent() { }
241
242 virtual int32_t getType() const = 0;
243
244 inline int32_t getDeviceId() const { return mDeviceId; }
245
Jeff Brownc5ed5912010-07-14 18:48:53 -0700246 inline int32_t getSource() const { return mSource; }
Jeff Brown91c69ab2011-02-14 17:03:18 -0800247
248 inline void setSource(int32_t source) { mSource = source; }
249
Jeff Brown46b9ac02010-04-22 18:58:52 -0700250protected:
Jeff Brownc5ed5912010-07-14 18:48:53 -0700251 void initialize(int32_t deviceId, int32_t source);
Dianne Hackborn2c6081c2010-07-15 17:44:53 -0700252 void initialize(const InputEvent& from);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700253
Jeff Brown46b9ac02010-04-22 18:58:52 -0700254 int32_t mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -0700255 int32_t mSource;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700256};
257
Jeff Brown5c225b12010-06-16 01:53:36 -0700258/*
259 * Key events.
260 */
Jeff Brown46b9ac02010-04-22 18:58:52 -0700261class KeyEvent : public InputEvent {
262public:
263 virtual ~KeyEvent() { }
264
Jeff Brownc5ed5912010-07-14 18:48:53 -0700265 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_KEY; }
Jeff Brown46b9ac02010-04-22 18:58:52 -0700266
267 inline int32_t getAction() const { return mAction; }
268
269 inline int32_t getFlags() const { return mFlags; }
270
271 inline int32_t getKeyCode() const { return mKeyCode; }
272
273 inline int32_t getScanCode() const { return mScanCode; }
274
275 inline int32_t getMetaState() const { return mMetaState; }
276
277 inline int32_t getRepeatCount() const { return mRepeatCount; }
278
279 inline nsecs_t getDownTime() const { return mDownTime; }
280
281 inline nsecs_t getEventTime() const { return mEventTime; }
282
Dianne Hackborn3c80a4a2010-06-29 19:20:40 -0700283 // Return true if this event may have a default action implementation.
284 static bool hasDefaultAction(int32_t keyCode);
285 bool hasDefaultAction() const;
286
287 // Return true if this event represents a system key.
288 static bool isSystemKey(int32_t keyCode);
289 bool isSystemKey() const;
290
Jeff Brown46b9ac02010-04-22 18:58:52 -0700291 void initialize(
292 int32_t deviceId,
Jeff Brownc5ed5912010-07-14 18:48:53 -0700293 int32_t source,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700294 int32_t action,
295 int32_t flags,
296 int32_t keyCode,
297 int32_t scanCode,
298 int32_t metaState,
299 int32_t repeatCount,
300 nsecs_t downTime,
301 nsecs_t eventTime);
Dianne Hackborn2c6081c2010-07-15 17:44:53 -0700302 void initialize(const KeyEvent& from);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700303
Jeff Brown91c69ab2011-02-14 17:03:18 -0800304protected:
Jeff Brown46b9ac02010-04-22 18:58:52 -0700305 int32_t mAction;
306 int32_t mFlags;
307 int32_t mKeyCode;
308 int32_t mScanCode;
309 int32_t mMetaState;
310 int32_t mRepeatCount;
311 nsecs_t mDownTime;
312 nsecs_t mEventTime;
313};
314
Jeff Brown5c225b12010-06-16 01:53:36 -0700315/*
316 * Motion events.
317 */
Jeff Brown46b9ac02010-04-22 18:58:52 -0700318class MotionEvent : public InputEvent {
319public:
320 virtual ~MotionEvent() { }
321
Jeff Brownc5ed5912010-07-14 18:48:53 -0700322 virtual int32_t getType() const { return AINPUT_EVENT_TYPE_MOTION; }
Jeff Brown46b9ac02010-04-22 18:58:52 -0700323
324 inline int32_t getAction() const { return mAction; }
325
Jeff Brown2ed24622011-03-14 19:39:54 -0700326 inline int32_t getActionMasked() const { return mAction & AMOTION_EVENT_ACTION_MASK; }
327
328 inline int32_t getActionIndex() const {
329 return (mAction & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK)
330 >> AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
331 }
332
Jeff Brown91c69ab2011-02-14 17:03:18 -0800333 inline void setAction(int32_t action) { mAction = action; }
334
Jeff Brown85a31762010-09-01 17:01:00 -0700335 inline int32_t getFlags() const { return mFlags; }
336
Jeff Brown21bc5c92011-02-28 18:27:14 -0800337 inline void setFlags(int32_t flags) { mFlags = flags; }
338
Jeff Brown46b9ac02010-04-22 18:58:52 -0700339 inline int32_t getEdgeFlags() const { return mEdgeFlags; }
340
Jeff Brown91c69ab2011-02-14 17:03:18 -0800341 inline void setEdgeFlags(int32_t edgeFlags) { mEdgeFlags = edgeFlags; }
342
Jeff Brown46b9ac02010-04-22 18:58:52 -0700343 inline int32_t getMetaState() const { return mMetaState; }
344
Jeff Brown91c69ab2011-02-14 17:03:18 -0800345 inline void setMetaState(int32_t metaState) { mMetaState = metaState; }
346
Jeff Brown5c225b12010-06-16 01:53:36 -0700347 inline float getXOffset() const { return mXOffset; }
348
349 inline float getYOffset() const { return mYOffset; }
350
Jeff Brown46b9ac02010-04-22 18:58:52 -0700351 inline float getXPrecision() const { return mXPrecision; }
352
353 inline float getYPrecision() const { return mYPrecision; }
354
355 inline nsecs_t getDownTime() const { return mDownTime; }
356
357 inline size_t getPointerCount() const { return mPointerIds.size(); }
358
359 inline int32_t getPointerId(size_t pointerIndex) const { return mPointerIds[pointerIndex]; }
360
361 inline nsecs_t getEventTime() const { return mSampleEventTimes[getHistorySize()]; }
362
Jeff Brown91c69ab2011-02-14 17:03:18 -0800363 const PointerCoords* getRawPointerCoords(size_t pointerIndex) const;
364
365 float getRawAxisValue(int32_t axis, size_t pointerIndex) const;
366
Jeff Brown5c225b12010-06-16 01:53:36 -0700367 inline float getRawX(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800368 return getRawAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700369 }
370
Jeff Brown5c225b12010-06-16 01:53:36 -0700371 inline float getRawY(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800372 return getRawAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700373 }
374
Jeff Brown91c69ab2011-02-14 17:03:18 -0800375 float getAxisValue(int32_t axis, size_t pointerIndex) const;
376
Jeff Brown5c225b12010-06-16 01:53:36 -0700377 inline float getX(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800378 return getAxisValue(AMOTION_EVENT_AXIS_X, pointerIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700379 }
380
381 inline float getY(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800382 return getAxisValue(AMOTION_EVENT_AXIS_Y, pointerIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700383 }
384
Jeff Brown46b9ac02010-04-22 18:58:52 -0700385 inline float getPressure(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800386 return getAxisValue(AMOTION_EVENT_AXIS_PRESSURE, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700387 }
388
389 inline float getSize(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800390 return getAxisValue(AMOTION_EVENT_AXIS_SIZE, pointerIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700391 }
392
Jeff Brownc5ed5912010-07-14 18:48:53 -0700393 inline float getTouchMajor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800394 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700395 }
396
397 inline float getTouchMinor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800398 return getAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700399 }
400
401 inline float getToolMajor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800402 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700403 }
404
405 inline float getToolMinor(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800406 return getAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700407 }
408
409 inline float getOrientation(size_t pointerIndex) const {
Jeff Brownebbd5d12011-02-17 13:01:34 -0800410 return getAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700411 }
412
Jeff Brown46b9ac02010-04-22 18:58:52 -0700413 inline size_t getHistorySize() const { return mSampleEventTimes.size() - 1; }
414
415 inline nsecs_t getHistoricalEventTime(size_t historicalIndex) const {
416 return mSampleEventTimes[historicalIndex];
417 }
418
Jeff Brown91c69ab2011-02-14 17:03:18 -0800419 const PointerCoords* getHistoricalRawPointerCoords(
420 size_t pointerIndex, size_t historicalIndex) const;
421
422 float getHistoricalRawAxisValue(int32_t axis, size_t pointerIndex,
423 size_t historicalIndex) const;
424
Jeff Brown5c225b12010-06-16 01:53:36 -0700425 inline float getHistoricalRawX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800426 return getHistoricalRawAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800427 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700428 }
429
Jeff Brown5c225b12010-06-16 01:53:36 -0700430 inline float getHistoricalRawY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800431 return getHistoricalRawAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800432 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700433 }
434
Jeff Brown91c69ab2011-02-14 17:03:18 -0800435 float getHistoricalAxisValue(int32_t axis, size_t pointerIndex, size_t historicalIndex) const;
436
Jeff Brown5c225b12010-06-16 01:53:36 -0700437 inline float getHistoricalX(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800438 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800439 AMOTION_EVENT_AXIS_X, pointerIndex, historicalIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700440 }
441
442 inline float getHistoricalY(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800443 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800444 AMOTION_EVENT_AXIS_Y, pointerIndex, historicalIndex);
Jeff Brown5c225b12010-06-16 01:53:36 -0700445 }
446
Jeff Brown46b9ac02010-04-22 18:58:52 -0700447 inline float getHistoricalPressure(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800448 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800449 AMOTION_EVENT_AXIS_PRESSURE, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700450 }
451
452 inline float getHistoricalSize(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800453 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800454 AMOTION_EVENT_AXIS_SIZE, pointerIndex, historicalIndex);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700455 }
456
Jeff Brownc5ed5912010-07-14 18:48:53 -0700457 inline float getHistoricalTouchMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800458 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800459 AMOTION_EVENT_AXIS_TOUCH_MAJOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700460 }
461
462 inline float getHistoricalTouchMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800463 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800464 AMOTION_EVENT_AXIS_TOUCH_MINOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700465 }
466
467 inline float getHistoricalToolMajor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800468 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800469 AMOTION_EVENT_AXIS_TOOL_MAJOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700470 }
471
472 inline float getHistoricalToolMinor(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800473 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800474 AMOTION_EVENT_AXIS_TOOL_MINOR, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700475 }
476
477 inline float getHistoricalOrientation(size_t pointerIndex, size_t historicalIndex) const {
Jeff Brown91c69ab2011-02-14 17:03:18 -0800478 return getHistoricalAxisValue(
Jeff Brownebbd5d12011-02-17 13:01:34 -0800479 AMOTION_EVENT_AXIS_ORIENTATION, pointerIndex, historicalIndex);
Jeff Brownc5ed5912010-07-14 18:48:53 -0700480 }
481
Jeff Brown2ed24622011-03-14 19:39:54 -0700482 ssize_t findPointerIndex(int32_t pointerId) const;
483
Jeff Brown46b9ac02010-04-22 18:58:52 -0700484 void initialize(
485 int32_t deviceId,
Jeff Brownc5ed5912010-07-14 18:48:53 -0700486 int32_t source,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700487 int32_t action,
Jeff Brown85a31762010-09-01 17:01:00 -0700488 int32_t flags,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700489 int32_t edgeFlags,
490 int32_t metaState,
Jeff Brown5c225b12010-06-16 01:53:36 -0700491 float xOffset,
492 float yOffset,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700493 float xPrecision,
494 float yPrecision,
495 nsecs_t downTime,
496 nsecs_t eventTime,
497 size_t pointerCount,
498 const int32_t* pointerIds,
499 const PointerCoords* pointerCoords);
500
Jeff Brown91c69ab2011-02-14 17:03:18 -0800501 void copyFrom(const MotionEvent* other, bool keepHistory);
502
Jeff Brown46b9ac02010-04-22 18:58:52 -0700503 void addSample(
504 nsecs_t eventTime,
505 const PointerCoords* pointerCoords);
506
507 void offsetLocation(float xOffset, float yOffset);
508
Jeff Brown91c69ab2011-02-14 17:03:18 -0800509 void scale(float scaleFactor);
510
511#ifdef HAVE_ANDROID_OS
512 void transform(const SkMatrix* matrix);
513
514 status_t readFromParcel(Parcel* parcel);
515 status_t writeToParcel(Parcel* parcel) const;
516#endif
517
Jeff Brown56194eb2011-03-02 19:23:13 -0800518 static bool isTouchEvent(int32_t source, int32_t action);
519 inline bool isTouchEvent() const {
520 return isTouchEvent(mSource, mAction);
521 }
522
Jeff Brown5c225b12010-06-16 01:53:36 -0700523 // Low-level accessors.
524 inline const int32_t* getPointerIds() const { return mPointerIds.array(); }
525 inline const nsecs_t* getSampleEventTimes() const { return mSampleEventTimes.array(); }
526 inline const PointerCoords* getSamplePointerCoords() const {
527 return mSamplePointerCoords.array();
528 }
529
Jeff Brown91c69ab2011-02-14 17:03:18 -0800530protected:
Jeff Brown46b9ac02010-04-22 18:58:52 -0700531 int32_t mAction;
Jeff Brown85a31762010-09-01 17:01:00 -0700532 int32_t mFlags;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700533 int32_t mEdgeFlags;
534 int32_t mMetaState;
Jeff Brown5c225b12010-06-16 01:53:36 -0700535 float mXOffset;
536 float mYOffset;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700537 float mXPrecision;
538 float mYPrecision;
539 nsecs_t mDownTime;
540 Vector<int32_t> mPointerIds;
541 Vector<nsecs_t> mSampleEventTimes;
542 Vector<PointerCoords> mSamplePointerCoords;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700543};
544
545/*
546 * Input event factory.
547 */
548class InputEventFactoryInterface {
549protected:
550 virtual ~InputEventFactoryInterface() { }
551
552public:
553 InputEventFactoryInterface() { }
554
555 virtual KeyEvent* createKeyEvent() = 0;
556 virtual MotionEvent* createMotionEvent() = 0;
557};
558
559/*
560 * A simple input event factory implementation that uses a single preallocated instance
561 * of each type of input event that are reused for each request.
562 */
563class PreallocatedInputEventFactory : public InputEventFactoryInterface {
564public:
565 PreallocatedInputEventFactory() { }
566 virtual ~PreallocatedInputEventFactory() { }
567
568 virtual KeyEvent* createKeyEvent() { return & mKeyEvent; }
569 virtual MotionEvent* createMotionEvent() { return & mMotionEvent; }
570
571private:
572 KeyEvent mKeyEvent;
573 MotionEvent mMotionEvent;
574};
575
Jeff Brown6d0fec22010-07-23 21:28:06 -0700576/*
Jeff Brown2ed24622011-03-14 19:39:54 -0700577 * Calculates the velocity of pointer movements over time.
Jeff Brownace13b12011-03-09 17:39:48 -0800578 */
579class VelocityTracker {
580public:
581 struct Position {
582 float x, y;
583 };
584
585 VelocityTracker();
586
587 // Resets the velocity tracker state.
588 void clear();
589
Jeff Brown2ed24622011-03-14 19:39:54 -0700590 // Resets the velocity tracker state for specific pointers.
591 // Call this method when some pointers have changed and may be reusing
592 // an id that was assigned to a different pointer earlier.
593 void clearPointers(BitSet32 idBits);
594
Jeff Brownace13b12011-03-09 17:39:48 -0800595 // Adds movement information for a set of pointers.
596 // The idBits bitfield specifies the pointer ids of the pointers whose positions
597 // are included in the movement.
598 // The positions array contains position information for each pointer in order by
599 // increasing id. Its size should be equal to the number of one bits in idBits.
600 void addMovement(nsecs_t eventTime, BitSet32 idBits, const Position* positions);
601
Jeff Brown2ed24622011-03-14 19:39:54 -0700602 // Adds movement information for all pointers in a MotionEvent, including historical samples.
603 void addMovement(const MotionEvent* event);
604
Jeff Brownace13b12011-03-09 17:39:48 -0800605 // Gets the velocity of the specified pointer id in position units per second.
606 // Returns false and sets the velocity components to zero if there is no movement
607 // information for the pointer.
608 bool getVelocity(uint32_t id, float* outVx, float* outVy) const;
609
Jeff Brown2ed24622011-03-14 19:39:54 -0700610 // Gets the active pointer id, or -1 if none.
611 inline int32_t getActivePointerId() const { return mActivePointerId; }
612
613 // Gets a bitset containing all pointer ids from the most recent movement.
614 inline BitSet32 getCurrentPointerIdBits() const { return mMovements[mIndex].idBits; }
615
Jeff Brownace13b12011-03-09 17:39:48 -0800616private:
617 // Number of samples to keep.
618 static const uint32_t HISTORY_SIZE = 10;
619
620 // Oldest sample to consider when calculating the velocity.
621 static const nsecs_t MAX_AGE = 200 * 1000000; // 200 ms
622
623 // The minimum duration between samples when estimating velocity.
Jeff Brown2ed24622011-03-14 19:39:54 -0700624 static const nsecs_t MIN_DURATION = 10 * 1000000; // 10 ms
Jeff Brownace13b12011-03-09 17:39:48 -0800625
626 struct Movement {
627 nsecs_t eventTime;
628 BitSet32 idBits;
629 Position positions[MAX_POINTERS];
630 };
631
632 uint32_t mIndex;
633 Movement mMovements[HISTORY_SIZE];
Jeff Brown2ed24622011-03-14 19:39:54 -0700634 int32_t mActivePointerId;
Jeff Brownace13b12011-03-09 17:39:48 -0800635};
636
637/*
Jeff Brown6d0fec22010-07-23 21:28:06 -0700638 * Describes the characteristics and capabilities of an input device.
639 */
640class InputDeviceInfo {
641public:
642 InputDeviceInfo();
643 InputDeviceInfo(const InputDeviceInfo& other);
644 ~InputDeviceInfo();
645
646 struct MotionRange {
Jeff Brownefd32662011-03-08 15:13:06 -0800647 int32_t axis;
648 uint32_t source;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700649 float min;
650 float max;
651 float flat;
652 float fuzz;
653 };
654
655 void initialize(int32_t id, const String8& name);
656
657 inline int32_t getId() const { return mId; }
658 inline const String8 getName() const { return mName; }
659 inline uint32_t getSources() const { return mSources; }
660
Jeff Brownefd32662011-03-08 15:13:06 -0800661 const MotionRange* getMotionRange(int32_t axis, uint32_t source) const;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700662
663 void addSource(uint32_t source);
Jeff Brownefd32662011-03-08 15:13:06 -0800664 void addMotionRange(int32_t axis, uint32_t source,
665 float min, float max, float flat, float fuzz);
666 void addMotionRange(const MotionRange& range);
Jeff Brown6d0fec22010-07-23 21:28:06 -0700667
668 inline void setKeyboardType(int32_t keyboardType) { mKeyboardType = keyboardType; }
669 inline int32_t getKeyboardType() const { return mKeyboardType; }
670
Jeff Brownefd32662011-03-08 15:13:06 -0800671 inline const Vector<MotionRange>& getMotionRanges() const {
Jeff Brown8d608662010-08-30 03:02:23 -0700672 return mMotionRanges;
673 }
674
Jeff Brown6d0fec22010-07-23 21:28:06 -0700675private:
676 int32_t mId;
677 String8 mName;
678 uint32_t mSources;
679 int32_t mKeyboardType;
680
Jeff Brownefd32662011-03-08 15:13:06 -0800681 Vector<MotionRange> mMotionRanges;
Jeff Brown6d0fec22010-07-23 21:28:06 -0700682};
683
Jeff Brown90655042010-12-02 13:50:46 -0800684/*
685 * Identifies a device.
686 */
687struct InputDeviceIdentifier {
688 inline InputDeviceIdentifier() :
689 bus(0), vendor(0), product(0), version(0) {
690 }
691
692 String8 name;
693 String8 location;
694 String8 uniqueId;
695 uint16_t bus;
696 uint16_t vendor;
697 uint16_t product;
698 uint16_t version;
699};
700
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800701/* Types of input device configuration files. */
702enum InputDeviceConfigurationFileType {
703 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_CONFIGURATION = 0, /* .idc file */
704 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_LAYOUT = 1, /* .kl file */
705 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_CHARACTER_MAP = 2, /* .kcm file */
706};
707
708/*
Jeff Brown90655042010-12-02 13:50:46 -0800709 * Gets the path of an input device configuration file, if one is available.
Jeff Brown1f245102010-11-18 20:53:46 -0800710 * Considers both system provided and user installed configuration files.
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800711 *
Jeff Brown90655042010-12-02 13:50:46 -0800712 * The device identifier is used to construct several default configuration file
713 * names to try based on the device name, vendor, product, and version.
714 *
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800715 * Returns an empty string if not found.
716 */
Jeff Brown90655042010-12-02 13:50:46 -0800717extern String8 getInputDeviceConfigurationFilePathByDeviceIdentifier(
718 const InputDeviceIdentifier& deviceIdentifier,
719 InputDeviceConfigurationFileType type);
720
721/*
722 * Gets the path of an input device configuration file, if one is available.
723 * Considers both system provided and user installed configuration files.
724 *
725 * The name is case-sensitive and is used to construct the filename to resolve.
726 * All characters except 'a'-'z', 'A'-'Z', '0'-'9', '-', and '_' are replaced by underscores.
727 *
728 * Returns an empty string if not found.
729 */
730extern String8 getInputDeviceConfigurationFilePathByName(
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800731 const String8& name, InputDeviceConfigurationFileType type);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700732
733} // namespace android
734
735#endif // _UI_INPUT_H