- Improved preview list delegate

- All delegates are now good :)
This commit is contained in:
Christophe Dumez 2007-07-31 11:12:41 +00:00
parent 34d94cd2bb
commit 4922eb3dc5
3 changed files with 16 additions and 43 deletions

View file

@ -48,6 +48,7 @@
- COSMETIC: Redesigned torrent properties a little - COSMETIC: Redesigned torrent properties a little
- COSMETIC: Redesigned options a little - COSMETIC: Redesigned options a little
- COSMETIC: Display more logs messages concerning features - COSMETIC: Display more logs messages concerning features
- COSMETIC: Improved lists renderers
- COSMETIC: Use a different icon for torrents being checked and for connecting ones - COSMETIC: Use a different icon for torrents being checked and for connecting ones
* Mon May 07 2007 - Christophe Dumez <chris@qbittorrent.org> - v0.9.3 * Mon May 07 2007 - Christophe Dumez <chris@qbittorrent.org> - v0.9.3

1
TODO
View file

@ -46,7 +46,6 @@
* beta3 * beta3
- Translations update (IN PROGRESS) - Translations update (IN PROGRESS)
- Optimize and cleanup code - Optimize and cleanup code
- Improve delegates
- Check that there is no problem with right click menu in torrent content (all files filtered for example) - Check that there is no problem with right click menu in torrent content (all files filtered for example)
- Wait for some bug fixes in libtorrent : - Wait for some bug fixes in libtorrent :
- upload/download limit per torrent - upload/download limit per torrent

View file

@ -35,56 +35,28 @@
#define SIZE 1 #define SIZE 1
#define PROGRESS 2 #define PROGRESS 2
class PreviewListDelegate: public QAbstractItemDelegate { class PreviewListDelegate: public QItemDelegate {
Q_OBJECT Q_OBJECT
public: public:
PreviewListDelegate(QObject *parent=0) : QAbstractItemDelegate(parent){} PreviewListDelegate(QObject *parent=0) : QItemDelegate(parent){}
~PreviewListDelegate(){} ~PreviewListDelegate(){}
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{ void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
QItemDelegate delegate; QStyleOptionViewItemV3 opt = QItemDelegate::setOptions(index, option);
QStyleOptionViewItem opt = option;
QStyleOptionProgressBarV2 newopt;
char tmp[MAX_CHAR_TMP]; char tmp[MAX_CHAR_TMP];
float progress;
// set text color
QVariant value = index.data(Qt::ForegroundRole);
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
}
QPalette::ColorGroup cg = option.state & QStyle::State_Enabled
? QPalette::Normal : QPalette::Disabled;
if (option.state & QStyle::State_Selected){
painter->setPen(opt.palette.color(cg, QPalette::HighlightedText));
}else{
painter->setPen(opt.palette.color(cg, QPalette::Text));
}
// draw the background color
if(index.column() != PROGRESS){
if (option.showDecorationSelected && (option.state & QStyle::State_Selected)){
if (cg == QPalette::Normal && !(option.state & QStyle::State_Active)){
cg = QPalette::Inactive;
}
painter->fillRect(option.rect, option.palette.brush(cg, QPalette::Highlight));
}else{
value = index.data(Qt::BackgroundColorRole);
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
painter->fillRect(option.rect, qvariant_cast<QColor>(value));
}
}
}
switch(index.column()){ switch(index.column()){
case SIZE: case SIZE:
painter->drawText(option.rect, Qt::AlignCenter, misc::friendlyUnit(index.data().toLongLong())); QItemDelegate::drawBackground(painter, opt, index);
QItemDelegate::drawDisplay(painter, opt, option.rect, misc::friendlyUnit(index.data().toLongLong()));
break; break;
case NAME: case PROGRESS:{
painter->drawText(option.rect, Qt::AlignLeft, index.data().toString()); QPalette::ColorGroup cg = option.state & QStyle::State_Enabled ? QPalette::Normal : QPalette::Disabled;
break; float progress = index.data().toDouble()*100.;
case PROGRESS:
progress = index.data().toDouble()*100.;
snprintf(tmp, MAX_CHAR_TMP, "%.1f", progress); snprintf(tmp, MAX_CHAR_TMP, "%.1f", progress);
QStyleOptionProgressBarV2 newopt;
newopt.rect = opt.rect; newopt.rect = opt.rect;
newopt.text = QString(tmp)+"%"; newopt.text = QString(tmp)+"%";
newopt.progress = (int)progress; newopt.progress = (int)progress;
@ -101,14 +73,15 @@ class PreviewListDelegate: public QAbstractItemDelegate {
} }
painter->drawText(option.rect, Qt::AlignCenter, newopt.text); painter->drawText(option.rect, Qt::AlignCenter, newopt.text);
break; break;
}
default: default:
painter->drawText(option.rect, Qt::AlignCenter, index.data().toString()); QItemDelegate::paint(painter, option, index);
} }
} }
QSize sizeHint(const QStyleOptionViewItem & option, const QModelIndex & index) const{ QWidget* createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const {
QItemDelegate delegate; // No editor here
return delegate.sizeHint(option, index); return 0;
} }
}; };