/usr/include/kdevplatform/util/activetooltip.h is in kdevelop-dev 4:5.2.1-1ubuntu4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 | /* This file is part of the KDE project
Copyright 2007 Vladimir Prus
Copyright 2009-2010 David Nolden
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef KDEVPLATFORM_ACTIVE_TOOLTIP_H
#define KDEVPLATFORM_ACTIVE_TOOLTIP_H
#include <QWidget>
#include "utilexport.h"
namespace KDevelop {
/** This class implements a tooltip that can contain arbitrary
widgets that the user can interact with.
Usage example:
KDevelop::ActiveToolTip* tooltip = new KDevelop::ActiveToolTip(mainWindow, QCursor::pos());
QVBoxLayout* layout = new QVBoxLayout(tooltip);
layout->addWidget(widget);
tooltip->resize( tooltip->sizeHint() );
ActiveToolTip::showToolTip(tooltip);
*/
class KDEVPLATFORMUTIL_EXPORT ActiveToolTip : public QWidget
{
Q_OBJECT
public:
///@param parent Parent widget. Must not be zero, else the widget won't be shown.
/// @param position Position where to show the tooltip, in global coordinates.
ActiveToolTip(QWidget *parent, const QPoint& position);
~ActiveToolTip() override;
///Shows and registers the given tool-tip.
///This should be used instead of just calling show() to make multiple different
///tooltips work together.
///The tooltip is owned by the manager after this is called. It will delete itself.
///@param tooltip The tooltip to show. It should not be visible yet, show() will eventually be called from here, with some delay.
/// The ownership stays with the caller.
///@param priority The priority of this tooltip. Lower is better. Multiple tooltips will be stacked down in the given order.
/// If it is zero, the given tooltip will be shown exclusively.
///@param uniqueId If this is nonempty, ActiveTooltip will make sure that only one tooltip with the given id is shown at a time
static void showToolTip(ActiveToolTip* tooltip, float priority = 100, const QString& uniqueId = QString());
bool eventFilter(QObject *object, QEvent *e) override;
bool insideThis(QObject* object);
void showEvent(QShowEvent*) override;
void resizeEvent(QResizeEvent*) override;
void paintEvent(QPaintEvent*) override;
void adjustRect();
///Clicks within the friend widget are allowed
void addFriendWidget(QWidget* widget);
///Set rect of handle (object) this tool tip is created for
///Moving mouse inside this rect, and between this and bounding geometry won't hide the tooltip
void setHandleRect(const QRect& rect);
///Set the area within which the mouse can be moved freely without hiding the tooltip
void setBoundingGeometry(const QRect& geometry);
Q_SIGNALS:
void resized();
// Emitted whenever mouse-activity is noticed within the tooltip area
void mouseIn();
// Emitted whenever mouse-activity is noticed outside of the tooltip area
void mouseOut();
private:
void closeEvent(QCloseEvent* ) override;
private:
const QScopedPointer<class ActiveToolTipPrivate> d;
};
}
#endif
|