Browse Source

- Fixed file priorities

adaptive-webui-19844
Christophe Dumez 15 years ago
parent
commit
f9da85ecfe
  1. 16
      src/PropListDelegate.h
  2. 32
      src/propertieswidget.cpp
  3. 1
      src/propertieswidget.h

16
src/PropListDelegate.h

@ -50,7 +50,7 @@ class PropListDelegate: public QItemDelegate {
Q_OBJECT Q_OBJECT
signals: signals:
void filteredFilesChanged(); void filteredFilesChanged() const;
public: public:
PropListDelegate(QObject *parent=0) : QItemDelegate(parent){ PropListDelegate(QObject *parent=0) : QItemDelegate(parent){
@ -60,7 +60,6 @@ class PropListDelegate: public QItemDelegate {
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{ void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
QStyleOptionViewItemV2 opt = QItemDelegate::setOptions(index, option); QStyleOptionViewItemV2 opt = QItemDelegate::setOptions(index, option);
QPalette::ColorGroup cg = option.state & QStyle::State_Enabled ? QPalette::Normal : QPalette::Disabled;
switch(index.column()){ switch(index.column()){
case SIZE: case SIZE:
QItemDelegate::drawBackground(painter, opt, index); QItemDelegate::drawBackground(painter, opt, index);
@ -100,11 +99,11 @@ class PropListDelegate: public QItemDelegate {
newopt.currentText = tr("Normal", "Normal (priority)"); newopt.currentText = tr("Normal", "Normal (priority)");
} }
newopt.state |= QStyle::State_Enabled; newopt.state |= QStyle::State_Enabled;
QApplication::style()->drawComplexControl(QStyle::CC_ComboBox, &newopt, newopt.subControls = QStyle::SC_All;
painter); //painter->translate(QPoint(opt.rect.x()*-1,opt.rect.y()*-1));
opt.palette.setColor(QPalette::Text, QColor("black")); //QApplication::style()->drawComplexControl(QStyle::CC_ComboBox, &newopt, painter);
painter->setPen(opt.palette.color(cg, QPalette::Text)); //painter->translate(QPoint(opt.rect.x(),opt.rect.y()));
painter->drawText(option.rect, Qt::AlignLeft, QString::fromUtf8(" ")+newopt.currentText); QApplication::style()->drawControl(QStyle::CE_ComboBoxLabel, &newopt, painter);
break; break;
} }
default: default:
@ -154,11 +153,12 @@ class PropListDelegate: public QItemDelegate {
QFontMetrics fontMetrics(fnt); QFontMetrics fontMetrics(fnt);
const QString text = index.data(Qt::DisplayRole).toString(); const QString text = index.data(Qt::DisplayRole).toString();
QRect textRect = QRect(0, 0, 0, fontMetrics.lineSpacing() * (text.count(QLatin1Char('\n')) + 1)); QRect textRect = QRect(0, 0, 0, fontMetrics.lineSpacing() * (text.count(QLatin1Char('\n')) + 1));
textRect.setHeight(textRect.height()+10);
return textRect.size(); return textRect.size();
} }
public slots: public slots:
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) { void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const {
QComboBox *combobox = static_cast<QComboBox*>(editor); QComboBox *combobox = static_cast<QComboBox*>(editor);
int value = combobox->currentIndex(); int value = combobox->currentIndex();
qDebug("Setting combobox value in index: %d", value); qDebug("Setting combobox value in index: %d", value);

32
src/propertieswidget.cpp

@ -522,7 +522,7 @@ void PropertiesWidget::ignoreSelection(){
if(index.column() == PRIORITY){ if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(IGNORED)){ if(PropListModel->data(index) != QVariant(IGNORED)){
PropListModel->setData(index, QVariant(IGNORED)); PropListModel->setData(index, QVariant(IGNORED));
transferList->updateTorrentSizeAndProgress(h.hash()); filteredFilesChanged();
setItemColor(index, "red"); setItemColor(index, "red");
} }
} }
@ -535,7 +535,7 @@ void PropertiesWidget::normalSelection(){
if(index.column() == PRIORITY){ if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(NORMAL)){ if(PropListModel->data(index) != QVariant(NORMAL)){
PropListModel->setData(index, QVariant(NORMAL)); PropListModel->setData(index, QVariant(NORMAL));
transferList->updateTorrentSizeAndProgress(h.hash()); filteredFilesChanged();
setItemColor(index, "green"); setItemColor(index, "green");
} }
} }
@ -548,7 +548,7 @@ void PropertiesWidget::highSelection(){
if(index.column() == PRIORITY){ if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(HIGH)){ if(PropListModel->data(index) != QVariant(HIGH)){
PropListModel->setData(index, QVariant(HIGH)); PropListModel->setData(index, QVariant(HIGH));
transferList->updateTorrentSizeAndProgress(h.hash()); filteredFilesChanged();
setItemColor(index, "green"); setItemColor(index, "green");
} }
} }
@ -561,7 +561,7 @@ void PropertiesWidget::maximumSelection(){
if(index.column() == PRIORITY){ if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(MAXIMUM)){ if(PropListModel->data(index) != QVariant(MAXIMUM)){
PropListModel->setData(index, QVariant(MAXIMUM)); PropListModel->setData(index, QVariant(MAXIMUM));
transferList->updateTorrentSizeAndProgress(h.hash()); filteredFilesChanged();
setItemColor(index, "green"); setItemColor(index, "green");
} }
} }
@ -727,6 +727,26 @@ void PropertiesWidget::setItemColor(QModelIndex index, QString color){
} }
} }
bool PropertiesWidget::savePiecesPriorities() {
/*if(!changedFilteredfiles) return true;
if(allFiltered()) {
QMessageBox::warning(0, tr("Priorities error"), tr("Error, you can't filter all the files in a torrent."));
return false;
}*/
qDebug("Saving pieces priorities");
int *priorities = new int[h.get_torrent_info().num_files()];
getPriorities(PropListModel->invisibleRootItem(), priorities);
unsigned int nbFiles = h.get_torrent_info().num_files();
for(unsigned int i=0; i<nbFiles; ++i) {
h.file_priority(i, priorities[i]);
}
delete[] priorities;
TorrentPersistentData::saveFilesPriority(h);
return true;
}
void PropertiesWidget::on_changeSavePathButton_clicked() { void PropertiesWidget::on_changeSavePathButton_clicked() {
QString dir; QString dir;
QDir saveDir(h.save_path()); QDir saveDir(h.save_path());
@ -755,9 +775,11 @@ void PropertiesWidget::on_changeSavePathButton_clicked() {
} }
void PropertiesWidget::filteredFilesChanged() { void PropertiesWidget::filteredFilesChanged() {
if(h.is_valid()) if(h.is_valid()) {
savePiecesPriorities();
transferList->updateTorrentSizeAndProgress(h.hash()); transferList->updateTorrentSizeAndProgress(h.hash());
} }
}
void PropertiesWidget::addFilesToTree(torrent_file *root, QStandardItem *parent) { void PropertiesWidget::addFilesToTree(torrent_file *root, QStandardItem *parent) {
QList<QStandardItem*> child; QList<QStandardItem*> child;

1
src/propertieswidget.h

@ -75,6 +75,7 @@ protected:
QPushButton* getButtonFromIndex(int index); QPushButton* getButtonFromIndex(int index);
std::vector<int> loadFilesPriorities(); std::vector<int> loadFilesPriorities();
bool allFiltered() const; bool allFiltered() const;
bool savePiecesPriorities();
protected slots: protected slots:
void loadTorrentInfos(QTorrentHandle &h); void loadTorrentInfos(QTorrentHandle &h);

Loading…
Cancel
Save