summaryrefslogtreecommitdiffstats
path: root/src/widgets/styles
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@nokia.com>2012-02-27 12:38:04 +0100
committerQt by Nokia <qt-info@nokia.com>2012-02-27 18:30:38 +0100
commit5a0eb4e768435b9ce32b074e620fca33be4df2fb (patch)
treebc98e9cfc155ffda26c1eee049e31d09e75710ac /src/widgets/styles
parent3d3b3de83adf62b3dc4c76e8bfd178e3a4969d07 (diff)
Fix icon loading in style sheets.
QIcon was moved to QtWidgets, while the parser is still in QtGui. Introduce a QCss::IconValue struct that contains the icon data and convert to QIcon in widgets. Change-Id: I09ac8a12a4b02bdca91ee2e8fcc28c86b5a001e7 Reviewed-by: Morten Johan Sørvig <morten.sorvig@nokia.com>
Diffstat (limited to 'src/widgets/styles')
-rw-r--r--src/widgets/styles/qstylesheetstyle.cpp19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/widgets/styles/qstylesheetstyle.cpp b/src/widgets/styles/qstylesheetstyle.cpp
index 30c6ed5e74..5c0ee254d4 100644
--- a/src/widgets/styles/qstylesheetstyle.cpp
+++ b/src/widgets/styles/qstylesheetstyle.cpp
@@ -860,6 +860,19 @@ static QStyle::StandardPixmap subControlIcon(int pe)
return QStyle::SP_CustomBase;
}
+static inline QIcon cssIconValueToIcon(const QCss::IconValue &iconValue)
+{
+ if (iconValue.entries.isEmpty())
+ return QIcon();
+ QIcon icon = QIcon(iconValue.entries.first().uri);
+ for (int i = 1; i < iconValue.entries.size(); ++i) {
+ const QCss::IconValue::IconEntry &entry = iconValue.entries.at(i);
+ icon.addPixmap(entry.uri, static_cast<QIcon::Mode>(entry.mode),
+ static_cast<QIcon::State>(entry.state));
+ }
+ return icon;
+}
+
QRenderRule::QRenderRule(const QVector<Declaration> &declarations, const QWidget *widget)
: features(0), hasFont(false), pal(0), b(0), bg(0), bd(0), ou(0), geo(0), p(0), img(0), clipset(0)
{
@@ -919,11 +932,11 @@ QRenderRule::QRenderRule(const QVector<Declaration> &declarations, const QWidget
if (v.extractPalette(&fg, &sfg, &sbg, &abg))
pal = new QStyleSheetPaletteData(fg, sfg, sbg, abg);
- QIcon icon;
alignment = Qt::AlignCenter;
QSize size;
- if (v.extractImage(&icon, &alignment, &size))
- img = new QStyleSheetImageData(icon, alignment, size);
+ QCss::IconValue iconValue;
+ if (v.extractImage(&iconValue, &alignment, &size))
+ img = new QStyleSheetImageData(cssIconValueToIcon(iconValue), alignment, size);
int adj = -255;
hasFont = v.extractFont(&font, &adj);