Browse Source

Merge pull request #13153 from jagannatharjun/styledelegate-content

Use QStyledItemDelegate for content views
adaptive-webui-19844
Mike Tzou 4 years ago committed by GitHub
parent
commit
0defdacbfd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 20
      src/gui/properties/proplistdelegate.cpp
  2. 4
      src/gui/properties/proplistdelegate.h

20
src/gui/properties/proplistdelegate.cpp

@ -64,7 +64,7 @@ namespace @@ -64,7 +64,7 @@ namespace
}
PropListDelegate::PropListDelegate(PropertiesWidget *properties)
: QItemDelegate(properties)
: QStyledItemDelegate(properties)
, m_properties(properties)
{
}
@ -73,13 +73,15 @@ void PropListDelegate::paint(QPainter *painter, const QStyleOptionViewItem &opti @@ -73,13 +73,15 @@ void PropListDelegate::paint(QPainter *painter, const QStyleOptionViewItem &opti
{
painter->save();
QStyleOptionViewItem opt = QItemDelegate::setOptions(index, option);
QItemDelegate::drawBackground(painter, opt, index);
const QStyle *style = option.widget ? option.widget->style() : QApplication::style();
QStyleOptionViewItem opt = option;
QStyledItemDelegate::initStyleOption(&opt, index);
switch (index.column()) {
case PCSIZE:
case REMAINING:
QItemDelegate::drawDisplay(painter, opt, option.rect, Utils::Misc::friendlyUnit(index.data().toLongLong()));
opt.text = Utils::Misc::friendlyUnit(index.data().toLongLong());
style->drawControl(QStyle::CE_ItemViewItem, &opt, painter, opt.widget);
break;
case PROGRESS: {
@ -130,26 +132,28 @@ void PropListDelegate::paint(QPainter *painter, const QStyleOptionViewItem &opti @@ -130,26 +132,28 @@ void PropListDelegate::paint(QPainter *painter, const QStyleOptionViewItem &opti
text = tr("Normal", "Normal (priority)");
break;
}
QItemDelegate::drawDisplay(painter, opt, option.rect, text);
opt.text = text;
style->drawControl(QStyle::CE_ItemViewItem, &opt, painter, opt.widget);
}
break;
case AVAILABILITY: {
const qreal availability = index.data().toReal();
if (availability < 0) {
QItemDelegate::drawDisplay(painter, opt, option.rect, tr("N/A"));
opt.text = tr("N/A");
}
else {
const QString value = (availability >= 1.0)
? QLatin1String("100")
: Utils::String::fromDouble(availability * 100, 1);
QItemDelegate::drawDisplay(painter, opt, option.rect, (value + C_THIN_SPACE + QLatin1Char('%')));
opt.text = (value + C_THIN_SPACE + QLatin1Char('%'));
}
style->drawControl(QStyle::CE_ItemViewItem, &opt, painter, opt.widget);
}
break;
default:
QItemDelegate::paint(painter, option, index);
QStyledItemDelegate::paint(painter, option, index);
break;
}

4
src/gui/properties/proplistdelegate.h

@ -29,7 +29,7 @@ @@ -29,7 +29,7 @@
#ifndef PROPLISTDELEGATE_H
#define PROPLISTDELEGATE_H
#include <QItemDelegate>
#include <QStyledItemDelegate>
class QAbstractItemModel;
class QModelIndex;
@ -49,7 +49,7 @@ enum PropColumn @@ -49,7 +49,7 @@ enum PropColumn
AVAILABILITY
};
class PropListDelegate final : public QItemDelegate
class PropListDelegate final : public QStyledItemDelegate
{
Q_OBJECT

Loading…
Cancel
Save