mirror of
https://github.com/qbittorrent/qBittorrent.git
synced 2024-11-22 09:16:05 +03:00
- Improved preview list delegate
- All delegates are now good :)
This commit is contained in:
parent
34d94cd2bb
commit
4922eb3dc5
3 changed files with 16 additions and 43 deletions
|
@ -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
1
TODO
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue