QTouchEventSequence Class

class QTest::QTouchEventSequence

The QTouchEventSequence class is used to simulate a sequence of touch events. More...

Header: #include <QTouchEventSequence>
CMake: find_package(Qt6 COMPONENTS Test REQUIRED) target_link_libraries(mytarget PRIVATE Qt6::Test)
qmake: QT += testlib

Public Functions

virtual ~QTouchEventSequence()
virtual void commit(bool processEvents = true)
QTest::QTouchEventSequence & move(int touchId, const QPoint &pt, QWindow *window = nullptr)
QTest::QTouchEventSequence & press(int touchId, const QPoint &pt, QWindow *window = nullptr)
QTest::QTouchEventSequence & release(int touchId, const QPoint &pt, QWindow *window = nullptr)
virtual QTest::QTouchEventSequence & stationary(int touchId)

Detailed Description

To simulate a sequence of touch events on a specific device for a window or widget, call QTest::touchEvent to create a QTouchEventSequence instance. Add touch events to the sequence by calling press(), move(), release() and stationary(), and let the instance run out of scope to commit the sequence to the event system.

Example:

QTouchDevice *dev = QTest::createTouchDevice();
QWidget widget;

QTest::touchEvent(&widget, dev)
    .press(0, QPoint(10, 10));
QTest::touchEvent(&widget, dev)
    .stationary(0)
    .press(1, QPoint(40, 10));
QTest::touchEvent(&widget, dev)
    .move(0, QPoint(12, 12))
    .move(1, QPoint(45, 5));
QTest::touchEvent(&widget, dev)
    .release(0, QPoint(12, 12))
    .release(1, QPoint(45, 5));

Member Function Documentation

[virtual] QTouchEventSequence::~QTouchEventSequence()

Commits this sequence of touch events, unless autoCommit was disabled, and frees allocated resources.

[virtual] void QTouchEventSequence::commit(bool processEvents = true)

Commits this sequence of touch events to the event system. Normally there is no need to call this function because it is called from the destructor. However, if autoCommit is disabled, the events only get committed upon explicitly calling this function.

In special cases tests may want to disable the processing of the events. This can be achieved by setting processEvents to false. This results in merely queuing the events, the event loop will not be forced to process them.

[since 5.0] QTest::QTouchEventSequence &QTouchEventSequence::move(int touchId, const QPoint &pt, QWindow *window = nullptr)

Adds a move event for touchpoint touchId at position pt to this sequence and returns a reference to this QTouchEventSequence.

The position pt is interpreted as relative to window. If window is the null pointer, then pt is interpreted as relative to the window provided when instantiating this QTouchEventSequence.

Simulates that the user moved the finger identified by touchId.

This function was introduced in Qt 5.0.

[since 5.0] QTest::QTouchEventSequence &QTouchEventSequence::press(int touchId, const QPoint &pt, QWindow *window = nullptr)

Adds a press event for touchpoint touchId at position pt to this sequence and returns a reference to this QTouchEventSequence.

The position pt is interpreted as relative to window. If window is the null pointer, then pt is interpreted as relative to the window provided when instantiating this QTouchEventSequence.

Simulates that the user pressed the touch screen or pad with the finger identified by touchId.

This function was introduced in Qt 5.0.

[since 5.0] QTest::QTouchEventSequence &QTouchEventSequence::release(int touchId, const QPoint &pt, QWindow *window = nullptr)

Adds a release event for touchpoint touchId at position pt to this sequence and returns a reference to this QTouchEventSequence.

The position pt is interpreted as relative to window. If window is the null pointer, then pt is interpreted as relative to the window provided when instantiating this QTouchEventSequence.

Simulates that the user lifted the finger identified by touchId.

This function was introduced in Qt 5.0.

[virtual] QTest::QTouchEventSequence &QTouchEventSequence::stationary(int touchId)

Adds a stationary event for touchpoint touchId to this sequence and returns a reference to this QTouchEventSequence.

Simulates that the user did not move the finger identified by touchId.

© The Qt Company Ltd
Licensed under the GNU Free Documentation License, Version 1.3.
https://doc.qt.io/qt-6.0/qtest-qtoucheventsequence.html