summaryrefslogtreecommitdiffstats
path: root/tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp
diff options
context:
space:
mode:
authorJan-Arve Sæther <jan-arve.saether@nokia.com>2011-02-09 15:07:24 +0100
committerThierry Bastian <thierry.bastian@nokia.com>2011-05-12 15:47:26 +0200
commit913ff732004c2c61c39bcdd82ff05ea1827f328b (patch)
tree7e0b50b23cabaf3643fd64806e8ab6577e7e86d5 /tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp
parent1ce725cb60358a31b1107ab5c892abb7ceca8453 (diff)
Avoid flicker when invalidate is propagated in a widget/layout hierarchy
* Do not call invalidate from activateRecursive(). This resulted in that a layout was invalidated as many times as there were items in the layout. * Several improvements. Do not call resize(size()) too often. Calling resize() from the widgetEvent() is not very nice though... * Remove commented out code * make sure layout is activated even if the widget does not change size * activate the layout if the resize is same as size() * In order to not break existing apps, make this an opt-in feature with QGraphicsLayout::setInstantInvalidatePropagation(true); Reviewed-by: Frederik Gladhorn Reviewed-by: John Tapsell
Diffstat (limited to 'tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp')
-rw-r--r--tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp88
1 files changed, 88 insertions, 0 deletions
diff --git a/tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp b/tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp
index 979f03df64..c57392640f 100644
--- a/tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp
+++ b/tests/auto/qgraphicslayout/tst_qgraphicslayout.cpp
@@ -62,6 +62,7 @@ private slots:
void compressLayoutRequest();
void automaticReparenting();
void verifyActivate();
+ void invalidate();
void constructors();
void alternativeLayoutItems();
void ownership();
@@ -218,6 +219,7 @@ class TestLayout : public QGraphicsLinearLayout
: QGraphicsLinearLayout(parent)
{
m_count = 0;
+ m_invalidateCount = 0;
}
void setGeometry(const QRectF &rect) {
@@ -226,7 +228,12 @@ class TestLayout : public QGraphicsLinearLayout
QGraphicsLinearLayout::setGeometry(rect);
}
+ void invalidate() {
+ ++m_invalidateCount;
+ QGraphicsLinearLayout::invalidate();
+ }
+ int m_invalidateCount;
int m_count;
};
@@ -251,6 +258,87 @@ void tst_QGraphicsLayout::verifyActivate()
}
+void tst_QGraphicsLayout::invalidate()
+{
+ QGraphicsLayout::setInstantInvalidatePropagation(true);
+ QGraphicsScene scene;
+ QGraphicsView view(&scene);
+
+ TestGraphicsWidget *a = new TestGraphicsWidget;
+ scene.addItem(a);
+ TestLayout *alay = new TestLayout(a);
+ TestGraphicsWidget *b = new TestGraphicsWidget;
+ alay->addItem(b);
+ TestLayout *blay = new TestLayout(b);
+ TestGraphicsWidget *e = new TestGraphicsWidget;
+ blay->addItem(e);
+
+
+ TestGraphicsWidget *c = new TestGraphicsWidget;
+ alay->addItem(c);
+ TestLayout *clay = new TestLayout(c);
+ TestGraphicsWidget *f = new TestGraphicsWidget;
+ clay->addItem(f);
+
+ TestGraphicsWidget *d = new TestGraphicsWidget;
+ alay->addItem(d);
+ TestLayout *dlay = new TestLayout(d);
+ TestGraphicsWidget *g = new TestGraphicsWidget;
+ dlay->addItem(g);
+
+ view.show();
+
+ alay->m_invalidateCount = 0;
+ blay->m_invalidateCount = 0;
+ clay->m_invalidateCount = 0;
+ dlay->m_invalidateCount = 0;
+
+ QCoreApplication::sendPostedEvents();
+ QCoreApplication::processEvents();
+
+ alay->activate();
+ QCOMPARE(alay->isActivated(), true);
+ QCOMPARE(blay->isActivated(), true);
+ QCOMPARE(clay->isActivated(), true);
+ qDebug() << "alay->m_invalidateCount:" << alay->m_invalidateCount;
+ qDebug() << "blay->m_invalidateCount:" << blay->m_invalidateCount;
+ qDebug() << "clay->m_invalidateCount:" << clay->m_invalidateCount;
+ qDebug() << "dlay->m_invalidateCount:" << dlay->m_invalidateCount;
+
+ a->clearEventCount();
+ b->clearEventCount();
+ c->clearEventCount();
+
+ blay->invalidate();
+ QCOMPARE(alay->isActivated(), false);
+ QCOMPARE(blay->isActivated(), false);
+ QCOMPARE(clay->isActivated(), true);
+ QCOMPARE(a->eventCount(QEvent::LayoutRequest), 0);
+ QCOMPARE(b->eventCount(QEvent::LayoutRequest), 0);
+ QCOMPARE(c->eventCount(QEvent::LayoutRequest), 0);
+
+
+ alay->m_invalidateCount = 0;
+ blay->m_invalidateCount = 0;
+ clay->m_invalidateCount = 0;
+ dlay->m_invalidateCount = 0;
+ clay->invalidate();
+ QCOMPARE(alay->isActivated(), false);
+ QCOMPARE(blay->isActivated(), false);
+ QCOMPARE(clay->isActivated(), false);
+
+ QCoreApplication::sendPostedEvents();
+ QCOMPARE(a->eventCount(QEvent::LayoutRequest), 1);
+ QCOMPARE(b->eventCount(QEvent::LayoutRequest), 0);
+ QCOMPARE(c->eventCount(QEvent::LayoutRequest), 0);
+ qDebug() << "alay->m_invalidateCount:" << alay->m_invalidateCount;
+ qDebug() << "blay->m_invalidateCount:" << blay->m_invalidateCount;
+ qDebug() << "clay->m_invalidateCount:" << clay->m_invalidateCount;
+ qDebug() << "dlay->m_invalidateCount:" << dlay->m_invalidateCount;
+
+ QGraphicsLayout::setInstantInvalidatePropagation(false);
+}
+
class Layout : public QGraphicsLayout
{
public: