From: Peter Penz Date: Sat, 26 Jul 2008 14:10:26 +0000 (+0000) Subject: Tooltips are shown on wrong position in combination with a dual screen setup. Thanks... X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/commitdiff_plain/309f302c1db22e7025df63b12fc0bf94d29523b9 Tooltips are shown on wrong position in combination with a dual screen setup. Thanks to Lucas Murray for the patch! BUG: 167205 svn path=/trunk/KDE/kdebase/apps/; revision=838041 --- diff --git a/src/tooltipmanager.cpp b/src/tooltipmanager.cpp index cc3c9eb5a..8e4ad0eba 100644 --- a/src/tooltipmanager.cpp +++ b/src/tooltipmanager.cpp @@ -117,7 +117,7 @@ void ToolTipManager::showToolTip() option.decorationSize = QSize(32, 32); const QSize size = g_delegate->sizeHint(&option, tip); - const QRect desktop = QApplication::desktop()->availableGeometry(); + const QRect desktop = QApplication::desktop()->screenGeometry(m_itemRect.bottomRight()); // m_itemRect defines the area of the item, where the tooltip should be // shown. Per default the tooltip is shown in the bottom right corner. @@ -126,16 +126,11 @@ void ToolTipManager::showToolTip() // - the content is not drawn inside m_itemRect int x = m_itemRect.right(); int y = m_itemRect.bottom(); - const int xDiff = x + size.width() - desktop.width(); - const int yDiff = y + size.height() - desktop.height(); - - if ((xDiff > 0) && (yDiff > 0)) { + if (x + size.width() - 1 > desktop.right()) { x = m_itemRect.left() - size.width(); + } + if (y + size.height() - 1 > desktop.bottom()) { y = m_itemRect.top() - size.height(); - } else if (xDiff > 0) { - x -= xDiff; - } else if (yDiff > 0) { - y -= yDiff; } KToolTip::showTip(QPoint(x, y), tip);