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
|
// Copyright (C) 2020 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qquickpalettecolorprovider_p.h"
#include <QtQuick/private/qquickabstractpaletteprovider_p.h>
QT_BEGIN_NAMESPACE
static bool notEq(const QPalette &p1, const QPalette &p2)
{
return p1.resolveMask() != p2.resolveMask() || p1 != p2;
}
static QPalette::ColorGroup adjustCg(QPalette::ColorGroup group)
{
return group == QPalette::All ? QPalette::Active : group;
}
class DefaultPalettesProvider : public QQuickAbstractPaletteProvider
{
public:
QPalette defaultPalette() const override { static QPalette p; return p; }
QPalette parentPalette() const override { return defaultPalette(); }
};
static std::default_delete<const QQuickAbstractPaletteProvider> defaultDeleter() { return {}; }
QQuickPaletteColorProvider::QQuickPaletteColorProvider()
: m_paletteProvider(ProviderPtr(new DefaultPalettesProvider, defaultDeleter()))
{
}
const QColor &QQuickPaletteColorProvider::color(QPalette::ColorGroup group, QPalette::ColorRole role) const
{
return m_resolvedPalette.color(adjustCg(group), role);
}
bool QQuickPaletteColorProvider::setColor(QPalette::ColorGroup g, QPalette::ColorRole r, QColor c)
{
m_requestedPalette.value() = m_resolvedPalette;
m_requestedPalette->setColor(g, r, c);
return inheritPalette(paletteProvider()->parentPalette());
}
bool QQuickPaletteColorProvider::resetColor(QPalette::ColorGroup group, QPalette::ColorRole role)
{
const auto &defaultPalette = paletteProvider()->defaultPalette() ;
const auto &defaultColor = defaultPalette.color(adjustCg(group), role);
return setColor(group, role, defaultColor);
}
bool QQuickPaletteColorProvider::fromQPalette(QPalette p)
{
m_requestedPalette.value() = std::move(p);
return inheritPalette(paletteProvider()->parentPalette());
}
QPalette QQuickPaletteColorProvider::palette() const
{
return m_resolvedPalette;
}
const QQuickAbstractPaletteProvider *QQuickPaletteColorProvider::paletteProvider() const
{
Q_ASSERT(m_paletteProvider);
return m_paletteProvider.get();
}
void QQuickPaletteColorProvider::setPaletteProvider(const QQuickAbstractPaletteProvider *paletteProvider)
{
static const auto emptyDeleter = [](auto &&){};
m_paletteProvider = ProviderPtr(paletteProvider, emptyDeleter);
}
bool QQuickPaletteColorProvider::copyColorGroup(QPalette::ColorGroup cg,
const QQuickPaletteColorProvider &p)
{
m_requestedPalette.value() = m_resolvedPalette;
auto srcPalette = p.palette();
for (int roleIndex = QPalette::WindowText; roleIndex < QPalette::NColorRoles; ++roleIndex) {
const auto cr = QPalette::ColorRole(roleIndex);
if (srcPalette.isBrushSet(cg, cr)) {
m_requestedPalette->setBrush(cg, cr, srcPalette.brush(cg, cr));
}
}
return inheritPalette(paletteProvider()->parentPalette());
}
bool QQuickPaletteColorProvider::reset()
{
return fromQPalette(QPalette());
}
bool QQuickPaletteColorProvider::inheritPalette(const QPalette &p)
{
auto inheritedMask = m_requestedPalette.isAllocated() ? m_requestedPalette->resolveMask() | p.resolveMask() : p.resolveMask();
QPalette parentPalette = m_requestedPalette.isAllocated() ? m_requestedPalette->resolve(p) : p;
parentPalette.setResolveMask(inheritedMask);
auto tmpResolvedPalette = parentPalette.resolve(paletteProvider()->defaultPalette());
tmpResolvedPalette.setResolveMask(tmpResolvedPalette.resolveMask() | inheritedMask);
bool changed = notEq(tmpResolvedPalette, m_resolvedPalette);
if (changed) {
std::swap(tmpResolvedPalette, m_resolvedPalette);
}
return changed;
}
QT_END_NAMESPACE
|