diff options
| author | 2024-11-25 11:17:42 +0000 | |
|---|---|---|
| committer | 2024-11-25 18:57:34 +0000 | |
| commit | 5cd7497f3e9d6869ff414c216c88b6eb3a57c6fc (patch) | |
| tree | 28ad34a70803a70a57861145c28556c0fabd617b | |
| parent | 7918c82519d65001c21057319793816898cfe0f1 (diff) | |
Refactor processing of relative pointer movements
Refactor to extract common code that controls cursor movement of a
relative mouse in processing of motion events in PointerChoreographer.
Bug: 367660694
Test: atest inputflinger_tests
Flag: EXEMPT refactor
Change-Id: I7f8683f7cda7de6c7bcaf82ceb02dc54b70c71ee
| -rw-r--r-- | services/inputflinger/PointerChoreographer.cpp | 42 | ||||
| -rw-r--r-- | services/inputflinger/PointerChoreographer.h | 2 | 
2 files changed, 20 insertions, 24 deletions
| diff --git a/services/inputflinger/PointerChoreographer.cpp b/services/inputflinger/PointerChoreographer.cpp index a67df58fe4..38e5974c3f 100644 --- a/services/inputflinger/PointerChoreographer.cpp +++ b/services/inputflinger/PointerChoreographer.cpp @@ -243,14 +243,7 @@ NotifyMotionArgs PointerChoreographer::processMouseEventLocked(const NotifyMotio          pc.setPosition(args.xCursorPosition, args.yCursorPosition);      } else {          // This is a relative mouse, so move the cursor by the specified amount. -        const float deltaX = args.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X); -        const float deltaY = args.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y); -        pc.move(deltaX, deltaY); -        const auto [x, y] = pc.getPosition(); -        newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, x); -        newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, y); -        newArgs.xCursorPosition = x; -        newArgs.yCursorPosition = y; +        processPointerDeviceMotionEventLocked(/*byref*/ newArgs, /*byref*/ pc);      }      if (canUnfadeOnDisplay(displayId)) {          pc.unfade(PointerControllerInterface::Transition::IMMEDIATE); @@ -266,24 +259,9 @@ NotifyMotionArgs PointerChoreographer::processTouchpadEventLocked(const NotifyMo      newArgs.displayId = displayId;      if (args.getPointerCount() == 1 && args.classification == MotionClassification::NONE) {          // This is a movement of the mouse pointer. -        const float deltaX = args.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X); -        const float deltaY = args.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y); -        pc.move(deltaX, deltaY); -        if (canUnfadeOnDisplay(displayId)) { -            pc.unfade(PointerControllerInterface::Transition::IMMEDIATE); -        } - -        const auto [x, y] = pc.getPosition(); -        newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, x); -        newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, y); -        newArgs.xCursorPosition = x; -        newArgs.yCursorPosition = y; +        processPointerDeviceMotionEventLocked(/*byref*/ newArgs, /*byref*/ pc);      } else {          // This is a trackpad gesture with fake finger(s) that should not move the mouse pointer. -        if (canUnfadeOnDisplay(displayId)) { -            pc.unfade(PointerControllerInterface::Transition::IMMEDIATE); -        } -          const auto [x, y] = pc.getPosition();          for (uint32_t i = 0; i < newArgs.getPointerCount(); i++) {              newArgs.pointerCoords[i].setAxisValue(AMOTION_EVENT_AXIS_X, @@ -294,9 +272,25 @@ NotifyMotionArgs PointerChoreographer::processTouchpadEventLocked(const NotifyMo          newArgs.xCursorPosition = x;          newArgs.yCursorPosition = y;      } +    if (canUnfadeOnDisplay(displayId)) { +        pc.unfade(PointerControllerInterface::Transition::IMMEDIATE); +    }      return newArgs;  } +void PointerChoreographer::processPointerDeviceMotionEventLocked(NotifyMotionArgs& newArgs, +                                                                 PointerControllerInterface& pc) { +    const float deltaX = newArgs.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_X); +    const float deltaY = newArgs.pointerCoords[0].getAxisValue(AMOTION_EVENT_AXIS_RELATIVE_Y); + +    pc.move(deltaX, deltaY); +    const auto [x, y] = pc.getPosition(); +    newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, x); +    newArgs.pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, y); +    newArgs.xCursorPosition = x; +    newArgs.yCursorPosition = y; +} +  void PointerChoreographer::processDrawingTabletEventLocked(const android::NotifyMotionArgs& args) {      if (args.displayId == ui::LogicalDisplayId::INVALID) {          return; diff --git a/services/inputflinger/PointerChoreographer.h b/services/inputflinger/PointerChoreographer.h index 85f51e06bc..fba1aef260 100644 --- a/services/inputflinger/PointerChoreographer.h +++ b/services/inputflinger/PointerChoreographer.h @@ -145,6 +145,8 @@ private:      void processDrawingTabletEventLocked(const NotifyMotionArgs& args) REQUIRES(getLock());      void processTouchscreenAndStylusEventLocked(const NotifyMotionArgs& args) REQUIRES(getLock());      void processStylusHoverEventLocked(const NotifyMotionArgs& args) REQUIRES(getLock()); +    void processPointerDeviceMotionEventLocked(NotifyMotionArgs& newArgs, +                                               PointerControllerInterface& pc) REQUIRES(getLock());      void processDeviceReset(const NotifyDeviceResetArgs& args);      void onControllerAddedOrRemovedLocked() REQUIRES(getLock());      void onPrivacySensitiveDisplaysChangedLocked( |