- 
    Bug 
- 
    Resolution: Unresolved
- 
    P3: Somewhat important 
- 
    None
- 
    5.4.2, 5.5.0
- 
    None
- 
    Mac OS X Yosemite 10.10.4, Mac OS X Mavericks 10.9.5
If you implement the QTabletEvent of a QWidget and from there call update(), the frequency with which the TabletEvent gets called drops from roughly 135 times per second to 100 times per second. It is even worse for QOpenGLWidget, where the rate is dropped to 60 times per second. This is critical for applications, that use QTabletEvent to draw smooth lines, since points are reduced if the frequency goes down. This does not happen Linux.
This happens even though paintEvent of QWidget doesn't do anything.
I attached an example project to illustrate this issue. Run the program and start drawing on the widget with the pen (nothing will be drawn actually). On TabletRelease, the average frequency is shown through qDebug().
Uncomment the following line in the example
//        update();
to see the effect.
void TabletWidget::tabletEvent(QTabletEvent *event)
{
    if (event->type() == QTabletEvent::TabletPress)
if (event->type() == QTabletEvent::TabletMove)
{ ++count; // update(); }if (event->type() == QTabletEvent::TabletRelease)
{ ++count; qDebug() << "tablet: " << static_cast<qreal>(count) / static_cast<qreal>(timer.elapsed()) * 1000.0; }}
void TabletWidget::paintEvent(QPaintEvent *event)
{ // nothing }- relates to
- 
                    QTBUG-44964 Add API for regulating if a specific event type should be compressed. -         
- Closed
 
-