From abb5f0d3768a817b7e30639107210e64b8dbc138 Mon Sep 17 00:00:00 2001 From: Friedemann Kleint Date: Thu, 15 Oct 2020 13:30:24 +0200 Subject: Windows QPA/wintab: Register tablet devices Inherit a class from QPointingDevice with a shared pointer to the data for a physical cursor. As a drive-by, keep the event time in QWindowsTabletSupport for leave proximity events that do not have a time associated. The previous code was relying on QWindowSystemInterface for this, which may be at odds with the tablet's time. Refactor and streamline the code a bit. Task-number: QTBUG-46412 Change-Id: I2f4fab25a49a9d9f1befbd7fc040e8eb23be71ff Reviewed-by: Shawn Rutledge --- .../platforms/windows/qwindowstabletsupport.h | 47 +++++++++++++++++++--- 1 file changed, 42 insertions(+), 5 deletions(-) (limited to 'src/plugins/platforms/windows/qwindowstabletsupport.h') diff --git a/src/plugins/platforms/windows/qwindowstabletsupport.h b/src/plugins/platforms/windows/qwindowstabletsupport.h index 229677dae4..dca2800215 100644 --- a/src/plugins/platforms/windows/qwindowstabletsupport.h +++ b/src/plugins/platforms/windows/qwindowstabletsupport.h @@ -47,6 +47,7 @@ #include #include #include +#include #include @@ -83,6 +84,8 @@ struct QWindowsWinTab32DLL PtrWTQueueSizeSet wTQueueSizeSet = nullptr; }; +// Data associated with a physical cursor (system ID) which is shared between +// devices of varying device type/pointer type. struct QWindowsTabletDeviceData { QPointF scaleCoordinates(int coordX, int coordY,const QRect &targetArea) const; @@ -99,13 +102,31 @@ struct QWindowsTabletDeviceData int maxY = 0; int minZ = 0; int maxZ = 0; - qint64 uniqueId = 0; - QInputDevice::DeviceType currentDevice = QInputDevice::DeviceType::Unknown; - QPointingDevice::PointerType currentPointerType = QPointingDevice::PointerType::Unknown; + qint64 systemId = 0; bool zCapability = false; + bool tiltCapability = false; QHash buttonsMap; }; +class QWinTabPointingDevice : public QPointingDevice +{ +public: + using DeviceDataPtr = QSharedPointer; + + explicit QWinTabPointingDevice(const DeviceDataPtr &data, + const QString &name, qint64 systemId, + QInputDevice::DeviceType devType, + PointerType pType, Capabilities caps, int maxPoints, + int buttonCount, const QString &seatName = QString(), + QPointingDeviceUniqueId uniqueId = QPointingDeviceUniqueId(), + QObject *parent = nullptr); + + const DeviceDataPtr &deviceData() const { return m_deviceData; } + +private: + DeviceDataPtr m_deviceData; +}; + #ifndef QT_NO_DEBUG_STREAM QDebug operator<<(QDebug d, const QWindowsTabletDeviceData &t); #endif @@ -117,6 +138,9 @@ class QWindowsTabletSupport explicit QWindowsTabletSupport(HWND window, HCTX context); public: + using DevicePtr = QSharedPointer; + using Devices = QList; + enum Mode { PenMode, @@ -146,16 +170,29 @@ public: private: unsigned options() const; QWindowsTabletDeviceData tabletInit(qint64 uniqueId, UINT cursorType) const; + void updateData(QWindowsTabletDeviceData *data) const; + void updateButtons(unsigned currentCursor, QWindowsTabletDeviceData *data) const; + void enterProximity(ulong time = 0, QWindow *window = nullptr); + void leaveProximity(ulong time = 0, QWindow *window = nullptr); + void enterLeaveProximity(bool enter, ulong time, QWindow *window = nullptr); + DevicePtr findDevice(qint64 systemId) const; + DevicePtr findDevice(qint64 systemId, + QInputDevice::DeviceType deviceType, + QPointingDevice::PointerType pointerType) const; + DevicePtr clonePhysicalDevice(qint64 systemId, + QInputDevice::DeviceType deviceType, + QPointingDevice::PointerType pointerType); static QWindowsWinTab32DLL m_winTab32DLL; const HWND m_window; const HCTX m_context; static int m_absoluteRange; bool m_tiltSupport = false; - QList m_devices; - int m_currentDevice = -1; + Devices m_devices; + DevicePtr m_currentDevice; Mode m_mode = PenMode; State m_state = PenUp; + ulong m_eventTime = 0; }; QT_END_NAMESPACE -- cgit v1.2.3