blob: 44487c3a8542bbd621f6bbc66422d1b135c4458b [file] [log] [blame]
Jeff Brown5912f952013-07-01 19:10:31 -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#define LOG_TAG "Input"
18//#define LOG_NDEBUG 0
19
chaviw09c8d2d2020-08-24 15:48:26 -070020#include <attestation/HmacKeyManager.h>
Garfield Tan84b087e2020-01-23 10:49:05 -080021#include <cutils/compiler.h>
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -050022#include <inttypes.h>
Garfield Tan84b087e2020-01-23 10:49:05 -080023#include <string.h>
Jeff Brown5912f952013-07-01 19:10:31 -070024
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -050025#include <android-base/stringprintf.h>
chaviw98318de2021-05-19 16:45:23 -050026#include <gui/constants.h>
Prabir Pradhan092f3a92021-11-25 10:53:27 -080027#include <input/DisplayViewport.h>
Jeff Brown5912f952013-07-01 19:10:31 -070028#include <input/Input.h>
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -080029#include <input/InputDevice.h>
Michael Wright872db4f2014-04-22 15:03:51 -070030#include <input/InputEventLabels.h>
Jeff Brown5912f952013-07-01 19:10:31 -070031
Brett Chabotfaa986c2020-11-04 17:39:36 -080032#ifdef __linux__
Jeff Brown5912f952013-07-01 19:10:31 -070033#include <binder/Parcel.h>
Brett Chabotfaa986c2020-11-04 17:39:36 -080034#endif
Brett Chabot58208522020-09-09 13:55:24 -070035#ifdef __ANDROID__
Garfield Tan84b087e2020-01-23 10:49:05 -080036#include <sys/random.h>
Jeff Brown5912f952013-07-01 19:10:31 -070037#endif
38
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -050039using android::base::StringPrintf;
40
Jeff Brown5912f952013-07-01 19:10:31 -070041namespace android {
42
Prabir Pradhan6b384612021-05-14 16:56:25 -070043namespace {
44
45float transformAngle(const ui::Transform& transform, float angleRadians) {
46 // Construct and transform a vector oriented at the specified clockwise angle from vertical.
47 // Coordinate system: down is increasing Y, right is increasing X.
48 float x = sinf(angleRadians);
49 float y = -cosf(angleRadians);
50 vec2 transformedPoint = transform.transform(x, y);
51
52 // Determine how the origin is transformed by the matrix so that we
53 // can transform orientation vectors.
54 const vec2 origin = transform.transform(0, 0);
55
56 transformedPoint.x -= origin.x;
57 transformedPoint.y -= origin.y;
58
59 // Derive the transformed vector's clockwise angle from vertical.
Prabir Pradhand2b02672021-10-19 11:24:45 -070060 // The return value of atan2f is in range [-pi, pi] which conforms to the orientation API.
61 return atan2f(transformedPoint.x, -transformedPoint.y);
Prabir Pradhan6b384612021-05-14 16:56:25 -070062}
63
Prabir Pradhan7e1ee562021-10-26 10:19:49 -070064bool shouldDisregardTransformation(uint32_t source) {
65 // Do not apply any transformations to axes from joysticks or touchpads.
66 return isFromSource(source, AINPUT_SOURCE_CLASS_JOYSTICK) ||
67 isFromSource(source, AINPUT_SOURCE_CLASS_POSITION);
68}
69
70bool shouldDisregardOffset(uint32_t source) {
Prabir Pradhan9f388812021-05-13 16:54:53 -070071 // Pointer events are the only type of events that refer to absolute coordinates on the display,
72 // so we should apply the entire window transform. For other types of events, we should make
73 // sure to not apply the window translation/offset.
Prabir Pradhan7e1ee562021-10-26 10:19:49 -070074 return !isFromSource(source, AINPUT_SOURCE_CLASS_POINTER);
Prabir Pradhan9f388812021-05-13 16:54:53 -070075}
76
Prabir Pradhan6b384612021-05-14 16:56:25 -070077} // namespace
78
Siarhei Vishniakou16a2e302019-01-14 19:21:45 -080079const char* motionClassificationToString(MotionClassification classification) {
80 switch (classification) {
81 case MotionClassification::NONE:
82 return "NONE";
83 case MotionClassification::AMBIGUOUS_GESTURE:
84 return "AMBIGUOUS_GESTURE";
85 case MotionClassification::DEEP_PRESS:
86 return "DEEP_PRESS";
87 }
88}
89
Garfield Tan84b087e2020-01-23 10:49:05 -080090// --- IdGenerator ---
91IdGenerator::IdGenerator(Source source) : mSource(source) {}
92
93int32_t IdGenerator::nextId() const {
94 constexpr uint32_t SEQUENCE_NUMBER_MASK = ~SOURCE_MASK;
95 int32_t id = 0;
96
97// Avoid building against syscall getrandom(2) on host, which will fail build on Mac. Host doesn't
98// use sequence number so just always return mSource.
99#ifdef __ANDROID__
100 constexpr size_t BUF_LEN = sizeof(id);
101 size_t totalBytes = 0;
102 while (totalBytes < BUF_LEN) {
103 ssize_t bytes = TEMP_FAILURE_RETRY(getrandom(&id, BUF_LEN, GRND_NONBLOCK));
104 if (CC_UNLIKELY(bytes < 0)) {
105 ALOGW("Failed to fill in random number for sequence number: %s.", strerror(errno));
106 id = 0;
107 break;
108 }
109 totalBytes += bytes;
110 }
111#endif // __ANDROID__
112
113 return (id & SEQUENCE_NUMBER_MASK) | static_cast<int32_t>(mSource);
114}
115
Jeff Brown5912f952013-07-01 19:10:31 -0700116// --- InputEvent ---
117
Prabir Pradhande69f8a2021-11-18 16:40:34 +0000118vec2 transformWithoutTranslation(const ui::Transform& transform, const vec2& xy) {
119 const vec2 transformedXy = transform.transform(xy);
120 const vec2 transformedOrigin = transform.transform(0, 0);
121 return transformedXy - transformedOrigin;
122}
123
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800124const char* inputEventTypeToString(int32_t type) {
125 switch (type) {
126 case AINPUT_EVENT_TYPE_KEY: {
127 return "KEY";
128 }
129 case AINPUT_EVENT_TYPE_MOTION: {
130 return "MOTION";
131 }
132 case AINPUT_EVENT_TYPE_FOCUS: {
133 return "FOCUS";
134 }
Prabir Pradhan3f37b7b2020-11-10 16:50:18 -0800135 case AINPUT_EVENT_TYPE_CAPTURE: {
136 return "CAPTURE";
137 }
arthurhung7632c332020-12-30 16:58:01 +0800138 case AINPUT_EVENT_TYPE_DRAG: {
139 return "DRAG";
140 }
Antonio Kantek7cdf8ef2021-07-13 18:04:53 -0700141 case AINPUT_EVENT_TYPE_TOUCH_MODE: {
142 return "TOUCH_MODE";
143 }
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800144 }
145 return "UNKNOWN";
146}
147
Siarhei Vishniakoud9489572021-11-12 20:08:38 -0800148std::string inputEventSourceToString(int32_t source) {
149 if (source == AINPUT_SOURCE_UNKNOWN) {
150 return "UNKNOWN";
151 }
152 if (source == static_cast<int32_t>(AINPUT_SOURCE_ANY)) {
153 return "ANY";
154 }
155 static const std::map<int32_t, const char*> SOURCES{
156 {AINPUT_SOURCE_KEYBOARD, "KEYBOARD"},
157 {AINPUT_SOURCE_DPAD, "DPAD"},
158 {AINPUT_SOURCE_GAMEPAD, "GAMEPAD"},
159 {AINPUT_SOURCE_TOUCHSCREEN, "TOUCHSCREEN"},
160 {AINPUT_SOURCE_MOUSE, "MOUSE"},
161 {AINPUT_SOURCE_STYLUS, "STYLUS"},
162 {AINPUT_SOURCE_BLUETOOTH_STYLUS, "BLUETOOTH_STYLUS"},
163 {AINPUT_SOURCE_TRACKBALL, "TRACKBALL"},
164 {AINPUT_SOURCE_MOUSE_RELATIVE, "MOUSE_RELATIVE"},
165 {AINPUT_SOURCE_TOUCHPAD, "TOUCHPAD"},
166 {AINPUT_SOURCE_TOUCH_NAVIGATION, "TOUCH_NAVIGATION"},
167 {AINPUT_SOURCE_JOYSTICK, "JOYSTICK"},
168 {AINPUT_SOURCE_HDMI, "HDMI"},
169 {AINPUT_SOURCE_SENSOR, "SENSOR"},
170 {AINPUT_SOURCE_ROTARY_ENCODER, "ROTARY_ENCODER"},
171 };
172 std::string result;
173 for (const auto& [source_entry, str] : SOURCES) {
174 if ((source & source_entry) == source_entry) {
175 if (!result.empty()) {
176 result += " | ";
177 }
178 result += str;
179 }
180 }
181 if (result.empty()) {
182 result = StringPrintf("0x%08x", source);
183 }
184 return result;
185}
186
187bool isFromSource(uint32_t source, uint32_t test) {
188 return (source & test) == test;
189}
190
Siarhei Vishniakou54d3e182020-01-15 17:38:38 -0800191VerifiedKeyEvent verifiedKeyEventFromKeyEvent(const KeyEvent& event) {
192 return {{VerifiedInputEvent::Type::KEY, event.getDeviceId(), event.getEventTime(),
193 event.getSource(), event.getDisplayId()},
194 event.getAction(),
195 event.getDownTime(),
196 event.getFlags() & VERIFIED_KEY_EVENT_FLAGS,
197 event.getKeyCode(),
198 event.getScanCode(),
199 event.getMetaState(),
200 event.getRepeatCount()};
201}
202
203VerifiedMotionEvent verifiedMotionEventFromMotionEvent(const MotionEvent& event) {
204 return {{VerifiedInputEvent::Type::MOTION, event.getDeviceId(), event.getEventTime(),
205 event.getSource(), event.getDisplayId()},
206 event.getRawX(0),
207 event.getRawY(0),
208 event.getActionMasked(),
209 event.getDownTime(),
210 event.getFlags() & VERIFIED_MOTION_EVENT_FLAGS,
211 event.getMetaState(),
212 event.getButtonState()};
213}
214
Garfield Tan4cc839f2020-01-24 11:26:14 -0800215void InputEvent::initialize(int32_t id, int32_t deviceId, uint32_t source, int32_t displayId,
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600216 std::array<uint8_t, 32> hmac) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800217 mId = id;
Jeff Brown5912f952013-07-01 19:10:31 -0700218 mDeviceId = deviceId;
219 mSource = source;
Siarhei Vishniakoua62a8dd2018-06-08 21:17:33 +0100220 mDisplayId = displayId;
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600221 mHmac = hmac;
Jeff Brown5912f952013-07-01 19:10:31 -0700222}
223
224void InputEvent::initialize(const InputEvent& from) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800225 mId = from.mId;
Jeff Brown5912f952013-07-01 19:10:31 -0700226 mDeviceId = from.mDeviceId;
227 mSource = from.mSource;
Siarhei Vishniakoua62a8dd2018-06-08 21:17:33 +0100228 mDisplayId = from.mDisplayId;
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600229 mHmac = from.mHmac;
Jeff Brown5912f952013-07-01 19:10:31 -0700230}
231
Garfield Tan4cc839f2020-01-24 11:26:14 -0800232int32_t InputEvent::nextId() {
233 static IdGenerator idGen(IdGenerator::Source::OTHER);
234 return idGen.nextId();
235}
236
Jeff Brown5912f952013-07-01 19:10:31 -0700237// --- KeyEvent ---
238
Michael Wright872db4f2014-04-22 15:03:51 -0700239const char* KeyEvent::getLabel(int32_t keyCode) {
Chris Ye4958d062020-08-20 13:21:10 -0700240 return InputEventLookup::getLabelByKeyCode(keyCode);
Jeff Brown5912f952013-07-01 19:10:31 -0700241}
242
Michael Wright872db4f2014-04-22 15:03:51 -0700243int32_t KeyEvent::getKeyCodeFromLabel(const char* label) {
Chris Ye4958d062020-08-20 13:21:10 -0700244 return InputEventLookup::getKeyCodeByLabel(label);
Jeff Brown5912f952013-07-01 19:10:31 -0700245}
246
Garfield Tan4cc839f2020-01-24 11:26:14 -0800247void KeyEvent::initialize(int32_t id, int32_t deviceId, uint32_t source, int32_t displayId,
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600248 std::array<uint8_t, 32> hmac, int32_t action, int32_t flags,
249 int32_t keyCode, int32_t scanCode, int32_t metaState, int32_t repeatCount,
250 nsecs_t downTime, nsecs_t eventTime) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800251 InputEvent::initialize(id, deviceId, source, displayId, hmac);
Jeff Brown5912f952013-07-01 19:10:31 -0700252 mAction = action;
253 mFlags = flags;
254 mKeyCode = keyCode;
255 mScanCode = scanCode;
256 mMetaState = metaState;
257 mRepeatCount = repeatCount;
258 mDownTime = downTime;
259 mEventTime = eventTime;
260}
261
262void KeyEvent::initialize(const KeyEvent& from) {
263 InputEvent::initialize(from);
264 mAction = from.mAction;
265 mFlags = from.mFlags;
266 mKeyCode = from.mKeyCode;
267 mScanCode = from.mScanCode;
268 mMetaState = from.mMetaState;
269 mRepeatCount = from.mRepeatCount;
270 mDownTime = from.mDownTime;
271 mEventTime = from.mEventTime;
272}
273
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700274const char* KeyEvent::actionToString(int32_t action) {
275 // Convert KeyEvent action to string
276 switch (action) {
277 case AKEY_EVENT_ACTION_DOWN:
278 return "DOWN";
279 case AKEY_EVENT_ACTION_UP:
280 return "UP";
281 case AKEY_EVENT_ACTION_MULTIPLE:
282 return "MULTIPLE";
283 }
284 return "UNKNOWN";
285}
Jeff Brown5912f952013-07-01 19:10:31 -0700286
287// --- PointerCoords ---
288
289float PointerCoords::getAxisValue(int32_t axis) const {
Michael Wright38dcdff2014-03-19 12:06:10 -0700290 if (axis < 0 || axis > 63 || !BitSet64::hasBit(bits, axis)){
Jeff Brown5912f952013-07-01 19:10:31 -0700291 return 0;
292 }
Michael Wright38dcdff2014-03-19 12:06:10 -0700293 return values[BitSet64::getIndexOfBit(bits, axis)];
Jeff Brown5912f952013-07-01 19:10:31 -0700294}
295
296status_t PointerCoords::setAxisValue(int32_t axis, float value) {
297 if (axis < 0 || axis > 63) {
298 return NAME_NOT_FOUND;
299 }
300
Michael Wright38dcdff2014-03-19 12:06:10 -0700301 uint32_t index = BitSet64::getIndexOfBit(bits, axis);
302 if (!BitSet64::hasBit(bits, axis)) {
Jeff Brown5912f952013-07-01 19:10:31 -0700303 if (value == 0) {
304 return OK; // axes with value 0 do not need to be stored
305 }
Michael Wright38dcdff2014-03-19 12:06:10 -0700306
307 uint32_t count = BitSet64::count(bits);
Jeff Brown5912f952013-07-01 19:10:31 -0700308 if (count >= MAX_AXES) {
309 tooManyAxes(axis);
310 return NO_MEMORY;
311 }
Michael Wright38dcdff2014-03-19 12:06:10 -0700312 BitSet64::markBit(bits, axis);
Jeff Brown5912f952013-07-01 19:10:31 -0700313 for (uint32_t i = count; i > index; i--) {
314 values[i] = values[i - 1];
315 }
316 }
Michael Wright38dcdff2014-03-19 12:06:10 -0700317
Jeff Brown5912f952013-07-01 19:10:31 -0700318 values[index] = value;
319 return OK;
320}
321
322static inline void scaleAxisValue(PointerCoords& c, int axis, float scaleFactor) {
323 float value = c.getAxisValue(axis);
324 if (value != 0) {
325 c.setAxisValue(axis, value * scaleFactor);
326 }
327}
328
Robert Carre07e1032018-11-26 12:55:53 -0800329void PointerCoords::scale(float globalScaleFactor, float windowXScale, float windowYScale) {
Jeff Brown5912f952013-07-01 19:10:31 -0700330 // No need to scale pressure or size since they are normalized.
331 // No need to scale orientation since it is meaningless to do so.
Robert Carre07e1032018-11-26 12:55:53 -0800332
333 // If there is a global scale factor, it is included in the windowX/YScale
334 // so we don't need to apply it twice to the X/Y axes.
335 // However we don't want to apply any windowXYScale not included in the global scale
336 // to the TOUCH_MAJOR/MINOR coordinates.
337 scaleAxisValue(*this, AMOTION_EVENT_AXIS_X, windowXScale);
338 scaleAxisValue(*this, AMOTION_EVENT_AXIS_Y, windowYScale);
339 scaleAxisValue(*this, AMOTION_EVENT_AXIS_TOUCH_MAJOR, globalScaleFactor);
340 scaleAxisValue(*this, AMOTION_EVENT_AXIS_TOUCH_MINOR, globalScaleFactor);
341 scaleAxisValue(*this, AMOTION_EVENT_AXIS_TOOL_MAJOR, globalScaleFactor);
342 scaleAxisValue(*this, AMOTION_EVENT_AXIS_TOOL_MINOR, globalScaleFactor);
Prabir Pradhanc6523582021-05-14 18:02:55 -0700343 scaleAxisValue(*this, AMOTION_EVENT_AXIS_RELATIVE_X, windowXScale);
344 scaleAxisValue(*this, AMOTION_EVENT_AXIS_RELATIVE_Y, windowYScale);
Robert Carre07e1032018-11-26 12:55:53 -0800345}
346
Alex Chauf7c99f32021-12-03 10:37:54 +0000347void PointerCoords::applyOffset(float xOffset, float yOffset) {
348 setAxisValue(AMOTION_EVENT_AXIS_X, getX() + xOffset);
349 setAxisValue(AMOTION_EVENT_AXIS_Y, getY() + yOffset);
350}
351
Brett Chabotfaa986c2020-11-04 17:39:36 -0800352#ifdef __linux__
Jeff Brown5912f952013-07-01 19:10:31 -0700353status_t PointerCoords::readFromParcel(Parcel* parcel) {
354 bits = parcel->readInt64();
355
Michael Wright38dcdff2014-03-19 12:06:10 -0700356 uint32_t count = BitSet64::count(bits);
Jeff Brown5912f952013-07-01 19:10:31 -0700357 if (count > MAX_AXES) {
358 return BAD_VALUE;
359 }
360
361 for (uint32_t i = 0; i < count; i++) {
362 values[i] = parcel->readFloat();
363 }
364 return OK;
365}
366
367status_t PointerCoords::writeToParcel(Parcel* parcel) const {
368 parcel->writeInt64(bits);
369
Michael Wright38dcdff2014-03-19 12:06:10 -0700370 uint32_t count = BitSet64::count(bits);
Jeff Brown5912f952013-07-01 19:10:31 -0700371 for (uint32_t i = 0; i < count; i++) {
372 parcel->writeFloat(values[i]);
373 }
374 return OK;
375}
Brett Chabotfaa986c2020-11-04 17:39:36 -0800376#endif
Jeff Brown5912f952013-07-01 19:10:31 -0700377
378void PointerCoords::tooManyAxes(int axis) {
379 ALOGW("Could not set value for axis %d because the PointerCoords structure is full and "
380 "cannot contain more than %d axis values.", axis, int(MAX_AXES));
381}
382
383bool PointerCoords::operator==(const PointerCoords& other) const {
384 if (bits != other.bits) {
385 return false;
386 }
Michael Wright38dcdff2014-03-19 12:06:10 -0700387 uint32_t count = BitSet64::count(bits);
Jeff Brown5912f952013-07-01 19:10:31 -0700388 for (uint32_t i = 0; i < count; i++) {
389 if (values[i] != other.values[i]) {
390 return false;
391 }
392 }
393 return true;
394}
395
396void PointerCoords::copyFrom(const PointerCoords& other) {
397 bits = other.bits;
Michael Wright38dcdff2014-03-19 12:06:10 -0700398 uint32_t count = BitSet64::count(bits);
Jeff Brown5912f952013-07-01 19:10:31 -0700399 for (uint32_t i = 0; i < count; i++) {
400 values[i] = other.values[i];
401 }
402}
403
chaviwc01e1372020-07-01 12:37:31 -0700404void PointerCoords::transform(const ui::Transform& transform) {
Prabir Pradhan6b384612021-05-14 16:56:25 -0700405 const vec2 xy = transform.transform(getXYValue());
406 setAxisValue(AMOTION_EVENT_AXIS_X, xy.x);
407 setAxisValue(AMOTION_EVENT_AXIS_Y, xy.y);
408
Prabir Pradhanc6523582021-05-14 18:02:55 -0700409 if (BitSet64::hasBit(bits, AMOTION_EVENT_AXIS_RELATIVE_X) ||
410 BitSet64::hasBit(bits, AMOTION_EVENT_AXIS_RELATIVE_Y)) {
411 const ui::Transform rotation(transform.getOrientation());
412 const vec2 relativeXy = rotation.transform(getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X),
413 getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y));
414 setAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X, relativeXy.x);
415 setAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y, relativeXy.y);
416 }
417
Prabir Pradhan6b384612021-05-14 16:56:25 -0700418 if (BitSet64::hasBit(bits, AMOTION_EVENT_AXIS_ORIENTATION)) {
419 const float val = getAxisValue(AMOTION_EVENT_AXIS_ORIENTATION);
420 setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, transformAngle(transform, val));
421 }
chaviwc01e1372020-07-01 12:37:31 -0700422}
Jeff Brown5912f952013-07-01 19:10:31 -0700423
424// --- PointerProperties ---
425
426bool PointerProperties::operator==(const PointerProperties& other) const {
427 return id == other.id
428 && toolType == other.toolType;
429}
430
431void PointerProperties::copyFrom(const PointerProperties& other) {
432 id = other.id;
433 toolType = other.toolType;
434}
435
436
437// --- MotionEvent ---
438
Garfield Tan4cc839f2020-01-24 11:26:14 -0800439void MotionEvent::initialize(int32_t id, int32_t deviceId, uint32_t source, int32_t displayId,
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600440 std::array<uint8_t, 32> hmac, int32_t action, int32_t actionButton,
441 int32_t flags, int32_t edgeFlags, int32_t metaState,
chaviw9eaa22c2020-07-01 16:21:27 -0700442 int32_t buttonState, MotionClassification classification,
443 const ui::Transform& transform, float xPrecision, float yPrecision,
Evan Rosky84f07f02021-04-16 10:42:42 -0700444 float rawXCursorPosition, float rawYCursorPosition,
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700445 const ui::Transform& rawTransform, nsecs_t downTime, nsecs_t eventTime,
Evan Rosky09576692021-07-01 12:22:09 -0700446 size_t pointerCount, const PointerProperties* pointerProperties,
Garfield Tan00f511d2019-06-12 16:55:40 -0700447 const PointerCoords* pointerCoords) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800448 InputEvent::initialize(id, deviceId, source, displayId, hmac);
Jeff Brown5912f952013-07-01 19:10:31 -0700449 mAction = action;
Michael Wright7b159c92015-05-14 14:48:03 +0100450 mActionButton = actionButton;
Jeff Brown5912f952013-07-01 19:10:31 -0700451 mFlags = flags;
452 mEdgeFlags = edgeFlags;
453 mMetaState = metaState;
454 mButtonState = buttonState;
Siarhei Vishniakou49e59222018-12-28 18:17:15 -0800455 mClassification = classification;
chaviw9eaa22c2020-07-01 16:21:27 -0700456 mTransform = transform;
Jeff Brown5912f952013-07-01 19:10:31 -0700457 mXPrecision = xPrecision;
458 mYPrecision = yPrecision;
Garfield Tan937bb832019-07-25 17:48:31 -0700459 mRawXCursorPosition = rawXCursorPosition;
460 mRawYCursorPosition = rawYCursorPosition;
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700461 mRawTransform = rawTransform;
Jeff Brown5912f952013-07-01 19:10:31 -0700462 mDownTime = downTime;
463 mPointerProperties.clear();
464 mPointerProperties.appendArray(pointerProperties, pointerCount);
465 mSampleEventTimes.clear();
466 mSamplePointerCoords.clear();
467 addSample(eventTime, pointerCoords);
468}
469
470void MotionEvent::copyFrom(const MotionEvent* other, bool keepHistory) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800471 InputEvent::initialize(other->mId, other->mDeviceId, other->mSource, other->mDisplayId,
472 other->mHmac);
Jeff Brown5912f952013-07-01 19:10:31 -0700473 mAction = other->mAction;
Michael Wright7b159c92015-05-14 14:48:03 +0100474 mActionButton = other->mActionButton;
Jeff Brown5912f952013-07-01 19:10:31 -0700475 mFlags = other->mFlags;
476 mEdgeFlags = other->mEdgeFlags;
477 mMetaState = other->mMetaState;
478 mButtonState = other->mButtonState;
Siarhei Vishniakou49e59222018-12-28 18:17:15 -0800479 mClassification = other->mClassification;
chaviw9eaa22c2020-07-01 16:21:27 -0700480 mTransform = other->mTransform;
Jeff Brown5912f952013-07-01 19:10:31 -0700481 mXPrecision = other->mXPrecision;
482 mYPrecision = other->mYPrecision;
Garfield Tan937bb832019-07-25 17:48:31 -0700483 mRawXCursorPosition = other->mRawXCursorPosition;
484 mRawYCursorPosition = other->mRawYCursorPosition;
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700485 mRawTransform = other->mRawTransform;
Jeff Brown5912f952013-07-01 19:10:31 -0700486 mDownTime = other->mDownTime;
487 mPointerProperties = other->mPointerProperties;
488
489 if (keepHistory) {
490 mSampleEventTimes = other->mSampleEventTimes;
491 mSamplePointerCoords = other->mSamplePointerCoords;
492 } else {
493 mSampleEventTimes.clear();
Siarhei Vishniakou46a27742020-09-09 13:57:28 -0500494 mSampleEventTimes.push_back(other->getEventTime());
Jeff Brown5912f952013-07-01 19:10:31 -0700495 mSamplePointerCoords.clear();
496 size_t pointerCount = other->getPointerCount();
497 size_t historySize = other->getHistorySize();
498 mSamplePointerCoords.appendArray(other->mSamplePointerCoords.array()
499 + (historySize * pointerCount), pointerCount);
500 }
501}
502
503void MotionEvent::addSample(
504 int64_t eventTime,
505 const PointerCoords* pointerCoords) {
Siarhei Vishniakou46a27742020-09-09 13:57:28 -0500506 mSampleEventTimes.push_back(eventTime);
Jeff Brown5912f952013-07-01 19:10:31 -0700507 mSamplePointerCoords.appendArray(pointerCoords, getPointerCount());
508}
509
Prabir Pradhan092f3a92021-11-25 10:53:27 -0800510int MotionEvent::getSurfaceRotation() const {
511 // The surface rotation is the rotation from the window's coordinate space to that of the
512 // display. Since the event's transform takes display space coordinates to window space, the
513 // returned surface rotation is the inverse of the rotation for the surface.
514 switch (mTransform.getOrientation()) {
515 case ui::Transform::ROT_0:
516 return DISPLAY_ORIENTATION_0;
517 case ui::Transform::ROT_90:
518 return DISPLAY_ORIENTATION_270;
519 case ui::Transform::ROT_180:
520 return DISPLAY_ORIENTATION_180;
521 case ui::Transform::ROT_270:
522 return DISPLAY_ORIENTATION_90;
523 default:
524 return -1;
525 }
526}
527
Garfield Tan00f511d2019-06-12 16:55:40 -0700528float MotionEvent::getXCursorPosition() const {
chaviw9eaa22c2020-07-01 16:21:27 -0700529 vec2 vals = mTransform.transform(getRawXCursorPosition(), getRawYCursorPosition());
530 return vals.x;
Garfield Tan00f511d2019-06-12 16:55:40 -0700531}
532
533float MotionEvent::getYCursorPosition() const {
chaviw9eaa22c2020-07-01 16:21:27 -0700534 vec2 vals = mTransform.transform(getRawXCursorPosition(), getRawYCursorPosition());
535 return vals.y;
Garfield Tan00f511d2019-06-12 16:55:40 -0700536}
537
Garfield Tan937bb832019-07-25 17:48:31 -0700538void MotionEvent::setCursorPosition(float x, float y) {
chaviw9eaa22c2020-07-01 16:21:27 -0700539 ui::Transform inverse = mTransform.inverse();
540 vec2 vals = inverse.transform(x, y);
541 mRawXCursorPosition = vals.x;
542 mRawYCursorPosition = vals.y;
Garfield Tan937bb832019-07-25 17:48:31 -0700543}
544
Jeff Brown5912f952013-07-01 19:10:31 -0700545const PointerCoords* MotionEvent::getRawPointerCoords(size_t pointerIndex) const {
546 return &mSamplePointerCoords[getHistorySize() * getPointerCount() + pointerIndex];
547}
548
549float MotionEvent::getRawAxisValue(int32_t axis, size_t pointerIndex) const {
Evan Rosky84f07f02021-04-16 10:42:42 -0700550 return getHistoricalRawAxisValue(axis, pointerIndex, getHistorySize());
Jeff Brown5912f952013-07-01 19:10:31 -0700551}
552
553float MotionEvent::getAxisValue(int32_t axis, size_t pointerIndex) const {
chaviw9eaa22c2020-07-01 16:21:27 -0700554 return getHistoricalAxisValue(axis, pointerIndex, getHistorySize());
Jeff Brown5912f952013-07-01 19:10:31 -0700555}
556
557const PointerCoords* MotionEvent::getHistoricalRawPointerCoords(
558 size_t pointerIndex, size_t historicalIndex) const {
559 return &mSamplePointerCoords[historicalIndex * getPointerCount() + pointerIndex];
560}
561
562float MotionEvent::getHistoricalRawAxisValue(int32_t axis, size_t pointerIndex,
Prabir Pradhan6b384612021-05-14 16:56:25 -0700563 size_t historicalIndex) const {
Prabir Pradhan9eb02c02021-10-19 14:02:20 -0700564 const PointerCoords& coords = *getHistoricalRawPointerCoords(pointerIndex, historicalIndex);
565 return calculateTransformedAxisValue(axis, mSource, mRawTransform, coords);
Jeff Brown5912f952013-07-01 19:10:31 -0700566}
567
568float MotionEvent::getHistoricalAxisValue(int32_t axis, size_t pointerIndex,
Prabir Pradhan9f388812021-05-13 16:54:53 -0700569 size_t historicalIndex) const {
Prabir Pradhan9eb02c02021-10-19 14:02:20 -0700570 const PointerCoords& coords = *getHistoricalRawPointerCoords(pointerIndex, historicalIndex);
571 return calculateTransformedAxisValue(axis, mSource, mTransform, coords);
Jeff Brown5912f952013-07-01 19:10:31 -0700572}
573
574ssize_t MotionEvent::findPointerIndex(int32_t pointerId) const {
575 size_t pointerCount = mPointerProperties.size();
576 for (size_t i = 0; i < pointerCount; i++) {
577 if (mPointerProperties.itemAt(i).id == pointerId) {
578 return i;
579 }
580 }
581 return -1;
582}
583
584void MotionEvent::offsetLocation(float xOffset, float yOffset) {
chaviw9eaa22c2020-07-01 16:21:27 -0700585 float currXOffset = mTransform.tx();
586 float currYOffset = mTransform.ty();
587 mTransform.set(currXOffset + xOffset, currYOffset + yOffset);
Jeff Brown5912f952013-07-01 19:10:31 -0700588}
589
Robert Carre07e1032018-11-26 12:55:53 -0800590void MotionEvent::scale(float globalScaleFactor) {
chaviw9eaa22c2020-07-01 16:21:27 -0700591 mTransform.set(mTransform.tx() * globalScaleFactor, mTransform.ty() * globalScaleFactor);
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700592 mRawTransform.set(mRawTransform.tx() * globalScaleFactor,
593 mRawTransform.ty() * globalScaleFactor);
Robert Carre07e1032018-11-26 12:55:53 -0800594 mXPrecision *= globalScaleFactor;
595 mYPrecision *= globalScaleFactor;
Jeff Brown5912f952013-07-01 19:10:31 -0700596
597 size_t numSamples = mSamplePointerCoords.size();
598 for (size_t i = 0; i < numSamples; i++) {
chaviw9eaa22c2020-07-01 16:21:27 -0700599 mSamplePointerCoords.editItemAt(i).scale(globalScaleFactor, globalScaleFactor,
600 globalScaleFactor);
Jeff Brown5912f952013-07-01 19:10:31 -0700601 }
602}
603
chaviw9eaa22c2020-07-01 16:21:27 -0700604void MotionEvent::transform(const std::array<float, 9>& matrix) {
Prabir Pradhan6b384612021-05-14 16:56:25 -0700605 // We want to preserve the raw axes values stored in the PointerCoords, so we just update the
606 // transform using the values passed in.
chaviw9eaa22c2020-07-01 16:21:27 -0700607 ui::Transform newTransform;
608 newTransform.set(matrix);
609 mTransform = newTransform * mTransform;
Jeff Brown5912f952013-07-01 19:10:31 -0700610}
611
Evan Roskyd4d4d802021-05-03 20:12:21 -0700612void MotionEvent::applyTransform(const std::array<float, 9>& matrix) {
Prabir Pradhan6b384612021-05-14 16:56:25 -0700613 ui::Transform transform;
614 transform.set(matrix);
Evan Roskyd4d4d802021-05-03 20:12:21 -0700615
616 // Apply the transformation to all samples.
Prabir Pradhan6b384612021-05-14 16:56:25 -0700617 std::for_each(mSamplePointerCoords.begin(), mSamplePointerCoords.end(),
618 [&transform](PointerCoords& c) { c.transform(transform); });
Prabir Pradhan4b19bd02021-06-01 17:34:59 -0700619
620 if (mRawXCursorPosition != AMOTION_EVENT_INVALID_CURSOR_POSITION &&
621 mRawYCursorPosition != AMOTION_EVENT_INVALID_CURSOR_POSITION) {
622 const vec2 cursor = transform.transform(mRawXCursorPosition, mRawYCursorPosition);
623 mRawXCursorPosition = cursor.x;
624 mRawYCursorPosition = cursor.y;
625 }
Evan Roskyd4d4d802021-05-03 20:12:21 -0700626}
627
Brett Chabotfaa986c2020-11-04 17:39:36 -0800628#ifdef __linux__
chaviw9eaa22c2020-07-01 16:21:27 -0700629static status_t readFromParcel(ui::Transform& transform, const Parcel& parcel) {
630 float dsdx, dtdx, tx, dtdy, dsdy, ty;
631 status_t status = parcel.readFloat(&dsdx);
632 status |= parcel.readFloat(&dtdx);
633 status |= parcel.readFloat(&tx);
634 status |= parcel.readFloat(&dtdy);
635 status |= parcel.readFloat(&dsdy);
636 status |= parcel.readFloat(&ty);
637
638 transform.set({dsdx, dtdx, tx, dtdy, dsdy, ty, 0, 0, 1});
639 return status;
640}
641
642static status_t writeToParcel(const ui::Transform& transform, Parcel& parcel) {
643 status_t status = parcel.writeFloat(transform.dsdx());
644 status |= parcel.writeFloat(transform.dtdx());
645 status |= parcel.writeFloat(transform.tx());
646 status |= parcel.writeFloat(transform.dtdy());
647 status |= parcel.writeFloat(transform.dsdy());
648 status |= parcel.writeFloat(transform.ty());
649 return status;
650}
651
Jeff Brown5912f952013-07-01 19:10:31 -0700652status_t MotionEvent::readFromParcel(Parcel* parcel) {
653 size_t pointerCount = parcel->readInt32();
654 size_t sampleCount = parcel->readInt32();
Flanker552a8a52015-09-07 15:28:58 +0800655 if (pointerCount == 0 || pointerCount > MAX_POINTERS ||
656 sampleCount == 0 || sampleCount > MAX_SAMPLES) {
Jeff Brown5912f952013-07-01 19:10:31 -0700657 return BAD_VALUE;
658 }
659
Garfield Tan4cc839f2020-01-24 11:26:14 -0800660 mId = parcel->readInt32();
Jeff Brown5912f952013-07-01 19:10:31 -0700661 mDeviceId = parcel->readInt32();
Siarhei Vishniakou3826d472020-01-27 10:44:40 -0600662 mSource = parcel->readUint32();
Siarhei Vishniakou777a10b2018-01-31 16:45:06 -0800663 mDisplayId = parcel->readInt32();
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600664 std::vector<uint8_t> hmac;
665 status_t result = parcel->readByteVector(&hmac);
666 if (result != OK || hmac.size() != 32) {
667 return BAD_VALUE;
668 }
669 std::move(hmac.begin(), hmac.begin() + hmac.size(), mHmac.begin());
Jeff Brown5912f952013-07-01 19:10:31 -0700670 mAction = parcel->readInt32();
Michael Wright7b159c92015-05-14 14:48:03 +0100671 mActionButton = parcel->readInt32();
Jeff Brown5912f952013-07-01 19:10:31 -0700672 mFlags = parcel->readInt32();
673 mEdgeFlags = parcel->readInt32();
674 mMetaState = parcel->readInt32();
675 mButtonState = parcel->readInt32();
Siarhei Vishniakou49e59222018-12-28 18:17:15 -0800676 mClassification = static_cast<MotionClassification>(parcel->readByte());
chaviw9eaa22c2020-07-01 16:21:27 -0700677
678 result = android::readFromParcel(mTransform, *parcel);
679 if (result != OK) {
680 return result;
681 }
Jeff Brown5912f952013-07-01 19:10:31 -0700682 mXPrecision = parcel->readFloat();
683 mYPrecision = parcel->readFloat();
Garfield Tan937bb832019-07-25 17:48:31 -0700684 mRawXCursorPosition = parcel->readFloat();
685 mRawYCursorPosition = parcel->readFloat();
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700686
687 result = android::readFromParcel(mRawTransform, *parcel);
688 if (result != OK) {
689 return result;
690 }
Jeff Brown5912f952013-07-01 19:10:31 -0700691 mDownTime = parcel->readInt64();
692
693 mPointerProperties.clear();
694 mPointerProperties.setCapacity(pointerCount);
695 mSampleEventTimes.clear();
Siarhei Vishniakou46a27742020-09-09 13:57:28 -0500696 mSampleEventTimes.reserve(sampleCount);
Jeff Brown5912f952013-07-01 19:10:31 -0700697 mSamplePointerCoords.clear();
698 mSamplePointerCoords.setCapacity(sampleCount * pointerCount);
699
700 for (size_t i = 0; i < pointerCount; i++) {
701 mPointerProperties.push();
702 PointerProperties& properties = mPointerProperties.editTop();
703 properties.id = parcel->readInt32();
704 properties.toolType = parcel->readInt32();
705 }
706
Dan Austinc94fc452015-09-22 14:22:41 -0700707 while (sampleCount > 0) {
708 sampleCount--;
Siarhei Vishniakou46a27742020-09-09 13:57:28 -0500709 mSampleEventTimes.push_back(parcel->readInt64());
Jeff Brown5912f952013-07-01 19:10:31 -0700710 for (size_t i = 0; i < pointerCount; i++) {
711 mSamplePointerCoords.push();
712 status_t status = mSamplePointerCoords.editTop().readFromParcel(parcel);
713 if (status) {
714 return status;
715 }
716 }
717 }
718 return OK;
719}
720
721status_t MotionEvent::writeToParcel(Parcel* parcel) const {
722 size_t pointerCount = mPointerProperties.size();
723 size_t sampleCount = mSampleEventTimes.size();
724
725 parcel->writeInt32(pointerCount);
726 parcel->writeInt32(sampleCount);
727
Garfield Tan4cc839f2020-01-24 11:26:14 -0800728 parcel->writeInt32(mId);
Jeff Brown5912f952013-07-01 19:10:31 -0700729 parcel->writeInt32(mDeviceId);
Siarhei Vishniakou3826d472020-01-27 10:44:40 -0600730 parcel->writeUint32(mSource);
Siarhei Vishniakou777a10b2018-01-31 16:45:06 -0800731 parcel->writeInt32(mDisplayId);
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600732 std::vector<uint8_t> hmac(mHmac.begin(), mHmac.end());
733 parcel->writeByteVector(hmac);
Jeff Brown5912f952013-07-01 19:10:31 -0700734 parcel->writeInt32(mAction);
Michael Wright7b159c92015-05-14 14:48:03 +0100735 parcel->writeInt32(mActionButton);
Jeff Brown5912f952013-07-01 19:10:31 -0700736 parcel->writeInt32(mFlags);
737 parcel->writeInt32(mEdgeFlags);
738 parcel->writeInt32(mMetaState);
739 parcel->writeInt32(mButtonState);
Siarhei Vishniakou49e59222018-12-28 18:17:15 -0800740 parcel->writeByte(static_cast<int8_t>(mClassification));
chaviw9eaa22c2020-07-01 16:21:27 -0700741
742 status_t result = android::writeToParcel(mTransform, *parcel);
743 if (result != OK) {
744 return result;
745 }
Jeff Brown5912f952013-07-01 19:10:31 -0700746 parcel->writeFloat(mXPrecision);
747 parcel->writeFloat(mYPrecision);
Garfield Tan937bb832019-07-25 17:48:31 -0700748 parcel->writeFloat(mRawXCursorPosition);
749 parcel->writeFloat(mRawYCursorPosition);
Prabir Pradhanb9b18502021-08-26 12:30:32 -0700750
751 result = android::writeToParcel(mRawTransform, *parcel);
752 if (result != OK) {
753 return result;
754 }
Jeff Brown5912f952013-07-01 19:10:31 -0700755 parcel->writeInt64(mDownTime);
756
757 for (size_t i = 0; i < pointerCount; i++) {
758 const PointerProperties& properties = mPointerProperties.itemAt(i);
759 parcel->writeInt32(properties.id);
760 parcel->writeInt32(properties.toolType);
761 }
762
763 const PointerCoords* pc = mSamplePointerCoords.array();
764 for (size_t h = 0; h < sampleCount; h++) {
Siarhei Vishniakou46a27742020-09-09 13:57:28 -0500765 parcel->writeInt64(mSampleEventTimes[h]);
Jeff Brown5912f952013-07-01 19:10:31 -0700766 for (size_t i = 0; i < pointerCount; i++) {
767 status_t status = (pc++)->writeToParcel(parcel);
768 if (status) {
769 return status;
770 }
771 }
772 }
773 return OK;
774}
Brett Chabotfaa986c2020-11-04 17:39:36 -0800775#endif
Jeff Brown5912f952013-07-01 19:10:31 -0700776
Siarhei Vishniakou3826d472020-01-27 10:44:40 -0600777bool MotionEvent::isTouchEvent(uint32_t source, int32_t action) {
Prabir Pradhan7e1ee562021-10-26 10:19:49 -0700778 if (isFromSource(source, AINPUT_SOURCE_CLASS_POINTER)) {
Jeff Brown5912f952013-07-01 19:10:31 -0700779 // Specifically excludes HOVER_MOVE and SCROLL.
780 switch (action & AMOTION_EVENT_ACTION_MASK) {
781 case AMOTION_EVENT_ACTION_DOWN:
782 case AMOTION_EVENT_ACTION_MOVE:
783 case AMOTION_EVENT_ACTION_UP:
784 case AMOTION_EVENT_ACTION_POINTER_DOWN:
785 case AMOTION_EVENT_ACTION_POINTER_UP:
786 case AMOTION_EVENT_ACTION_CANCEL:
787 case AMOTION_EVENT_ACTION_OUTSIDE:
788 return true;
789 }
790 }
791 return false;
792}
793
Michael Wright872db4f2014-04-22 15:03:51 -0700794const char* MotionEvent::getLabel(int32_t axis) {
Chris Ye4958d062020-08-20 13:21:10 -0700795 return InputEventLookup::getAxisLabel(axis);
Michael Wright872db4f2014-04-22 15:03:51 -0700796}
797
798int32_t MotionEvent::getAxisFromLabel(const char* label) {
Chris Ye4958d062020-08-20 13:21:10 -0700799 return InputEventLookup::getAxisByLabel(label);
Michael Wright872db4f2014-04-22 15:03:51 -0700800}
801
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -0500802std::string MotionEvent::actionToString(int32_t action) {
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700803 // Convert MotionEvent action to string
804 switch (action & AMOTION_EVENT_ACTION_MASK) {
805 case AMOTION_EVENT_ACTION_DOWN:
806 return "DOWN";
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700807 case AMOTION_EVENT_ACTION_UP:
808 return "UP";
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -0500809 case AMOTION_EVENT_ACTION_MOVE:
810 return "MOVE";
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700811 case AMOTION_EVENT_ACTION_CANCEL:
812 return "CANCEL";
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -0500813 case AMOTION_EVENT_ACTION_OUTSIDE:
814 return "OUTSIDE";
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700815 case AMOTION_EVENT_ACTION_POINTER_DOWN:
Siarhei Vishniakouca205502021-07-16 21:31:58 +0000816 return StringPrintf("POINTER_DOWN(%" PRId32 ")", MotionEvent::getActionIndex(action));
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700817 case AMOTION_EVENT_ACTION_POINTER_UP:
Siarhei Vishniakouca205502021-07-16 21:31:58 +0000818 return StringPrintf("POINTER_UP(%" PRId32 ")", MotionEvent::getActionIndex(action));
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -0500819 case AMOTION_EVENT_ACTION_HOVER_MOVE:
820 return "HOVER_MOVE";
821 case AMOTION_EVENT_ACTION_SCROLL:
822 return "SCROLL";
823 case AMOTION_EVENT_ACTION_HOVER_ENTER:
824 return "HOVER_ENTER";
825 case AMOTION_EVENT_ACTION_HOVER_EXIT:
826 return "HOVER_EXIT";
827 case AMOTION_EVENT_ACTION_BUTTON_PRESS:
828 return "BUTTON_PRESS";
829 case AMOTION_EVENT_ACTION_BUTTON_RELEASE:
830 return "BUTTON_RELEASE";
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700831 }
Siarhei Vishniakouc68fdec2020-10-22 14:58:14 -0500832 return android::base::StringPrintf("%" PRId32, action);
Siarhei Vishniakoud44dddf2020-03-25 16:16:40 -0700833}
834
Prabir Pradhan7e1ee562021-10-26 10:19:49 -0700835// Apply the given transformation to the point without checking whether the entire transform
836// should be disregarded altogether for the provided source.
837static inline vec2 calculateTransformedXYUnchecked(uint32_t source, const ui::Transform& transform,
838 const vec2& xy) {
839 return shouldDisregardOffset(source) ? transformWithoutTranslation(transform, xy)
840 : transform.transform(xy);
841}
842
Prabir Pradhanb5cb9572021-09-24 06:35:16 -0700843vec2 MotionEvent::calculateTransformedXY(uint32_t source, const ui::Transform& transform,
844 const vec2& xy) {
Prabir Pradhan7e1ee562021-10-26 10:19:49 -0700845 if (shouldDisregardTransformation(source)) {
846 return xy;
847 }
848 return calculateTransformedXYUnchecked(source, transform, xy);
Prabir Pradhanb5cb9572021-09-24 06:35:16 -0700849}
850
Prabir Pradhan9eb02c02021-10-19 14:02:20 -0700851float MotionEvent::calculateTransformedAxisValue(int32_t axis, uint32_t source,
852 const ui::Transform& transform,
853 const PointerCoords& coords) {
Prabir Pradhan7e1ee562021-10-26 10:19:49 -0700854 if (shouldDisregardTransformation(source)) {
855 return coords.getAxisValue(axis);
856 }
857
Prabir Pradhan9eb02c02021-10-19 14:02:20 -0700858 if (axis == AMOTION_EVENT_AXIS_X || axis == AMOTION_EVENT_AXIS_Y) {
Prabir Pradhan7e1ee562021-10-26 10:19:49 -0700859 const vec2 xy = calculateTransformedXYUnchecked(source, transform, coords.getXYValue());
Prabir Pradhan9eb02c02021-10-19 14:02:20 -0700860 static_assert(AMOTION_EVENT_AXIS_X == 0 && AMOTION_EVENT_AXIS_Y == 1);
861 return xy[axis];
862 }
863
864 if (axis == AMOTION_EVENT_AXIS_RELATIVE_X || axis == AMOTION_EVENT_AXIS_RELATIVE_Y) {
865 const vec2 relativeXy =
866 transformWithoutTranslation(transform,
867 {coords.getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X),
868 coords.getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y)});
869 return axis == AMOTION_EVENT_AXIS_RELATIVE_X ? relativeXy.x : relativeXy.y;
870 }
871
872 if (axis == AMOTION_EVENT_AXIS_ORIENTATION) {
873 return transformAngle(transform, coords.getAxisValue(AMOTION_EVENT_AXIS_ORIENTATION));
874 }
875
876 return coords.getAxisValue(axis);
877}
878
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800879// --- FocusEvent ---
880
Antonio Kantek3cfec7b2021-11-05 18:26:17 -0700881void FocusEvent::initialize(int32_t id, bool hasFocus) {
Garfield Tan4cc839f2020-01-24 11:26:14 -0800882 InputEvent::initialize(id, ReservedInputDeviceId::VIRTUAL_KEYBOARD_ID, AINPUT_SOURCE_UNKNOWN,
Siarhei Vishniakou9c858ac2020-01-23 14:20:11 -0600883 ADISPLAY_ID_NONE, INVALID_HMAC);
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800884 mHasFocus = hasFocus;
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800885}
886
887void FocusEvent::initialize(const FocusEvent& from) {
888 InputEvent::initialize(from);
889 mHasFocus = from.mHasFocus;
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800890}
Jeff Brown5912f952013-07-01 19:10:31 -0700891
Prabir Pradhan3f37b7b2020-11-10 16:50:18 -0800892// --- CaptureEvent ---
893
894void CaptureEvent::initialize(int32_t id, bool pointerCaptureEnabled) {
895 InputEvent::initialize(id, ReservedInputDeviceId::VIRTUAL_KEYBOARD_ID, AINPUT_SOURCE_UNKNOWN,
896 ADISPLAY_ID_NONE, INVALID_HMAC);
897 mPointerCaptureEnabled = pointerCaptureEnabled;
898}
899
900void CaptureEvent::initialize(const CaptureEvent& from) {
901 InputEvent::initialize(from);
902 mPointerCaptureEnabled = from.mPointerCaptureEnabled;
903}
904
arthurhung7632c332020-12-30 16:58:01 +0800905// --- DragEvent ---
906
907void DragEvent::initialize(int32_t id, float x, float y, bool isExiting) {
908 InputEvent::initialize(id, ReservedInputDeviceId::VIRTUAL_KEYBOARD_ID, AINPUT_SOURCE_UNKNOWN,
909 ADISPLAY_ID_NONE, INVALID_HMAC);
910 mIsExiting = isExiting;
911 mX = x;
912 mY = y;
913}
914
915void DragEvent::initialize(const DragEvent& from) {
916 InputEvent::initialize(from);
917 mIsExiting = from.mIsExiting;
918 mX = from.mX;
919 mY = from.mY;
920}
921
Antonio Kantek7cdf8ef2021-07-13 18:04:53 -0700922// --- TouchModeEvent ---
923
924void TouchModeEvent::initialize(int32_t id, bool isInTouchMode) {
925 InputEvent::initialize(id, ReservedInputDeviceId::VIRTUAL_KEYBOARD_ID, AINPUT_SOURCE_UNKNOWN,
926 ADISPLAY_ID_NONE, INVALID_HMAC);
927 mIsInTouchMode = isInTouchMode;
928}
929
930void TouchModeEvent::initialize(const TouchModeEvent& from) {
931 InputEvent::initialize(from);
932 mIsInTouchMode = from.mIsInTouchMode;
933}
934
Jeff Brown5912f952013-07-01 19:10:31 -0700935// --- PooledInputEventFactory ---
936
937PooledInputEventFactory::PooledInputEventFactory(size_t maxPoolSize) :
938 mMaxPoolSize(maxPoolSize) {
939}
940
941PooledInputEventFactory::~PooledInputEventFactory() {
Jeff Brown5912f952013-07-01 19:10:31 -0700942}
943
944KeyEvent* PooledInputEventFactory::createKeyEvent() {
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -0800945 if (mKeyEventPool.empty()) {
946 return new KeyEvent();
Jeff Brown5912f952013-07-01 19:10:31 -0700947 }
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -0800948 KeyEvent* event = mKeyEventPool.front().release();
949 mKeyEventPool.pop();
950 return event;
Jeff Brown5912f952013-07-01 19:10:31 -0700951}
952
953MotionEvent* PooledInputEventFactory::createMotionEvent() {
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -0800954 if (mMotionEventPool.empty()) {
955 return new MotionEvent();
Jeff Brown5912f952013-07-01 19:10:31 -0700956 }
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -0800957 MotionEvent* event = mMotionEventPool.front().release();
958 mMotionEventPool.pop();
959 return event;
Jeff Brown5912f952013-07-01 19:10:31 -0700960}
961
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -0800962FocusEvent* PooledInputEventFactory::createFocusEvent() {
963 if (mFocusEventPool.empty()) {
964 return new FocusEvent();
965 }
966 FocusEvent* event = mFocusEventPool.front().release();
967 mFocusEventPool.pop();
968 return event;
969}
970
Prabir Pradhan3f37b7b2020-11-10 16:50:18 -0800971CaptureEvent* PooledInputEventFactory::createCaptureEvent() {
972 if (mCaptureEventPool.empty()) {
973 return new CaptureEvent();
974 }
975 CaptureEvent* event = mCaptureEventPool.front().release();
976 mCaptureEventPool.pop();
977 return event;
978}
979
arthurhung7632c332020-12-30 16:58:01 +0800980DragEvent* PooledInputEventFactory::createDragEvent() {
981 if (mDragEventPool.empty()) {
982 return new DragEvent();
983 }
984 DragEvent* event = mDragEventPool.front().release();
985 mDragEventPool.pop();
986 return event;
987}
988
Antonio Kantek7cdf8ef2021-07-13 18:04:53 -0700989TouchModeEvent* PooledInputEventFactory::createTouchModeEvent() {
990 if (mTouchModeEventPool.empty()) {
991 return new TouchModeEvent();
992 }
993 TouchModeEvent* event = mTouchModeEventPool.front().release();
994 mTouchModeEventPool.pop();
995 return event;
996}
997
Jeff Brown5912f952013-07-01 19:10:31 -0700998void PooledInputEventFactory::recycle(InputEvent* event) {
999 switch (event->getType()) {
1000 case AINPUT_EVENT_TYPE_KEY:
1001 if (mKeyEventPool.size() < mMaxPoolSize) {
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -08001002 mKeyEventPool.push(std::unique_ptr<KeyEvent>(static_cast<KeyEvent*>(event)));
Jeff Brown5912f952013-07-01 19:10:31 -07001003 return;
1004 }
1005 break;
1006 case AINPUT_EVENT_TYPE_MOTION:
1007 if (mMotionEventPool.size() < mMaxPoolSize) {
Siarhei Vishniakou727a44e2019-11-23 12:59:16 -08001008 mMotionEventPool.push(std::unique_ptr<MotionEvent>(static_cast<MotionEvent*>(event)));
Jeff Brown5912f952013-07-01 19:10:31 -07001009 return;
1010 }
1011 break;
Siarhei Vishniakou7feb2ea2019-11-25 15:11:23 -08001012 case AINPUT_EVENT_TYPE_FOCUS:
1013 if (mFocusEventPool.size() < mMaxPoolSize) {
1014 mFocusEventPool.push(std::unique_ptr<FocusEvent>(static_cast<FocusEvent*>(event)));
1015 return;
1016 }
1017 break;
Prabir Pradhan3f37b7b2020-11-10 16:50:18 -08001018 case AINPUT_EVENT_TYPE_CAPTURE:
1019 if (mCaptureEventPool.size() < mMaxPoolSize) {
1020 mCaptureEventPool.push(
1021 std::unique_ptr<CaptureEvent>(static_cast<CaptureEvent*>(event)));
1022 return;
1023 }
1024 break;
arthurhung7632c332020-12-30 16:58:01 +08001025 case AINPUT_EVENT_TYPE_DRAG:
1026 if (mDragEventPool.size() < mMaxPoolSize) {
1027 mDragEventPool.push(std::unique_ptr<DragEvent>(static_cast<DragEvent*>(event)));
1028 return;
1029 }
1030 break;
Antonio Kantekeb4a30c2021-09-28 17:49:49 -07001031 case AINPUT_EVENT_TYPE_TOUCH_MODE:
1032 if (mTouchModeEventPool.size() < mMaxPoolSize) {
1033 mTouchModeEventPool.push(
1034 std::unique_ptr<TouchModeEvent>(static_cast<TouchModeEvent*>(event)));
1035 return;
1036 }
1037 break;
Jeff Brown5912f952013-07-01 19:10:31 -07001038 }
1039 delete event;
1040}
1041
1042} // namespace android