QDesktopWidget::screenNumber(QPoint): fix handling of virtual desktops

On X11, QXcbVirtualDesktop represents an X11 screen while QScreen
represents an X11 output.  In the case that there are multiple screens
(possibly with multiple outputs), calculate the screen number correctly:
Find the screen index on the primary virtual desktop first to avoid
obtaining a screen index which doesn't belong to the primary virtual
desktop when screen geometry is similar.

Change-Id: I4cbb29b7aa7cd2125759ffbbbe3db4e934feaeae
Reviewed-by: Shawn Rutledge <shawn.rutledge@theqtcompany.com>
This commit is contained in:
Błażej Szczygieł 2016-01-01 13:56:04 +01:00
parent 1606a0e508
commit b50f0244c8

View File

@ -239,12 +239,25 @@ int QDesktopWidget::screenNumber(const QWidget *w) const
int QDesktopWidget::screenNumber(const QPoint &p) const int QDesktopWidget::screenNumber(const QPoint &p) const
{ {
QList<QScreen *> screens = QGuiApplication::screens(); const QList<QScreen *> screens = QGuiApplication::screens();
if (!screens.isEmpty()) {
for (int i = 0; i < screens.size(); ++i) const QList<QScreen *> primaryScreens = screens.first()->virtualSiblings();
if (screens.at(i)->geometry().contains(p)) // Find the screen index on the primary virtual desktop first
return i; foreach (QScreen *screen, primaryScreens) {
if (screen->geometry().contains(p))
return screens.indexOf(screen);
}
// If the screen index is not found on primary virtual desktop, find
// the screen index on all screens except the first which was for
// sure in the previous loop. Some other screens may repeat. Find
// only when there is more than one virtual desktop.
if (screens.count() != primaryScreens.count()) {
for (int i = 1; i < screens.size(); ++i) {
if (screens[i]->geometry().contains(p))
return i;
}
}
}
return primaryScreen(); //even better would be closest screen return primaryScreen(); //even better would be closest screen
} }