┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/tooltipmanager.cpp
diff options
context:
space:
mode:
authorSimon Paul St James <[email protected]>2008-08-18 20:33:21 +0000
committerSimon Paul St James <[email protected]>2008-08-18 20:33:21 +0000
commitcfe28380063eedb2f9b418215acfe369ea9da5d5 (patch)
tree903b05f6dba48fa02b6d08121ee84272669750ce /src/tooltipmanager.cpp
parent26df5e0041b0584d2fd8df8dfc520abee86f1e99 (diff)
Very rough initial attempt at previews-in-tooltip for Konqueror and Dolphin. Still needs extensive work in positioning, scaling/ padding items to fit, and timing things so that the previews are more likely to have been generated when the tooltip is positioned and displayed.
CCBUG:161848 svn path=/trunk/KDE/kdebase/apps/; revision=848984
Diffstat (limited to 'src/tooltipmanager.cpp')
-rw-r--r--src/tooltipmanager.cpp23
1 files changed, 18 insertions, 5 deletions
diff --git a/src/tooltipmanager.cpp b/src/tooltipmanager.cpp
index 8e4ad0eba..2b41ac48f 100644
--- a/src/tooltipmanager.cpp
+++ b/src/tooltipmanager.cpp
@@ -19,10 +19,10 @@
#include "tooltipmanager.h"
+#include "dolphintooltip.h"
#include "dolphinmodel.h"
#include "dolphinsortfilterproxymodel.h"
-#include <kformattedballoontipdelegate.h>
#include <kicon.h>
#include <ktooltip.h>
@@ -31,7 +31,7 @@
#include <QTimer>
#include <QToolTip>
-K_GLOBAL_STATIC(KFormattedBalloonTipDelegate, g_delegate)
+K_GLOBAL_STATIC(DolphinBalloonTooltipDelegate, g_delegate)
ToolTipManager::ToolTipManager(QAbstractItemView* parent,
DolphinSortFilterProxyModel* model) :
@@ -103,7 +103,10 @@ void ToolTipManager::hideToolTip()
void ToolTipManager::showToolTip()
{
- KToolTipItem* tip = new KToolTipItem(KIcon(m_item.iconName()), m_item.getToolTipText());
+ // TODO - create tip during requestTip(...) - this makes it more likely that the previews
+ // job will have completed by the time the tooltip is shown, resulting in less flicker.
+ // The memory management will be more intricate, though.
+ DolphinToolTipItem *tip = new DolphinToolTipItem(m_item);
KStyleOptionToolTip option;
// TODO: get option content from KToolTip or add KToolTip::sizeHint() method
@@ -127,12 +130,22 @@ void ToolTipManager::showToolTip()
int x = m_itemRect.right();
int y = m_itemRect.bottom();
if (x + size.width() - 1 > desktop.right()) {
- x = m_itemRect.left() - size.width();
+ // 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();
+ }
}
if (y + size.height() - 1 > desktop.bottom()) {
y = m_itemRect.top() - size.height();
}
-
KToolTip::showTip(QPoint(x, y), tip);
}