delay a few things on startup, such as setting the visibility mode, which ensures...
[personal-kdebase.git] / apps / dolphin / src / selectiontoggle.h
blobe8f808562b15dde3b888082b6249d6acaa44dae3
1 /***************************************************************************
2 * Copyright (C) 2008 by Peter Penz <peter.penz@gmx.at> *
3 * *
4 * This program is free software; you can redistribute it and/or modify *
5 * it under the terms of the GNU General Public License as published by *
6 * the Free Software Foundation; either version 2 of the License, or *
7 * (at your option) any later version. *
8 * *
9 * This program is distributed in the hope that it will be useful, *
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 * GNU General Public License for more details. *
13 * *
14 * You should have received a copy of the GNU General Public License *
15 * along with this program; if not, write to the *
16 * Free Software Foundation, Inc., *
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
18 ***************************************************************************/
20 #ifndef SELECTIONTOGGLE_H
21 #define SELECTIONTOGGLE_H
23 #include <kurl.h>
25 #include <QAbstractButton>
26 #include <QPixmap>
28 class QTimeLine;
30 /**
31 * @brief Toggle button for changing the selection of an hovered item.
33 * The toggle button is visually invisible until it is displayed at least
34 * for one second.
36 * @see SelectionManager
38 class SelectionToggle : public QAbstractButton
40 Q_OBJECT
42 public:
43 explicit SelectionToggle(QWidget* parent);
44 virtual ~SelectionToggle();
45 virtual QSize sizeHint() const;
47 /**
48 * Resets the selection toggle so that it is hidden and stays
49 * visually invisible for at least one second after it is shown again.
51 void reset();
53 void setUrl(const KUrl& url);
54 KUrl url() const;
56 public slots:
57 virtual void setVisible(bool visible);
59 protected:
60 virtual bool eventFilter(QObject* obj, QEvent* event);
61 virtual void enterEvent(QEvent* event);
62 virtual void leaveEvent(QEvent* event);
63 virtual void paintEvent(QPaintEvent* event);
65 private slots:
66 /**
67 * Sets the alpha value for the fading animation and is
68 * connected with m_fadingTimeLine.
70 void setFadingValue(int value);
72 void setIconOverlay(bool checked);
73 void refreshIcon();
75 private:
76 void startFading();
77 void stopFading();
79 private:
80 bool m_isHovered;
81 int m_fadingValue;
82 QPixmap m_icon;
83 QTimeLine* m_fadingTimeLine;
84 KUrl m_url;
87 #endif