blob: af899efec993f9baf6f89ceb8c44c50a1f8965ff [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:
623 struct Position {
624 float x, y;
625 };
626
627 VelocityTracker();
628
629 // Resets the velocity tracker state.
630 void clear();
631
Jeff Brown15933542011-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 Brownfa773aa2011-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 Brown15933542011-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 Brownfa773aa2011-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 Brown15933542011-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 Brownfa773aa2011-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.
Jeff Brown137c3c52011-09-09 15:39:35 -0700663 static const nsecs_t MAX_AGE = 100 * 1000000; // 100 ms
Jeff Brownfa773aa2011-03-09 17:39:48 -0800664
665 // The minimum duration between samples when estimating velocity.
Jeff Brown137c3c52011-09-09 15:39:35 -0700666 static const nsecs_t MIN_DURATION = 5 * 1000000; // 5 ms
Jeff Brownfa773aa2011-03-09 17:39:48 -0800667
668 struct Movement {
669 nsecs_t eventTime;
670 BitSet32 idBits;
671 Position positions[MAX_POINTERS];
Jeff Brown137c3c52011-09-09 15:39:35 -0700672
673 inline const Position& getPosition(uint32_t id) const {
674 return positions[idBits.getIndexOfBit(id)];
675 }
Jeff Brownfa773aa2011-03-09 17:39:48 -0800676 };
677
678 uint32_t mIndex;
679 Movement mMovements[HISTORY_SIZE];
Jeff Brown15933542011-03-14 19:39:54 -0700680 int32_t mActivePointerId;
Jeff Brownfa773aa2011-03-09 17:39:48 -0800681};
682
Jeff Brownadab6202011-06-01 12:33:19 -0700683
684/*
685 * Specifies parameters that govern pointer or wheel acceleration.
686 */
687struct VelocityControlParameters {
688 // A scale factor that is multiplied with the raw velocity deltas
689 // prior to applying any other velocity control factors. The scale
690 // factor should be used to adapt the input device resolution
691 // (eg. counts per inch) to the output device resolution (eg. pixels per inch).
692 //
693 // Must be a positive value.
694 // Default is 1.0 (no scaling).
695 float scale;
696
697 // The scaled speed at which acceleration begins to be applied.
698 // This value establishes the upper bound of a low speed regime for
699 // small precise motions that are performed without any acceleration.
700 //
701 // Must be a non-negative value.
702 // Default is 0.0 (no low threshold).
703 float lowThreshold;
704
705 // The scaled speed at which maximum acceleration is applied.
706 // The difference between highThreshold and lowThreshold controls
707 // the range of speeds over which the acceleration factor is interpolated.
708 // The wider the range, the smoother the acceleration.
709 //
710 // Must be a non-negative value greater than or equal to lowThreshold.
711 // Default is 0.0 (no high threshold).
712 float highThreshold;
713
714 // The acceleration factor.
715 // When the speed is above the low speed threshold, the velocity will scaled
716 // by an interpolated value between 1.0 and this amount.
717 //
718 // Must be a positive greater than or equal to 1.0.
719 // Default is 1.0 (no acceleration).
720 float acceleration;
721
722 VelocityControlParameters() :
723 scale(1.0f), lowThreshold(0.0f), highThreshold(0.0f), acceleration(1.0f) {
724 }
725
726 VelocityControlParameters(float scale, float lowThreshold,
727 float highThreshold, float acceleration) :
728 scale(scale), lowThreshold(lowThreshold),
729 highThreshold(highThreshold), acceleration(acceleration) {
730 }
731};
732
733/*
734 * Implements mouse pointer and wheel speed control and acceleration.
735 */
736class VelocityControl {
737public:
738 VelocityControl();
739
740 /* Sets the various parameters. */
741 void setParameters(const VelocityControlParameters& parameters);
742
743 /* Resets the current movement counters to zero.
744 * This has the effect of nullifying any acceleration. */
745 void reset();
746
747 /* Translates a raw movement delta into an appropriately
748 * scaled / accelerated delta based on the current velocity. */
749 void move(nsecs_t eventTime, float* deltaX, float* deltaY);
750
751private:
752 // If no movements are received within this amount of time,
753 // we assume the movement has stopped and reset the movement counters.
754 static const nsecs_t STOP_TIME = 500 * 1000000; // 500 ms
755
756 VelocityControlParameters mParameters;
757
758 nsecs_t mLastMovementTime;
759 VelocityTracker::Position mRawPosition;
760 VelocityTracker mVelocityTracker;
761};
762
763
Jeff Brownfa773aa2011-03-09 17:39:48 -0800764/*
Jeff Browne57e8952010-07-23 21:28:06 -0700765 * Describes the characteristics and capabilities of an input device.
766 */
767class InputDeviceInfo {
768public:
769 InputDeviceInfo();
770 InputDeviceInfo(const InputDeviceInfo& other);
771 ~InputDeviceInfo();
772
773 struct MotionRange {
Jeff Brown46689da2011-03-08 15:13:06 -0800774 int32_t axis;
775 uint32_t source;
Jeff Browne57e8952010-07-23 21:28:06 -0700776 float min;
777 float max;
778 float flat;
779 float fuzz;
780 };
781
782 void initialize(int32_t id, const String8& name);
783
784 inline int32_t getId() const { return mId; }
785 inline const String8 getName() const { return mName; }
786 inline uint32_t getSources() const { return mSources; }
787
Jeff Brown46689da2011-03-08 15:13:06 -0800788 const MotionRange* getMotionRange(int32_t axis, uint32_t source) const;
Jeff Browne57e8952010-07-23 21:28:06 -0700789
790 void addSource(uint32_t source);
Jeff Brown46689da2011-03-08 15:13:06 -0800791 void addMotionRange(int32_t axis, uint32_t source,
792 float min, float max, float flat, float fuzz);
793 void addMotionRange(const MotionRange& range);
Jeff Browne57e8952010-07-23 21:28:06 -0700794
795 inline void setKeyboardType(int32_t keyboardType) { mKeyboardType = keyboardType; }
796 inline int32_t getKeyboardType() const { return mKeyboardType; }
797
Jeff Brown46689da2011-03-08 15:13:06 -0800798 inline const Vector<MotionRange>& getMotionRanges() const {
Jeff Brown38a7fab2010-08-30 03:02:23 -0700799 return mMotionRanges;
800 }
801
Jeff Browne57e8952010-07-23 21:28:06 -0700802private:
803 int32_t mId;
804 String8 mName;
805 uint32_t mSources;
806 int32_t mKeyboardType;
807
Jeff Brown46689da2011-03-08 15:13:06 -0800808 Vector<MotionRange> mMotionRanges;
Jeff Browne57e8952010-07-23 21:28:06 -0700809};
810
Jeff Browndb360642010-12-02 13:50:46 -0800811/*
812 * Identifies a device.
813 */
814struct InputDeviceIdentifier {
815 inline InputDeviceIdentifier() :
816 bus(0), vendor(0), product(0), version(0) {
817 }
818
819 String8 name;
820 String8 location;
821 String8 uniqueId;
822 uint16_t bus;
823 uint16_t vendor;
824 uint16_t product;
825 uint16_t version;
826};
827
Jeff Brown66888372010-11-29 17:37:49 -0800828/* Types of input device configuration files. */
829enum InputDeviceConfigurationFileType {
830 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_CONFIGURATION = 0, /* .idc file */
831 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_LAYOUT = 1, /* .kl file */
832 INPUT_DEVICE_CONFIGURATION_FILE_TYPE_KEY_CHARACTER_MAP = 2, /* .kcm file */
833};
834
835/*
Jeff Browndb360642010-12-02 13:50:46 -0800836 * Gets the path of an input device configuration file, if one is available.
Jeff Brown53c16642010-11-18 20:53:46 -0800837 * Considers both system provided and user installed configuration files.
Jeff Brown66888372010-11-29 17:37:49 -0800838 *
Jeff Browndb360642010-12-02 13:50:46 -0800839 * The device identifier is used to construct several default configuration file
840 * names to try based on the device name, vendor, product, and version.
841 *
Jeff Brown66888372010-11-29 17:37:49 -0800842 * Returns an empty string if not found.
843 */
Jeff Browndb360642010-12-02 13:50:46 -0800844extern String8 getInputDeviceConfigurationFilePathByDeviceIdentifier(
845 const InputDeviceIdentifier& deviceIdentifier,
846 InputDeviceConfigurationFileType type);
847
848/*
849 * Gets the path of an input device configuration file, if one is available.
850 * Considers both system provided and user installed configuration files.
851 *
852 * The name is case-sensitive and is used to construct the filename to resolve.
853 * All characters except 'a'-'z', 'A'-'Z', '0'-'9', '-', and '_' are replaced by underscores.
854 *
855 * Returns an empty string if not found.
856 */
857extern String8 getInputDeviceConfigurationFilePathByName(
Jeff Brown66888372010-11-29 17:37:49 -0800858 const String8& name, InputDeviceConfigurationFileType type);
Jeff Browne839a582010-04-22 18:58:52 -0700859
860} // namespace android
861
862#endif // _UI_INPUT_H