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
4#ifndef QICONLOADER_P_H
5#define QICONLOADER_P_H
6
7#include <QtGui/private/qtguiglobal_p.h>
8
9#ifndef QT_NO_ICON
10//
11// W A R N I N G
12// -------------
13//
14// This file is not part of the Qt API. It exists purely as an
15// implementation detail. This header file may change from version to
16// version without notice, or even be removed.
17//
18// We mean it.
19//
20
21#include <QtGui/QIcon>
22#include <QtGui/QIconEngine>
23#include <QtCore/QList>
24#include <QtCore/QSharedPointer>
25#include <QtCore/QVarLengthArray>
26#include <private/qflatmap_p.h>
27#include <private/qiconengine_p.h>
28
29#include <vector>
30#include <memory>
31#include <optional>
32
33QT_BEGIN_NAMESPACE
34
35class QIconLoader;
36
38{
41 QIconDirInfo(const QString &_path = QString()) :
42 path(_path),
43 size(0),
44 maxSize(0),
45 minSize(0),
46 threshold(0),
47 scale(1),
51 short size;
52 short maxSize;
53 short minSize;
54 short threshold;
55 short scale;
58};
60
62{
63public:
64 virtual ~QIconLoaderEngineEntry() = default;
65 virtual QPixmap pixmap(const QSize &size,
66 QIcon::Mode mode,
67 QIcon::State state,
68 qreal scale) = 0;
71};
72
73struct ScalableEntry final : public QIconLoaderEngineEntry
74{
75 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
77};
78
79struct PixmapEntry final : public QIconLoaderEngineEntry
80{
81 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
83};
84
85using QThemeIconEntries = std::vector<std::unique_ptr<QIconLoaderEngineEntry>>;
86
92
94{
95public:
96 QThemeIconEngine(const QString& iconName = QString());
97 QIconEngine *clone() const override;
98 bool read(QDataStream &in) override;
99 bool write(QDataStream &out) const override;
100
101protected:
102 QIconEngine *proxiedEngine() const override;
103
104private:
105 QThemeIconEngine(const QThemeIconEngine &other);
106 QString key() const override;
107
108 QString m_iconName;
109 mutable uint m_themeKey = 0;
110
111 mutable std::unique_ptr<QIconEngine> m_proxiedEngine;
112};
113
115{
116public:
117 QIconLoaderEngine(const QString& iconName = QString());
119
120 void paint(QPainter *painter, const QRect &rect, QIcon::Mode mode, QIcon::State state) override;
121 QPixmap pixmap(const QSize &size, QIcon::Mode mode, QIcon::State state) override;
122 QSize actualSize(const QSize &size, QIcon::Mode mode, QIcon::State state) override;
123 QIconEngine *clone() const override;
124
125 QString iconName() override;
126 bool isNull() override;
127 QPixmap scaledPixmap(const QSize &size, QIcon::Mode mode, QIcon::State state, qreal scale) override;
128 QList<QSize> availableSizes(QIcon::Mode mode, QIcon::State state) override;
129
130 Q_GUI_EXPORT static QIconLoaderEngineEntry *entryForSize(const QThemeIconInfo &info, const QSize &size, int scale = 1);
131
132private:
134
135 QString key() const override;
136 bool hasIcon() const;
137
138 QString m_iconName;
139 QThemeIconInfo m_info;
140
141 friend class QIconLoader;
142};
143
145
147{
148public:
149 QIconTheme() = default;
150 QIconTheme(const QString &name);
151 QStringList parents() const;
152 QList<QIconDirInfo> keyList() const { return m_keyList; }
153 QStringList contentDirs() const { return m_contentDirs; }
154 bool isValid() const { return m_valid; }
155private:
156 QStringList m_contentDirs;
157 QList<QIconDirInfo> m_keyList;
158 QStringList m_parents;
159 bool m_valid = false;
160public:
162};
163
164class QIconEnginePlugin;
165
166class Q_GUI_EXPORT QIconLoader
167{
168public:
169 QIconLoader();
170 QThemeIconInfo loadIcon(const QString &iconName) const;
171 uint themeKey() const { return m_themeKey; }
172
173 QString themeName() const;
174 void setThemeName(const QString &themeName);
175 QString fallbackThemeName() const;
176 void setFallbackThemeName(const QString &themeName);
177 QIconTheme theme() { return themeList.value(themeName()); }
178 void setThemeSearchPath(const QStringList &searchPaths);
179 QStringList themeSearchPaths() const;
180 void setFallbackSearchPaths(const QStringList &searchPaths);
181 QStringList fallbackSearchPaths() const;
182 QIconDirInfo dirInfo(int dirindex);
183 static QIconLoader *instance();
184 void updateSystemTheme();
185 void invalidateKey();
186 void ensureInitialized();
187 bool hasUserTheme() const { return !m_userTheme.isEmpty(); }
188
189 QIconEngine *iconEngine(const QString &iconName) const;
190
191private:
192 enum DashRule { FallBack, NoFallBack };
193 QThemeIconInfo findIconHelper(const QString &themeName,
194 const QString &iconName,
195 QStringList &visited,
196 DashRule rule) const;
197 QThemeIconInfo lookupFallbackIcon(const QString &iconName) const;
198
199 uint m_themeKey;
200 mutable std::optional<QIconEnginePlugin *> m_factory;
201 bool m_supportsSvg;
202 bool m_initialized;
203
204 mutable QString m_userTheme;
205 mutable QString m_userFallbackTheme;
206 mutable QString m_systemTheme;
207 mutable QStringList m_iconDirs;
208 mutable QVarLengthFlatMap <QString, QIconTheme, 5> themeList;
209 mutable QStringList m_fallbackDirs;
210 mutable QString m_iconName;
211};
212
213QT_END_NAMESPACE
214
215#endif // QT_NO_ICON
216
217#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