┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/tooltips/ktooltip.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2009-11-03 21:48:27 +0000
committerPeter Penz <[email protected]>2009-11-03 21:48:27 +0000
commit74c1d61aa3547c80e1c7ee05397c76ccd6260fa7 (patch)
treed3965c7f2b391a5def8018f48e5fcfe578af2dd6 /src/tooltips/ktooltip.cpp
parent48a9ecbf5bb5f3d4e2a548d5ce109ec1d459de6b (diff)
Since Qt 4.5 it is possible to have translucient windows. The tooltip approach having a delegate and custom drawing + animation code for transparent tooltips has now been replaced by a translucient window where any kind of (animated) widget can be embedded. Still a lot of finetuning has to be done, but maybe this code can be part of kdelibs in KDE 4.5 (systemsettings currently used the Dolphin tooltips code).
Additionally the tooltip uses now KMetaDataWidget instead of using KMetaInfo. This assures that no blocking of the application will occur even if there is a buggy Strigi analyzer that ignores the maximum size-setting and might block the retrieving of the meta data. BUG: 182941 BUG: 195878 svn path=/trunk/KDE/kdebase/apps/; revision=1044485
Diffstat (limited to 'src/tooltips/ktooltip.cpp')
-rw-r--r--src/tooltips/ktooltip.cpp202
1 files changed, 38 insertions, 164 deletions
diff --git a/src/tooltips/ktooltip.cpp b/src/tooltips/ktooltip.cpp
index 52a4d4a5f..c476fda1b 100644
--- a/src/tooltips/ktooltip.cpp
+++ b/src/tooltips/ktooltip.cpp
@@ -18,210 +18,84 @@
***************************************************************************/
#include "ktooltip.h"
-#include "ktooltip_p.h"
-#include "ktooltipdelegate.h"
-
-#include <QApplication>
-#include <QPainter>
+#include "ktooltipwindow_p.h"
+#include <QLabel>
+#include <QPoint>
#include <QWidget>
-#include <QToolTip>
-
-#ifdef Q_WS_X11
-# include <QX11Info>
-# include <X11/Xlib.h>
-# include <X11/extensions/shape.h>
-#endif
-
-// compile with XShape older than 1.0
-#ifndef ShapeInput
-const int ShapeInput = 2;
-#endif
-
-// ----------------------------------------------------------------------------
-
-
-class KTipLabel : public QWidget
+class KToolTipManager
{
public:
- KTipLabel();
- void showTip(const QPoint &pos, const KToolTipItem *item);
- void moveTip(const QPoint &pos);
+ ~KToolTipManager();
+
+ static KToolTipManager* instance();
+
+ void showTip(const QPoint& pos, QWidget* content);
void hideTip();
private:
- void paintEvent(QPaintEvent*);
- QSize sizeHint() const;
- KStyleOptionToolTip styleOption() const;
- KToolTipDelegate *delegate() const;
+ KToolTipManager();
-private:
- const KToolTipItem *m_currentItem;
+ KToolTipWindow* m_window;
+ static KToolTipManager *s_instance;
};
-KTipLabel::KTipLabel() : QWidget(0, Qt::ToolTip)
-{
-#ifdef Q_WS_X11
- if (QX11Info::isCompositingManagerRunning()) {
- setAttribute(Qt::WA_TranslucentBackground);
- }
-#endif
-}
-
-void KTipLabel::showTip(const QPoint &pos, const KToolTipItem *item)
-{
- m_currentItem = item;
- move(pos);
- show();
-}
-
-void KTipLabel::hideTip()
-{
- hide();
- m_currentItem = 0;
-}
-
-void KTipLabel::moveTip(const QPoint &pos)
-{
- move(pos);
-}
-
-void KTipLabel::paintEvent(QPaintEvent*)
-{
- if (!m_currentItem)
- return;
-
- KStyleOptionToolTip option = styleOption();
- option.rect = rect();
-
-#ifdef Q_WS_X11
- if (QX11Info::isCompositingManagerRunning())
- XShapeCombineRegion(x11Info().display(), winId(), ShapeInput, 0, 0,
- delegate()->inputShape(option).handle(), ShapeSet);
- else
-#endif
- setMask(delegate()->shapeMask(option));
-
- QPainter p(this);
- p.setFont(option.font);
- p.setPen(QPen(option.palette.brush(QPalette::Text), 0));
- delegate()->paint(&p, option, *m_currentItem);
-}
-
-QSize KTipLabel::sizeHint() const
-{
- if (!m_currentItem)
- return QSize();
-
- KStyleOptionToolTip option = styleOption();
- return delegate()->sizeHint(option, *m_currentItem);
-}
-
-KStyleOptionToolTip KTipLabel::styleOption() const
-{
- KStyleOptionToolTip option;
- KToolTipManager::instance()->initStyleOption(&option);
- return option;
-}
-
-KToolTipDelegate *KTipLabel::delegate() const
-{
- return KToolTipManager::instance()->delegate();
-}
-
-
-// ----------------------------------------------------------------------------
-
-
KToolTipManager *KToolTipManager::s_instance = 0;
-KToolTipManager::KToolTipManager()
- : m_label(new KTipLabel), m_currentItem(0), m_delegate(0)
+KToolTipManager::KToolTipManager() :
+ m_window(0)
{
}
KToolTipManager::~KToolTipManager()
{
- delete m_label;
- delete m_currentItem;
-}
-
-void KToolTipManager::showTip(const QPoint &pos, KToolTipItem *item)
-{
- hideTip();
- m_label->showTip(pos, item);
- m_currentItem = item;
- m_tooltipPos = pos;
-}
-
-void KToolTipManager::hideTip()
-{
- m_label->hideTip();
- delete m_currentItem;
- m_currentItem = 0;
+ delete m_window;
+ m_window = 0;
}
-void KToolTipManager::initStyleOption(KStyleOptionToolTip *option) const
+KToolTipManager* KToolTipManager::instance()
{
- option->direction = QApplication::layoutDirection();
- option->fontMetrics = QFontMetrics(QToolTip::font());
- option->activeCorner = KStyleOptionToolTip::TopLeftCorner;
- option->palette = QToolTip::palette();
- option->font = QToolTip::font();
- option->rect = QRect();
- option->state = QStyle::State_None;
- option->decorationSize = QSize(32, 32);
-}
+ if (s_instance == 0) {
+ s_instance = new KToolTipManager();
+ }
-void KToolTipManager::setDelegate(KToolTipDelegate *delegate)
-{
- m_delegate = delegate;
+ return s_instance;
}
-void KToolTipManager::update()
+void KToolTipManager::showTip(const QPoint& pos, QWidget* content)
{
- if (m_currentItem == 0)
- return;
- m_label->showTip(m_tooltipPos, m_currentItem);
+ hideTip();
+ Q_ASSERT(m_window == 0);
+ m_window = new KToolTipWindow(content);
+ m_window->move(pos);
+ m_window->show();
}
-KToolTipDelegate *KToolTipManager::delegate() const
+void KToolTipManager::hideTip()
{
- return m_delegate;
+ if (m_window != 0) {
+ m_window->hide();
+ delete m_window;
+ m_window = 0;
+ }
}
-
-// ----------------------------------------------------------------------------
-
-
namespace KToolTip
{
- void showText(const QPoint &pos, const QString &text, QWidget *widget, const QRect &rect)
- {
- Q_UNUSED(widget)
- Q_UNUSED(rect)
- KToolTipItem *item = new KToolTipItem(text);
- KToolTipManager::instance()->showTip(pos, item);
- }
-
- void showText(const QPoint &pos, const QString &text, QWidget *widget)
+ void showText(const QPoint& pos, const QString& text)
{
- showText(pos, text, widget, QRect());
+ QLabel* label = new QLabel(text);
+ showTip(pos, label);
}
- void showTip(const QPoint &pos, KToolTipItem *item)
+ void showTip(const QPoint& pos, QWidget* content)
{
- KToolTipManager::instance()->showTip(pos, item);
+ KToolTipManager::instance()->showTip(pos, content);
}
void hideTip()
{
KToolTipManager::instance()->hideTip();
}
-
- void setToolTipDelegate(KToolTipDelegate *delegate)
- {
- KToolTipManager::instance()->setDelegate(delegate);
- }
}