Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 1 | /* |
| 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_POINTER_CONTROLLER_H |
| 18 | #define _UI_POINTER_CONTROLLER_H |
| 19 | |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 20 | #include <PointerControllerInterface.h> |
| 21 | #include <gui/DisplayEventReceiver.h> |
Patrick Williams | 8e47a67 | 2023-05-01 11:30:37 -0500 | [diff] [blame] | 22 | #include <gui/WindowInfosUpdate.h> |
Arthur Hung | b9b3200 | 2018-12-18 17:39:43 +0800 | [diff] [blame] | 23 | #include <input/DisplayViewport.h> |
Jeff Brown | 9d3b1a4 | 2013-07-01 19:07:15 -0700 | [diff] [blame] | 24 | #include <input/Input.h> |
Jeff Brown | 8a90e6e | 2012-05-11 12:24:35 -0700 | [diff] [blame] | 25 | #include <utils/BitSet.h> |
Jeff Brown | 05dc66a | 2011-03-02 14:41:58 -0800 | [diff] [blame] | 26 | #include <utils/Looper.h> |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 27 | #include <utils/RefBase.h> |
| 28 | |
| 29 | #include <map> |
| 30 | #include <memory> |
Michael Wright | 72a8913 | 2022-10-22 03:16:31 +0100 | [diff] [blame] | 31 | #include <string> |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 32 | #include <vector> |
| 33 | |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 34 | #include "MouseCursorController.h" |
| 35 | #include "PointerControllerContext.h" |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 36 | #include "SpriteController.h" |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 37 | #include "TouchSpotController.h" |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 38 | |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 39 | namespace android { |
| 40 | |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 41 | /* |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 42 | * Tracks pointer movements and draws the pointer sprite to a surface. |
| 43 | * |
| 44 | * Handles pointer acceleration and animation. |
| 45 | */ |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 46 | class PointerController : public PointerControllerInterface { |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 47 | public: |
Michael Wright | a0bc6b1 | 2020-06-26 20:25:34 +0100 | [diff] [blame] | 48 | static std::shared_ptr<PointerController> create( |
| 49 | const sp<PointerControllerPolicyInterface>& policy, const sp<Looper>& looper, |
Byoungho Jung | 6a2ce94 | 2023-10-07 16:19:19 +0900 | [diff] [blame] | 50 | SpriteController& spriteController, bool enabled, |
| 51 | ControllerType type = ControllerType::LEGACY); |
Jeff Brown | 05dc66a | 2011-03-02 14:41:58 -0800 | [diff] [blame] | 52 | |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 53 | ~PointerController() override; |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 54 | |
Siarhei Vishniakou | a21a549 | 2023-03-15 09:29:53 -0700 | [diff] [blame] | 55 | std::optional<FloatRect> getBounds() const override; |
| 56 | void move(float deltaX, float deltaY) override; |
| 57 | void setPosition(float x, float y) override; |
| 58 | FloatPoint getPosition() const override; |
| 59 | int32_t getDisplayId() const override; |
| 60 | void fade(Transition transition) override; |
| 61 | void unfade(Transition transition) override; |
| 62 | void setDisplayViewport(const DisplayViewport& viewport) override; |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 63 | |
Siarhei Vishniakou | a21a549 | 2023-03-15 09:29:53 -0700 | [diff] [blame] | 64 | void setPresentation(Presentation presentation) override; |
| 65 | void setSpots(const PointerCoords* spotCoords, const uint32_t* spotIdToIndex, |
| 66 | BitSet32 spotIdBits, int32_t displayId) override; |
| 67 | void clearSpots() override; |
Byoungho Jung | 1a1571d | 2023-11-03 20:12:50 +0900 | [diff] [blame] | 68 | void updatePointerIcon(PointerIconStyle iconId) override; |
| 69 | void setCustomPointerIcon(const SpriteIcon& icon) override; |
Arpit Singh | 80fd68a | 2024-03-26 18:41:06 +0000 | [diff] [blame^] | 70 | void setSkipScreenshot(int32_t displayId, bool skip) override; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 71 | |
Byoungho Jung | 51282e8 | 2023-10-27 18:15:41 +0900 | [diff] [blame] | 72 | virtual void setInactivityTimeout(InactivityTimeout inactivityTimeout); |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 73 | void doInactivityTimeout(); |
Jun Mukai | 19a5601 | 2015-11-24 11:25:52 -0800 | [diff] [blame] | 74 | void reloadPointerResources(); |
Prabir Pradhan | c220018 | 2023-06-09 23:39:15 +0000 | [diff] [blame] | 75 | void onDisplayViewportsUpdated(const std::vector<DisplayViewport>& viewports); |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 76 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 77 | void onDisplayInfosChangedLocked(const std::vector<gui::DisplayInfo>& displayInfos) |
| 78 | REQUIRES(getLock()); |
| 79 | |
Byoungho Jung | 6a2ce94 | 2023-10-07 16:19:19 +0900 | [diff] [blame] | 80 | std::string dump() override; |
Michael Wright | 72a8913 | 2022-10-22 03:16:31 +0100 | [diff] [blame] | 81 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 82 | protected: |
Prabir Pradhan | bdf9369 | 2024-01-23 18:08:28 +0000 | [diff] [blame] | 83 | using WindowListenerRegisterConsumer = std::function<std::vector<gui::DisplayInfo>( |
| 84 | const sp<android::gui::WindowInfosListener>&)>; |
Linnan Li | 37c1b99 | 2023-11-24 13:05:13 +0800 | [diff] [blame] | 85 | using WindowListenerUnregisterConsumer = |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 86 | std::function<void(const sp<android::gui::WindowInfosListener>&)>; |
| 87 | |
| 88 | // Constructor used to test WindowInfosListener registration. |
| 89 | PointerController(const sp<PointerControllerPolicyInterface>& policy, const sp<Looper>& looper, |
Prabir Pradhan | 3401d23 | 2023-06-15 23:15:32 +0000 | [diff] [blame] | 90 | SpriteController& spriteController, bool enabled, |
Linnan Li | 37c1b99 | 2023-11-24 13:05:13 +0800 | [diff] [blame] | 91 | const WindowListenerRegisterConsumer& registerListener, |
| 92 | WindowListenerUnregisterConsumer unregisterListener); |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 93 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 94 | PointerController(const sp<PointerControllerPolicyInterface>& policy, const sp<Looper>& looper, |
Prabir Pradhan | 3401d23 | 2023-06-15 23:15:32 +0000 | [diff] [blame] | 95 | SpriteController& spriteController, bool enabled); |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 96 | |
Byoungho Jung | 6a2ce94 | 2023-10-07 16:19:19 +0900 | [diff] [blame] | 97 | private: |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 98 | friend PointerControllerContext::LooperCallback; |
| 99 | friend PointerControllerContext::MessageHandler; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 100 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 101 | // PointerController's DisplayInfoListener can outlive the PointerController because when the |
| 102 | // listener is registered, a strong pointer to the listener (which can extend its lifecycle) |
| 103 | // is given away. To avoid the small overhead of using two separate locks in these two objects, |
| 104 | // we use the DisplayInfoListener's lock in PointerController. |
| 105 | std::mutex& getLock() const; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 106 | |
Prabir Pradhan | 3401d23 | 2023-06-15 23:15:32 +0000 | [diff] [blame] | 107 | const bool mEnabled; |
| 108 | |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 109 | PointerControllerContext mContext; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 110 | |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 111 | MouseCursorController mCursorController; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 112 | |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 113 | struct Locked { |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 114 | Presentation presentation; |
Prabir Pradhan | 0e3d665 | 2022-03-10 14:39:46 +0000 | [diff] [blame] | 115 | int32_t pointerDisplayId = ADISPLAY_ID_NONE; |
Jeff Brown | 2352b97 | 2011-04-12 22:39:53 -0700 | [diff] [blame] | 116 | |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 117 | std::vector<gui::DisplayInfo> mDisplayInfos; |
Liam Harrington | c782be6 | 2020-07-17 19:48:24 +0000 | [diff] [blame] | 118 | std::unordered_map<int32_t /* displayId */, TouchSpotController> spotControllers; |
Arpit Singh | 80fd68a | 2024-03-26 18:41:06 +0000 | [diff] [blame^] | 119 | std::unordered_set<int32_t /* displayId */> displaysToSkipScreenshot; |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 120 | } mLocked GUARDED_BY(getLock()); |
Jeff Brown | 05dc66a | 2011-03-02 14:41:58 -0800 | [diff] [blame] | 121 | |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 122 | class DisplayInfoListener : public gui::WindowInfosListener { |
| 123 | public: |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 124 | explicit DisplayInfoListener(PointerController* pc) : mPointerController(pc){}; |
Patrick Williams | 8e47a67 | 2023-05-01 11:30:37 -0500 | [diff] [blame] | 125 | void onWindowInfosChanged(const gui::WindowInfosUpdate&) override; |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 126 | void onPointerControllerDestroyed(); |
| 127 | |
| 128 | // This lock is also used by PointerController. See PointerController::getLock(). |
| 129 | std::mutex mLock; |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 130 | |
| 131 | private: |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 132 | PointerController* mPointerController GUARDED_BY(mLock); |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 133 | }; |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 134 | |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 135 | sp<DisplayInfoListener> mDisplayInfoListener; |
Linnan Li | 37c1b99 | 2023-11-24 13:05:13 +0800 | [diff] [blame] | 136 | const WindowListenerUnregisterConsumer mUnregisterWindowInfosListener; |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 137 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 138 | const ui::Transform& getTransformForDisplayLocked(int displayId) const REQUIRES(getLock()); |
Prabir Pradhan | f97fac3 | 2021-11-18 16:40:34 +0000 | [diff] [blame] | 139 | |
Prabir Pradhan | 5693cee | 2021-12-31 06:51:15 -0800 | [diff] [blame] | 140 | void clearSpotsLocked() REQUIRES(getLock()); |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 141 | }; |
| 142 | |
Byoungho Jung | 6a2ce94 | 2023-10-07 16:19:19 +0900 | [diff] [blame] | 143 | class MousePointerController : public PointerController { |
| 144 | public: |
| 145 | /** A version of PointerController that controls one mouse pointer. */ |
| 146 | MousePointerController(const sp<PointerControllerPolicyInterface>& policy, |
| 147 | const sp<Looper>& looper, SpriteController& spriteController, |
| 148 | bool enabled); |
| 149 | |
Prabir Pradhan | b0e2807 | 2023-11-08 21:09:34 +0000 | [diff] [blame] | 150 | ~MousePointerController() override; |
| 151 | |
Byoungho Jung | 6a2ce94 | 2023-10-07 16:19:19 +0900 | [diff] [blame] | 152 | void setPresentation(Presentation) override { |
| 153 | LOG_ALWAYS_FATAL("Should not be called"); |
| 154 | } |
| 155 | void setSpots(const PointerCoords*, const uint32_t*, BitSet32, int32_t) override { |
| 156 | LOG_ALWAYS_FATAL("Should not be called"); |
| 157 | } |
| 158 | void clearSpots() override { |
| 159 | LOG_ALWAYS_FATAL("Should not be called"); |
| 160 | } |
| 161 | }; |
| 162 | |
Byoungho Jung | 51282e8 | 2023-10-27 18:15:41 +0900 | [diff] [blame] | 163 | class TouchPointerController : public PointerController { |
| 164 | public: |
| 165 | /** A version of PointerController that controls touch spots. */ |
| 166 | TouchPointerController(const sp<PointerControllerPolicyInterface>& policy, |
| 167 | const sp<Looper>& looper, SpriteController& spriteController, |
| 168 | bool enabled); |
| 169 | |
Prabir Pradhan | b0e2807 | 2023-11-08 21:09:34 +0000 | [diff] [blame] | 170 | ~TouchPointerController() override; |
| 171 | |
Byoungho Jung | 51282e8 | 2023-10-27 18:15:41 +0900 | [diff] [blame] | 172 | std::optional<FloatRect> getBounds() const override { |
| 173 | LOG_ALWAYS_FATAL("Should not be called"); |
| 174 | } |
| 175 | void move(float, float) override { |
| 176 | LOG_ALWAYS_FATAL("Should not be called"); |
| 177 | } |
| 178 | void setPosition(float, float) override { |
| 179 | LOG_ALWAYS_FATAL("Should not be called"); |
| 180 | } |
| 181 | FloatPoint getPosition() const override { |
| 182 | LOG_ALWAYS_FATAL("Should not be called"); |
| 183 | } |
| 184 | int32_t getDisplayId() const override { |
| 185 | LOG_ALWAYS_FATAL("Should not be called"); |
| 186 | } |
| 187 | void fade(Transition) override { |
| 188 | LOG_ALWAYS_FATAL("Should not be called"); |
| 189 | } |
| 190 | void unfade(Transition) override { |
| 191 | LOG_ALWAYS_FATAL("Should not be called"); |
| 192 | } |
| 193 | void setDisplayViewport(const DisplayViewport&) override { |
| 194 | LOG_ALWAYS_FATAL("Should not be called"); |
| 195 | } |
| 196 | void setPresentation(Presentation) override { |
| 197 | LOG_ALWAYS_FATAL("Should not be called"); |
| 198 | } |
Byoungho Jung | 1a1571d | 2023-11-03 20:12:50 +0900 | [diff] [blame] | 199 | void updatePointerIcon(PointerIconStyle) override { |
Byoungho Jung | 51282e8 | 2023-10-27 18:15:41 +0900 | [diff] [blame] | 200 | LOG_ALWAYS_FATAL("Should not be called"); |
| 201 | } |
Byoungho Jung | 1a1571d | 2023-11-03 20:12:50 +0900 | [diff] [blame] | 202 | void setCustomPointerIcon(const SpriteIcon&) override { |
Byoungho Jung | 51282e8 | 2023-10-27 18:15:41 +0900 | [diff] [blame] | 203 | LOG_ALWAYS_FATAL("Should not be called"); |
| 204 | } |
| 205 | // fade() should not be called by inactivity timeout. Do nothing. |
| 206 | void setInactivityTimeout(InactivityTimeout) override {} |
| 207 | }; |
| 208 | |
Byoungho Jung | 08daa25 | 2023-10-27 20:55:18 +0900 | [diff] [blame] | 209 | class StylusPointerController : public PointerController { |
| 210 | public: |
| 211 | /** A version of PointerController that controls one stylus pointer. */ |
| 212 | StylusPointerController(const sp<PointerControllerPolicyInterface>& policy, |
| 213 | const sp<Looper>& looper, SpriteController& spriteController, |
| 214 | bool enabled); |
| 215 | |
Prabir Pradhan | b0e2807 | 2023-11-08 21:09:34 +0000 | [diff] [blame] | 216 | ~StylusPointerController() override; |
| 217 | |
Byoungho Jung | 08daa25 | 2023-10-27 20:55:18 +0900 | [diff] [blame] | 218 | void setPresentation(Presentation) override { |
| 219 | LOG_ALWAYS_FATAL("Should not be called"); |
| 220 | } |
| 221 | void setSpots(const PointerCoords*, const uint32_t*, BitSet32, int32_t) override { |
| 222 | LOG_ALWAYS_FATAL("Should not be called"); |
| 223 | } |
| 224 | void clearSpots() override { |
| 225 | LOG_ALWAYS_FATAL("Should not be called"); |
| 226 | } |
| 227 | }; |
| 228 | |
Jeff Brown | b4ff35d | 2011-01-02 16:37:43 -0800 | [diff] [blame] | 229 | } // namespace android |
| 230 | |
| 231 | #endif // _UI_POINTER_CONTROLLER_H |