]> cloud.milkyroute.net Git - dolphin.git/blob - src/kitemviews/private/kitemlistviewanimation.h
Build with QT_NO_KEYWORDS
[dolphin.git] / src / kitemviews / private / kitemlistviewanimation.h
1 /*
2 * SPDX-FileCopyrightText: 2011 Peter Penz <peter.penz19@gmail.com>
3 *
4 * SPDX-License-Identifier: GPL-2.0-or-later
5 */
6
7 #ifndef KITEMLISTVIEWANIMATION_H
8 #define KITEMLISTVIEWANIMATION_H
9
10 #include "dolphin_export.h"
11
12 #include <QHash>
13 #include <QObject>
14 #include <QVariant>
15
16 class KItemListView;
17 class QGraphicsWidget;
18 class QPropertyAnimation;
19
20 /**
21 * @brief Internal helper class for KItemListView to animate the items.
22 *
23 * Supports item animations for moving, creating, deleting and resizing
24 * an item. Several applications can be applied to one item in parallel.
25 */
26 class DOLPHIN_EXPORT KItemListViewAnimation : public QObject
27 {
28 Q_OBJECT
29
30 public:
31 enum AnimationType {
32 MovingAnimation,
33 CreateAnimation,
34 DeleteAnimation,
35 ResizeAnimation
36 };
37
38 explicit KItemListViewAnimation(QObject* parent = nullptr);
39 ~KItemListViewAnimation() override;
40
41 void setScrollOrientation(Qt::Orientation orientation);
42 Qt::Orientation scrollOrientation() const;
43
44 void setScrollOffset(qreal scrollOffset);
45 qreal scrollOffset() const;
46
47 /**
48 * Starts the animation of the type \a type for the widget \a widget. If an animation
49 * of the type is already running, this animation will be stopped before starting
50 * the new animation.
51 */
52 void start(QGraphicsWidget* widget, AnimationType type, const QVariant& endValue = QVariant());
53
54 /**
55 * Stops the animation of the type \a type for the widget \a widget.
56 */
57 void stop(QGraphicsWidget* widget, AnimationType type);
58
59 /**
60 * Stops all animations that have been applied to the widget \a widget.
61 */
62 void stop(QGraphicsWidget* widget);
63
64 /**
65 * @return True if the animation of the type \a type has been started
66 * for the widget \a widget..
67 */
68 bool isStarted(QGraphicsWidget *widget, AnimationType type) const;
69
70 /**
71 * @return True if any animation has been started for the widget.
72 */
73 bool isStarted(QGraphicsWidget* widget) const;
74
75 Q_SIGNALS:
76 void finished(QGraphicsWidget* widget, KItemListViewAnimation::AnimationType type);
77
78 private Q_SLOTS:
79 void slotFinished();
80
81 private:
82 enum { AnimationTypeCount = 4 };
83
84 Qt::Orientation m_scrollOrientation;
85 qreal m_scrollOffset;
86 QHash<QGraphicsWidget*, QPropertyAnimation*> m_animation[AnimationTypeCount];
87 };
88
89 #endif
90
91