mirror of
https://github.com/qbittorrent/qBittorrent.git
synced 2024-11-27 11:49:01 +03:00
- Improved a lot the download list delegate
- Replaced Qt::TextColorRole by Qt::ForegroundRole because it is deprecated
This commit is contained in:
parent
0561206d91
commit
b0f3cdad5d
10 changed files with 32 additions and 53 deletions
|
@ -50,61 +50,35 @@ class DLListDelegate: public QItemDelegate {
|
||||||
~DLListDelegate(){}
|
~DLListDelegate(){}
|
||||||
|
|
||||||
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
|
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
|
||||||
QStyleOptionViewItem opt = option;
|
|
||||||
char tmp[MAX_CHAR_TMP];
|
char tmp[MAX_CHAR_TMP];
|
||||||
// set text color
|
QStyleOptionViewItemV3 opt = QItemDelegate::setOptions(index, option);
|
||||||
QVariant value = index.data(Qt::TextColorRole);
|
|
||||||
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{
|
|
||||||
// painter->fillRect(option.rect, option.palette.brush(cg, QPalette::Base));
|
|
||||||
// The following should work but is broken (retry with future versions of Qt)
|
|
||||||
QVariant value = index.data(Qt::BackgroundRole);
|
|
||||||
if (qVariantCanConvert<QBrush>(value)) {
|
|
||||||
QPointF oldBO = painter->brushOrigin();
|
|
||||||
painter->setBrushOrigin(option.rect.topLeft());
|
|
||||||
painter->fillRect(option.rect, qvariant_cast<QBrush>(value));
|
|
||||||
painter->setBrushOrigin(oldBO);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
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 ETA:
|
case ETA:
|
||||||
painter->drawText(option.rect, Qt::AlignCenter, misc::userFriendlyDuration(index.data().toLongLong()));
|
QItemDelegate::drawBackground(painter, opt, index);
|
||||||
|
QItemDelegate::drawDisplay(painter, opt, option.rect, misc::userFriendlyDuration(index.data().toLongLong()));
|
||||||
break;
|
break;
|
||||||
case UPSPEED:
|
case UPSPEED:
|
||||||
case DLSPEED:{
|
case DLSPEED:{
|
||||||
|
QItemDelegate::drawBackground(painter, opt, index);
|
||||||
float speed = index.data().toDouble();
|
float speed = index.data().toDouble();
|
||||||
snprintf(tmp, MAX_CHAR_TMP, "%.1f", speed/1024.);
|
snprintf(tmp, MAX_CHAR_TMP, "%.1f", speed/1024.);
|
||||||
painter->drawText(option.rect, Qt::AlignCenter, QString(tmp)+" "+tr("KiB/s"));
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, QString(tmp)+" "+tr("KiB/s"));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case RATIO:{
|
case RATIO:{
|
||||||
|
QItemDelegate::drawBackground(painter, opt, index);
|
||||||
float ratio = index.data().toDouble();
|
float ratio = index.data().toDouble();
|
||||||
snprintf(tmp, MAX_CHAR_TMP, "%.1f", ratio);
|
snprintf(tmp, MAX_CHAR_TMP, "%.1f", ratio);
|
||||||
painter->drawText(option.rect, Qt::AlignCenter, QString(tmp));
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, QString(tmp));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case PROGRESS:{
|
case PROGRESS:{
|
||||||
QStyleOptionProgressBarV2 newopt;
|
QStyleOptionProgressBarV2 newopt;
|
||||||
|
QPalette::ColorGroup cg = option.state & QStyle::State_Enabled ? QPalette::Normal : QPalette::Disabled;
|
||||||
float progress;
|
float progress;
|
||||||
progress = index.data().toDouble()*100.;
|
progress = index.data().toDouble()*100.;
|
||||||
snprintf(tmp, MAX_CHAR_TMP, "%.1f", progress);
|
snprintf(tmp, MAX_CHAR_TMP, "%.1f", progress);
|
||||||
|
@ -122,7 +96,7 @@ class DLListDelegate: public QItemDelegate {
|
||||||
opt.palette.setColor(QPalette::Text, QColor("grey"));
|
opt.palette.setColor(QPalette::Text, QColor("grey"));
|
||||||
painter->setPen(opt.palette.color(cg, QPalette::Text));
|
painter->setPen(opt.palette.color(cg, QPalette::Text));
|
||||||
}
|
}
|
||||||
painter->drawText(option.rect, Qt::AlignCenter, newopt.text);
|
painter->drawText(opt.rect, Qt::AlignCenter, newopt.text);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
@ -139,6 +113,11 @@ class DLListDelegate: public QItemDelegate {
|
||||||
return textRect.size();
|
return textRect.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QWidget* createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const {
|
||||||
|
// No editor here
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -51,7 +51,7 @@ class FinishedListDelegate: public QItemDelegate {
|
||||||
QStyleOptionViewItem opt = option;
|
QStyleOptionViewItem opt = option;
|
||||||
char tmp[MAX_CHAR_TMP];
|
char tmp[MAX_CHAR_TMP];
|
||||||
// set text color
|
// set text color
|
||||||
QVariant value = index.data(Qt::TextColorRole);
|
QVariant value = index.data(Qt::ForegroundRole);
|
||||||
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
||||||
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
||||||
}
|
}
|
||||||
|
|
|
@ -113,7 +113,7 @@ void FinishedTorrents::addFinishedSHA(QString hash){
|
||||||
// Set the color of a row in data model
|
// Set the color of a row in data model
|
||||||
void FinishedTorrents::setRowColor(int row, QString color){
|
void FinishedTorrents::setRowColor(int row, QString color){
|
||||||
for(int i=0; i<finishedListModel->columnCount(); ++i){
|
for(int i=0; i<finishedListModel->columnCount(); ++i){
|
||||||
finishedListModel->setData(finishedListModel->index(row, i), QVariant(QColor(color)), Qt::TextColorRole);
|
finishedListModel->setData(finishedListModel->index(row, i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -326,7 +326,7 @@ void FinishedTorrents::sortFinishedListFloat(int index, Qt::SortOrder sortOrder)
|
||||||
for(unsigned int col=0; col<nbColumns; ++col){
|
for(unsigned int col=0; col<nbColumns; ++col){
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col)));
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col)));
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
@ -349,7 +349,7 @@ void FinishedTorrents::sortFinishedListString(int index, Qt::SortOrder sortOrder
|
||||||
for(unsigned int col=0; col<nbColumns; ++col){
|
for(unsigned int col=0; col<nbColumns; ++col){
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col)));
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col)));
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
||||||
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
finishedListModel->setData(finishedListModel->index(nbRows_old+row, col), finishedListModel->data(finishedListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
|
|
@ -708,7 +708,7 @@ void GUI::sortDownloadListFloat(int index, Qt::SortOrder sortOrder){
|
||||||
for(unsigned int col=0; col<nbColumns; ++col){
|
for(unsigned int col=0; col<nbColumns; ++col){
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col)));
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col)));
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
@ -731,7 +731,7 @@ void GUI::sortDownloadListString(int index, Qt::SortOrder sortOrder){
|
||||||
for(unsigned int col=0; col<nbColumns; ++col){
|
for(unsigned int col=0; col<nbColumns; ++col){
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col)));
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col)));
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::DecorationRole), Qt::DecorationRole);
|
||||||
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
DLListModel->setData(DLListModel->index(nbRows_old+row, col), DLListModel->data(DLListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
@ -1604,7 +1604,7 @@ void GUI::checkConnectionStatus(){
|
||||||
void GUI::setRowColor(int row, QString color){
|
void GUI::setRowColor(int row, QString color){
|
||||||
unsigned int nbColumns = DLListModel->columnCount();
|
unsigned int nbColumns = DLListModel->columnCount();
|
||||||
for(unsigned int i=0; i<nbColumns; ++i){
|
for(unsigned int i=0; i<nbColumns; ++i){
|
||||||
DLListModel->setData(DLListModel->index(row, i), QVariant(QColor(color)), Qt::TextColorRole);
|
DLListModel->setData(DLListModel->index(row, i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -50,7 +50,7 @@ class PreviewListDelegate: public QAbstractItemDelegate {
|
||||||
char tmp[MAX_CHAR_TMP];
|
char tmp[MAX_CHAR_TMP];
|
||||||
float progress;
|
float progress;
|
||||||
// set text color
|
// set text color
|
||||||
QVariant value = index.data(Qt::TextColorRole);
|
QVariant value = index.data(Qt::ForegroundRole);
|
||||||
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
||||||
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,7 +60,7 @@ class PropListDelegate: public QItemDelegate {
|
||||||
QStyleOptionViewItem opt = option;
|
QStyleOptionViewItem opt = option;
|
||||||
char tmp[MAX_CHAR_TMP];
|
char tmp[MAX_CHAR_TMP];
|
||||||
// set text color
|
// set text color
|
||||||
QVariant value = index.data(Qt::TextColorRole);
|
QVariant value = index.data(Qt::ForegroundRole);
|
||||||
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
||||||
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
||||||
}
|
}
|
||||||
|
@ -249,7 +249,7 @@ class PropListDelegate: public QItemDelegate {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(int i=0; i<model->columnCount(); ++i){
|
for(int i=0; i<model->columnCount(); ++i){
|
||||||
model->setData(model->index(index.row(), i), QVariant(QColor(color)), Qt::TextColorRole);
|
model->setData(model->index(index.row(), i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ class SearchListDelegate: public QAbstractItemDelegate {
|
||||||
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
|
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
|
||||||
QStyleOptionViewItem opt = option;
|
QStyleOptionViewItem opt = option;
|
||||||
// set text color
|
// set text color
|
||||||
QVariant value = index.data(Qt::TextColorRole);
|
QVariant value = index.data(Qt::ForegroundRole);
|
||||||
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
if (value.isValid() && qvariant_cast<QColor>(value).isValid()){
|
||||||
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
opt.palette.setColor(QPalette::Text, qvariant_cast<QColor>(value));
|
||||||
}
|
}
|
||||||
|
|
|
@ -479,7 +479,7 @@ void properties::updateInfos(){
|
||||||
// Set the color of a row in data model
|
// Set the color of a row in data model
|
||||||
void properties::setRowColor(int row, QString color){
|
void properties::setRowColor(int row, QString color){
|
||||||
for(int i=0; i<PropListModel->columnCount(); ++i){
|
for(int i=0; i<PropListModel->columnCount(); ++i){
|
||||||
PropListModel->setData(PropListModel->index(row, i), QVariant(QColor(color)), Qt::TextColorRole);
|
PropListModel->setData(PropListModel->index(row, i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -119,7 +119,7 @@ SearchEngine::~SearchEngine(){
|
||||||
// Set the color of a row in data model
|
// Set the color of a row in data model
|
||||||
void SearchEngine::setRowColor(int row, QString color){
|
void SearchEngine::setRowColor(int row, QString color){
|
||||||
for(int i=0; i<SearchListModel->columnCount(); ++i){
|
for(int i=0; i<SearchListModel->columnCount(); ++i){
|
||||||
SearchListModel->setData(SearchListModel->index(row, i), QVariant(QColor(color)), Qt::TextColorRole);
|
SearchListModel->setData(SearchListModel->index(row, i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,7 +158,7 @@ void SearchEngine::sortSearchListInt(int index, Qt::SortOrder sortOrder){
|
||||||
int sourceRow = lines[row].first;
|
int sourceRow = lines[row].first;
|
||||||
for(int col=0; col<5; ++col){
|
for(int col=0; col<5; ++col){
|
||||||
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col)));
|
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col)));
|
||||||
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
@ -178,7 +178,7 @@ void SearchEngine::sortSearchListString(int index, Qt::SortOrder sortOrder){
|
||||||
int sourceRow = lines[row].first;
|
int sourceRow = lines[row].first;
|
||||||
for(int col=0; col<5; ++col){
|
for(int col=0; col<5; ++col){
|
||||||
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col)));
|
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col)));
|
||||||
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col), Qt::TextColorRole), Qt::TextColorRole);
|
SearchListModel->setData(SearchListModel->index(nbRows_old+row, col), SearchListModel->data(SearchListModel->index(sourceRow, col), Qt::ForegroundRole), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove old rows
|
// Remove old rows
|
||||||
|
|
|
@ -174,7 +174,7 @@ class torrentAdditionDialog : public QDialog, private Ui_addTorrentDialog{
|
||||||
// Set the color of a row in data model
|
// Set the color of a row in data model
|
||||||
void setRowColor(int row, QString color){
|
void setRowColor(int row, QString color){
|
||||||
for(int i=0; i<PropListModel->columnCount(); ++i){
|
for(int i=0; i<PropListModel->columnCount(); ++i){
|
||||||
PropListModel->setData(PropListModel->index(row, i), QVariant(QColor(color)), Qt::TextColorRole);
|
PropListModel->setData(PropListModel->index(row, i), QVariant(QColor(color)), Qt::ForegroundRole);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue