blob: 9cbfbc1b8bc96a6c01786b0bb7371bd2d5b4da08 (
plain)
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
95
96
97
98
|
/*
* SPDX-FileCopyrightText: 2011 Peter Penz <[email protected]>
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#ifndef KITEMLISTSMOOTHSCROLLER_H
#define KITEMLISTSMOOTHSCROLLER_H
#include "dolphin_export.h"
#include <QAbstractAnimation>
#include <QObject>
class QPropertyAnimation;
class QScrollBar;
class QWheelEvent;
/**
* @brief Helper class for KItemListContainer to have a smooth
* scrolling when adjusting the scrollbars.
*/
class DOLPHIN_EXPORT KItemListSmoothScroller : public QObject
{
Q_OBJECT
public:
explicit KItemListSmoothScroller(QScrollBar *scrollBar, QObject *parent = nullptr);
~KItemListSmoothScroller() override;
void setScrollBar(QScrollBar *scrollBar);
QScrollBar *scrollBar() const;
void setTargetObject(QObject *target);
QObject *targetObject() const;
void setPropertyName(const QByteArray &propertyName);
QByteArray propertyName() const;
/**
* Adjusts the position of the target by \p distance
* pixels. Is invoked in the context of QAbstractScrollArea::scrollContentsBy()
* where the scrollbars already have the new position but the content
* has not been scrolled yet.
*/
void scrollContentsBy(qreal distance);
/**
* Does a smooth-scrolling to the position \p position
* on the target and also adjusts the corresponding scrollbar
* to the new position.
*/
void scrollTo(qreal position);
/**
* Must be invoked before the scrollbar should get updated to have a new
* maximum. True is returned if the new maximum can be applied. If false
* is returned the maximum has already been reached and the value will
* be reached at the end of the animation.
*/
// TODO: This interface is tricky to understand. Try to make this more
// generic/readable if the corresponding code in KItemListContainer got
// stable.
bool requestScrollBarUpdate(int newMaximum);
/**
* Forwards wheel events to the scrollbar, ensuring smooth and proper scrolling
*/
void handleWheelEvent(QWheelEvent *event);
bool isAnimating();
Q_SIGNALS:
/**
* Emitted when the scrolling animation has finished
*/
void scrollingStopped();
protected:
bool eventFilter(QObject *obj, QEvent *event) override;
private Q_SLOTS:
void slotAnimationStateChanged(QAbstractAnimation::State newState, QAbstractAnimation::State oldState);
/**
* Calculates the duration of the smooth scrolling animation.
* If \p isSmoothScrollingEnabled is true, the duration will be calculated
* using the widget animation duration from the current style. Otherwise,
* the animation will be instantaneous.
*/
void updateAnimationDuration(bool isSmoothScrollingEnabled);
private:
bool m_scrollBarPressed;
bool m_smoothScrolling;
QScrollBar *m_scrollBar;
QPropertyAnimation *m_animation;
};
#endif
|