diff options
Diffstat (limited to 'sources/pyside6/PySide6/pysideqtesttouch.h')
-rw-r--r-- | sources/pyside6/PySide6/pysideqtesttouch.h | 215 |
1 files changed, 215 insertions, 0 deletions
diff --git a/sources/pyside6/PySide6/pysideqtesttouch.h b/sources/pyside6/PySide6/pysideqtesttouch.h new file mode 100644 index 000000000..935ab59d6 --- /dev/null +++ b/sources/pyside6/PySide6/pysideqtesttouch.h @@ -0,0 +1,215 @@ +/**************************************************************************** +** +** Copyright (C) 2016 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of Qt for Python. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 3 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL3 included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 3 requirements +** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 2.0 or (at your option) the GNU General +** Public license version 3 or any later version approved by the KDE Free +** Qt Foundation. The licenses are as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-2.0.html and +** https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef PYSIDEQTESTTOUCH_H +#define PYSIDEQTESTTOUCH_H + +#include <QtTest/qttestglobal.h> +#include <QtTest/qtestassert.h> +#include <QtTest/qtestsystem.h> +#include <QtTest/qtestspontaneevent.h> +#include <QtTest/qtesttouch.h> + +#include <QtCore/qmap.h> +#include <QtGui/qevent.h> +#include <QtGui/qwindow.h> +#ifdef QT_WIDGETS_LIB +#include <QtWidgets/qwidget.h> +#endif + +QT_BEGIN_NAMESPACE + +namespace QTest +{ + + class PySideQTouchEventSequence + { + public: + ~PySideQTouchEventSequence() + { + if (commitWhenDestroyed) + commit(); + } + PySideQTouchEventSequence *press(int touchId, const QPoint &pt, QWindow *window = nullptr) + { + auto it = m_points.find(touchId); + if (it == m_points.end()) { + QEventPoint point(touchId, QEventPoint::Pressed, pt, mapToScreen(window, pt)); + m_points.insert(touchId, point); + } + return this; + } + PySideQTouchEventSequence *move(int touchId, const QPoint &pt, QWindow *window = nullptr) + { + QEventPoint point(touchId, QEventPoint::Updated, pt, mapToScreen(window, pt)); + m_points[touchId] = point; + return this; + } + PySideQTouchEventSequence *release(int touchId, const QPoint &pt, QWindow *window = nullptr) + { + auto it = m_points.find(touchId); + if (it == m_points.end()) { + QEventPoint point(touchId, QEventPoint::Released, pt, mapToScreen(window, pt)); + m_points.insert(touchId, point); + } + return this; + } + PySideQTouchEventSequence *stationary(int touchId) + { + auto it = m_points.find(touchId); + if (it == m_points.end()) { + auto previous_it = m_previousPoints.find(touchId); + const QEventPoint point = previous_it != m_previousPoints.end() + ? previous_it.value() + : QEventPoint(touchId, QEventPoint::Stationary, QPointF(), QPointF()); + m_points.insert(touchId, point); + } + return this; + } + +#ifdef QT_WIDGETS_LIB + PySideQTouchEventSequence *press(int touchId, const QPoint &pt, QWidget *widget = nullptr) + { + auto it = m_points.find(touchId); + if (it == m_points.end()) { + QEventPoint point(touchId, QEventPoint::Pressed, pt, mapToScreen(widget, pt)); + m_points.insert(touchId, point); + } + return this; + } + + PySideQTouchEventSequence *move(int touchId, const QPoint &pt, QWidget *widget = nullptr) + { + QEventPoint point(touchId, QEventPoint::Updated, pt, mapToScreen(widget, pt)); + m_points[touchId] = point; + return this; + } + + PySideQTouchEventSequence *release(int touchId, const QPoint &pt, QWidget *widget = nullptr) + { + auto it = m_points.find(touchId); + if (it == m_points.end()) { + QEventPoint point(touchId, QEventPoint::Released, pt, mapToScreen(widget, pt)); + m_points.insert(touchId, point); + } + return this; + } +#endif + + void commit(bool processEvents = true) + { + if (!m_points.isEmpty()) { + if (targetWindow) { + qt_handleTouchEvent(targetWindow, device, m_points.values()); + } +#ifdef QT_WIDGETS_LIB + else if (targetWidget) { + qt_handleTouchEvent(targetWidget->windowHandle(), device, m_points.values()); + } +#endif + } + if (processEvents) + QCoreApplication::processEvents(); + m_previousPoints = m_points; + m_points.clear(); + } + +private: +#ifdef QT_WIDGETS_LIB + PySideQTouchEventSequence(QWidget *widget, QPointingDevice *aDevice, bool autoCommit) + : targetWidget(widget), device(aDevice), commitWhenDestroyed(autoCommit) + { + } +#endif + PySideQTouchEventSequence(QWindow *window, QPointingDevice *aDevice, bool autoCommit) + : targetWindow(window), device(aDevice), commitWhenDestroyed(autoCommit) + { + } + +#ifdef QT_WIDGETS_LIB + QPointF mapToScreen(const QWidget *widget, const QPointF &pt) + { + if (widget) + return widget->mapToGlobal(pt); + return targetWidget ? targetWidget->mapToGlobal(pt) : pt; + } +#endif + QPointF mapToScreen(const QWindow *window, const QPointF &pt) + { + if(window) + return window->mapToGlobal(pt); + return targetWindow ? targetWindow->mapToGlobal(pt) : pt; + } + + QMap<int, QEventPoint> m_previousPoints; + QMap<int, QEventPoint> m_points; +#ifdef QT_WIDGETS_LIB + QWidget *targetWidget = nullptr; +#endif + QWindow *targetWindow = nullptr; + QPointingDevice *device = nullptr; + bool commitWhenDestroyed = false; +#ifdef QT_WIDGETS_LIB + friend PySideQTouchEventSequence *generateTouchEvent(QWidget *, QPointingDevice *, bool); +#endif + friend PySideQTouchEventSequence *generateTouchEvent(QWindow *, QPointingDevice *, bool); + }; + +#ifdef QT_WIDGETS_LIB + inline + PySideQTouchEventSequence *generateTouchEvent(QWidget *widget, + QPointingDevice *device, + bool autoCommit = true) + { + return new PySideQTouchEventSequence(widget, device, autoCommit); + } +#endif + inline + PySideQTouchEventSequence *generateTouchEvent(QWindow *window, + QPointingDevice *device, + bool autoCommit = true) + { + return new PySideQTouchEventSequence(window, device, autoCommit); + } + +} + +QT_END_NAMESPACE + +#endif // PYSIDEQTESTTOUCH_H |