]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/tooltipmanager.cpp
* convert the size in bytes to larger unit
[dolphin.git] / src / tooltipmanager.cpp
index 2b41ac48f797a0361f79502950f8a1499cb52f03..687df218f0af5798b7ff75bbfe48c8a8e3b7bd54 100644 (file)
@@ -127,25 +127,35 @@ void ToolTipManager::showToolTip()
     // If the tooltip content exceeds the desktop borders, it must be assured that:
     // - the content is fully visible
     // - the content is not drawn inside m_itemRect
-    int x = m_itemRect.right();
-    int y = m_itemRect.bottom();
-    if (x + size.width() - 1 > desktop.right()) {
-        // Any room to the left of the item? 
-        if (m_itemRect.left() - size.width() > desktop.left())
-        {
-            x = m_itemRect.left() - size.width();
-        }
-        else
-        {
-            // Move left until we are back onscreen; we'll be horizontally
-            // overlapping m_itemRect, but hopefully the y value will keep us
-            // from drawing inside it.
-            x = desktop.right() - size.width();
-        }
+    const bool hasRoomToLeft  = (m_itemRect.left()   - size.width()  >= desktop.left());
+    const bool hasRoomToRight = (m_itemRect.right()  + size.width()  <= desktop.right());
+    const bool hasRoomAbove   = (m_itemRect.top()    - size.height() >= desktop.top());
+    const bool hasRoomBelow   = (m_itemRect.bottom() + size.height() <= desktop.bottom());    
+    if (!hasRoomAbove && !hasRoomBelow && !hasRoomToLeft && !hasRoomToRight) {
+        delete tip;
+        tip = 0;
+        return;
     }
-    if (y + size.height() - 1 > desktop.bottom()) {
-        y = m_itemRect.top() - size.height();
+
+    int x = 0;
+    if (hasRoomToLeft || hasRoomToRight) {
+        x = hasRoomToRight ? m_itemRect.right() : m_itemRect.left() - size.width();
+    } else {
+        // Put the tooltip at the far right of the screen. The item will be overlapped
+        // horizontally, but the y-coordinate will be adjusted afterwards so that no overlapping
+        // occurs vertically.
+        x = desktop.right() - size.width();
     }
+    
+    int y = 0;
+    if (hasRoomBelow || hasRoomAbove) {
+        y = hasRoomBelow ? m_itemRect.bottom() : m_itemRect.top() - size.height();
+    } else {
+        // Put the tooltip at the bottom of the screen. The x-coordinate has already
+        // been adjusted, so that no overlapping with m_itemRect occurs.
+        y = desktop.bottom() - size.height();
+    }
+
     KToolTip::showTip(QPoint(x, y), tip);
 }