Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qiconloader_p.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3// Qt-Security score:significant reason:default
4
5#ifndef QICONLOADER_P_H
6#define QICONLOADER_P_H
7
8#include <QtGui/private/qtguiglobal_p.h>
9
10#ifndef QT_NO_ICON
11//
12// W A R N I N G
13// -------------
14//
15// This file is not part of the Qt API. It exists purely as an
16// implementation detail. This header file may change from version to
17// version without notice, or even be removed.
18//
19// We mean it.
20//
21
22#include <QtGui/QIcon>
23#include <QtGui/QIconEngine>
24#include <QtCore/QList>
25#include <QtCore/QSharedPointer>
26#include <QtCore/QVarLengthArray>
27#include <private/qflatmap_p.h>
28#include <private/qiconengine_p.h>
29
30#include <vector>
31#include <memory>
32#include <optional>
33
34QT_BEGIN_NAMESPACE
35
36class QIconLoader;
37
39{
42 QIconDirInfo(const QString &_path = QString()) :
43 path(_path),
44 size(0),
45 maxSize(0),
46 minSize(0),
47 threshold(0),
48 scale(1),
52 short size;
53 short maxSize;
54 short minSize;
55 short threshold;
56 short scale;
59};
61
63{
64public:
65 virtual ~QIconLoaderEngineEntry() = default;
66 virtual QPixmap pixmap(const QSize &size,
67 QIcon::Mode mode,
68 QIcon::State state,
69 qreal scale) = 0;
72};
73
74struct ScalableEntry final : public QIconLoaderEngineEntry
75{
76 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
78};
79
80struct PixmapEntry final : public QIconLoaderEngineEntry
81{
82 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
84};
85
86using QThemeIconEntries = std::vector<std::unique_ptr<QIconLoaderEngineEntry>>;
87
93
95{
96public:
97 QThemeIconEngine(const QString& iconName = QString());
98 QIconEngine *clone() const override;
99 bool read(QDataStream &in) override;
100 bool write(QDataStream &out) const override;
101
102protected:
103 QIconEngine *proxiedEngine() const override;
104
105private:
106 QThemeIconEngine(const QThemeIconEngine &other);
107 QString key() const override;
108
109 QString m_iconName;
110 mutable uint m_themeKey = 0;
111
112 mutable std::unique_ptr<QIconEngine> m_proxiedEngine;
113};
114
116{
117public:
118 QIconLoaderEngine(const QString& iconName = QString());
120
121 void paint(QPainter *painter, const QRect &rect, QIcon::Mode mode, QIcon::State state) override;
122 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state) override;
123 QSize actualSize(const QSize &size, QIcon::Mode mode, QIcon::State state) override;
124 QIconEngine *clone() const override;
125
126 QString iconName() override;
127 bool isNull() override;
128 QPixmap scaledPixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
129 QList<QSize> availableSizes(QIcon::Mode mode, QIcon::State state) override;
130
131 Q_GUI_EXPORT static QIconLoaderEngineEntry *entryForSize(const QThemeIconInfo &info, const QSize &size, int scale = 1);
132
133private:
135
136 QString key() const override;
137 bool hasIcon() const;
138
139 QString m_iconName;
140 QThemeIconInfo m_info;
141
142 friend class QIconLoader;
143};
144
146
148{
149public:
150 QIconTheme() = default;
151 QIconTheme(const QString &name);
152 QStringList parents() const;
153 QList<QIconDirInfo> keyList() const { return m_keyList; }
154 QStringList contentDirs() const { return m_contentDirs; }
155 bool isValid() const { return m_valid; }
156private:
157 QStringList m_contentDirs;
158 QList<QIconDirInfo> m_keyList;
159 QStringList m_parents;
160 bool m_valid = false;
161public:
163};
164
165class QIconEnginePlugin;
166
167class Q_GUI_EXPORT QIconLoader
168{
169public:
170 QIconLoader();
171 QThemeIconInfo loadIcon(const QString &iconName) const;
172 uint themeKey() const { return m_themeKey; }
173
174 QString themeName() const;
175 void setThemeName(const QString &themeName);
176 QString fallbackThemeName() const;
177 void setFallbackThemeName(const QString &themeName);
178 QIconTheme theme() { return themeList.value(themeName()); }
179 void setThemeSearchPath(const QStringList &searchPaths);
180 QStringList themeSearchPaths() const;
181 void setFallbackSearchPaths(const QStringList &searchPaths);
182 QStringList fallbackSearchPaths() const;
183 QIconDirInfo dirInfo(int dirindex);
184 static QIconLoader *instance();
185 void updateSystemTheme();
186 void invalidateKey();
187 void ensureInitialized();
188 bool hasUserTheme() const { return !m_userTheme.isEmpty(); }
189
190 QIconEngine *iconEngine(const QString &iconName) const;
191
192private:
193 enum DashRule { FallBack, NoFallBack };
194 QThemeIconInfo findIconHelper(const QString &themeName,
195 const QString &iconName,
196 QStringList &visited,
197 DashRule rule) const;
198 QThemeIconInfo lookupFallbackIcon(const QString &iconName) const;
199
200 uint m_themeKey;
201 mutable std::optional<QIconEnginePlugin *> m_factory;
202 bool m_supportsSvg;
203 bool m_initialized;
204
205 mutable QString m_userTheme;
206 mutable QString m_userFallbackTheme;
207 mutable QString m_systemTheme;
208 mutable QStringList m_iconDirs;
209 mutable QVarLengthFlatMap <QString, QIconTheme, 5> themeList;
210 mutable QStringList m_fallbackDirs;
211 mutable QString m_iconName;
212};
213
214QT_END_NAMESPACE
215
216#endif // QT_NO_ICON
217
218#endif // QICONLOADER_P_H
virtual QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale)=0
virtual ~QIconLoaderEngineEntry()=default
An icon engine based on icon entries collected by QIconLoader.
QSize actualSize(const QSize &size, QIcon::Mode mode, QIcon::State state) override
Returns the actual size of the icon the engine provides for the requested size, mode and state.
bool isNull() override
QPixmap scaledPixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override
QIconLoaderEngine(const QString &iconName=QString())
QString iconName() override
Returns the name used to create the engine, if available.
QList< QSize > availableSizes(QIcon::Mode mode, QIcon::State state) override
Returns sizes of all images that are contained in the engine for the specific mode and state.
void paint(QPainter *painter, const QRect &rect, QIcon::Mode mode, QIcon::State state) override
Uses the given painter to paint the icon with the required mode and state into the rectangle rect.
QIconEngine * clone() const override
Reimplement this method to return a clone of this icon engine.
QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state) override
Returns the icon as a pixmap with the required size, mode, and state.
QIconTheme(const QString &name)
QStringList parents() const
QStringList contentDirs() const
bool isValid() const
QIconTheme()=default
QList< QSharedPointer< QIconCacheGtkReader > > m_gtkCaches
QList< QIconDirInfo > keyList() const
A named-based icon engine for providing theme icons.
QThemeIconEngine(const QString &iconName=QString())
QString key() const override
\variable QIconEngine::ScaledPixmapArgument::size
bool write(QDataStream &out) const override
Writes the contents of this engine to the QDataStream out.
bool read(QDataStream &in) override
Reads icon engine contents from the QDataStream in.
QIconEngine * clone() const override
Reimplement this method to return a clone of this icon engine.
QIconEngine * proxiedEngine() const override
Q_DECLARE_TYPEINFO(QIconDirInfo, Q_RELOCATABLE_TYPE)
QPixmap basePixmap
QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override
Context context
QIconDirInfo(const QString &_path=QString())
QThemeIconEntries entries
QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override