File: oxygenshadowcache.h

package info (click to toggle)
oxygen 4%3A6.5.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 31,492 kB
  • sloc: cpp: 23,036; python: 39; sh: 14; makefile: 5
file content (170 lines) | stat: -rw-r--r-- 3,854 bytes parent folder | download | duplicates (2)
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
#ifndef oxygen_shadowCacheh
#define oxygen_shadowCacheh

//////////////////////////////////////////////////////////////////////////////
// oxygenshadowcache.h
// handles caching of TileSet objects to draw shadows
// -------------------
//
// SPDX-FileCopyrightText: 2009 Hugo Pereira Da Costa <hugo.pereira@free.fr>
//
// SPDX-License-Identifier: MIT
//////////////////////////////////////////////////////////////////////////////

#include "oxygen_export.h"
#include "oxygenhelper.h"

#include <QCache>
#include <QRadialGradient>
#include <cmath>

namespace Oxygen
{
class OXYGEN_EXPORT ShadowCache
{
public:
    //* constructor
    explicit ShadowCache(Helper &);

    //* read configuration
    void readConfig(void);

    //* animations duration
    void setAnimationsDuration(int);

    //* cache size
    void setEnabled(bool enabled)
    {
        _enabled = enabled;
        if (enabled) {
            _shadowCache.setMaxCost(1 << 6);
            _animatedShadowCache.setMaxCost(_maxIndex << 6);

        } else {
            _shadowCache.setMaxCost(1);
            _animatedShadowCache.setMaxCost(1);
        }
    }

    //* max animation index
    int maxIndex(void) const
    {
        return _maxIndex;
    }

    //* max animation index
    void setMaxIndex(int value)
    {
        _maxIndex = value;
        if (_enabled) {
            _shadowCache.setMaxCost(1 << 6);
            _animatedShadowCache.setMaxCost(_maxIndex << 6);
        }
    }

    //* invalidate caches
    void invalidateCaches(void)
    {
        _shadowCache.clear();
        _animatedShadowCache.clear();
    }

    //* true if shadow is enabled for a given group
    bool isEnabled(QPalette::ColorGroup) const;

    //* set shadow size manually
    void setShadowSize(QPalette::ColorGroup, int);

    //* shadow size
    int shadowSize(void) const;

    //* Key class to be used into QCache
    /*! class is entirely inline for optimization */
    class Key
    {
    public:
        //* explicit constructor
        explicit Key(void)
        {
        }

        //* constructor from int
        explicit Key(int hash)
            : index(hash >> 3)
            , active((hash >> 2) & 1)
            , isShade((hash >> 1) & 1)
            , hasBorder((hash)&1)
        {
        }

        //* hash function
        int hash(void) const
        {
            return (index << 3) | (active << 2) | (isShade << 1) | (hasBorder);
        }

        int index = 0;
        bool active = false;
        bool isShade = false;
        bool hasBorder = true;
    };

    //* get shadow matching client
    TileSet tileSet(const Key &);

    //* get shadow matching client and opacity
    TileSet tileSet(Key, qreal);

    //* simple pixmap
    QPixmap pixmap(const Key &key) const
    {
        return pixmap(key, key.active);
    }

    //* simple pixmap, with opacity
    QPixmap animatedPixmap(const Key &, qreal opacity);

private:
    Helper &helper(void) const
    {
        return _helper;
    }

    //* simple pixmap
    QPixmap pixmap(const Key &, bool active) const;

    //* draw gradient into rect
    /*! a separate method is used in order to properly account for corners */
    void renderGradient(QPainter &, const QRectF &, const QRadialGradient &, bool hasBorder = true) const;

    //* helper
    Helper &_helper;

    //* defines overlap between shadows and body
    enum { overlap = 4 };

    //* caching enable state
    bool _enabled;

    //* shadow size
    int _activeShadowSize;

    //* shadow size
    int _inactiveShadowSize;

    //* max index
    /*! it is used to set caches max cost, and calculate animation opacity */
    int _maxIndex;

    //* cache
    using TileSetCache = QCache<int, TileSet>;

    //* shadow cache
    TileSetCache _shadowCache;

    //* animated shadow cache
    TileSetCache _animatedShadowCache;
};
}

#endif