Close popup widgets when wheel events are received

Task-number: QTBUG-40656
Change-Id: I134b07705744c23af9718dee486ab5e9ad4352cf
Reviewed-by: Jørgen Lind <jorgen.lind@digia.com>
This commit is contained in:
Friedemann Kleint 2014-08-26 15:46:48 +02:00
parent 0475822d01
commit 92c7cb8155
2 changed files with 37 additions and 0 deletions

View File

@ -3326,6 +3326,15 @@ bool QApplication::notify(QObject *receiver, QEvent *e)
{ {
QWidget* w = static_cast<QWidget *>(receiver); QWidget* w = static_cast<QWidget *>(receiver);
QWheelEvent* wheel = static_cast<QWheelEvent*>(e); QWheelEvent* wheel = static_cast<QWheelEvent*>(e);
// QTBUG-40656, combo and other popups should close when the main window gets a wheel event.
while (QWidget *popup = QApplication::activePopupWidget()) {
if (w->window() != popup)
popup->close();
else
break;
}
QPoint relpos = wheel->pos(); QPoint relpos = wheel->pos();
bool eventAccepted = wheel->isAccepted(); bool eventAccepted = wheel->isAccepted();

View File

@ -53,6 +53,7 @@
#include <qdialog.h> #include <qdialog.h>
#include <qevent.h> #include <qevent.h>
#include <qlineedit.h> #include <qlineedit.h>
#include <qlabel.h>
#include <qlistview.h> #include <qlistview.h>
#include <qheaderview.h> #include <qheaderview.h>
#include <qlistwidget.h> #include <qlistwidget.h>
@ -131,6 +132,7 @@ private slots:
void pixmapIcon(); void pixmapIcon();
void mouseWheel_data(); void mouseWheel_data();
void mouseWheel(); void mouseWheel();
void wheelClosingPopup();
void layoutDirection(); void layoutDirection();
void itemListPosition(); void itemListPosition();
void separatorItem_data(); void separatorItem_data();
@ -2041,6 +2043,32 @@ void tst_QComboBox::mouseWheel()
} }
} }
void tst_QComboBox::wheelClosingPopup()
{
// QTBUG-40656, combo and other popups should close when the main window gets a wheel event.
QScrollArea scrollArea;
scrollArea.move(300, 300);
QWidget *widget = new QWidget;
scrollArea.setWidget(widget);
QVBoxLayout *layout = new QVBoxLayout(widget);
layout->setSizeConstraint(QLayout::SetMinAndMaxSize);
layout->addSpacing(100);
QComboBox *comboBox = new QComboBox;
comboBox->addItems(QStringList() << QStringLiteral("Won") << QStringLiteral("Too")
<< QStringLiteral("3") << QStringLiteral("fore"));
layout->addWidget(comboBox);
layout->addSpacing(100);
const QPoint sizeP(scrollArea.width(), scrollArea.height());
scrollArea.move(QGuiApplication::primaryScreen()->availableGeometry().center() - sizeP / 2);
scrollArea.show();
QVERIFY(QTest::qWaitForWindowExposed(&scrollArea));
comboBox->showPopup();
QTRY_VERIFY(comboBox->view() && comboBox->view()->isVisible());
QWheelEvent event(QPointF(10, 10), WHEEL_DELTA, Qt::NoButton, Qt::NoModifier);
QVERIFY(QCoreApplication::sendEvent(scrollArea.windowHandle(), &event));
QTRY_VERIFY(!comboBox->view()->isVisible());
}
void tst_QComboBox::layoutDirection() void tst_QComboBox::layoutDirection()
{ {
QComboBox box; QComboBox box;