Browse Source

- Improved list refreshing code

adaptive-webui-19844
Christophe Dumez 15 years ago
parent
commit
bf7841cdb9
  1. 15
      src/TransferListWidget.cpp
  2. 5
      src/TransferListWidget.h

15
src/TransferListWidget.cpp

@ -37,7 +37,7 @@ @@ -37,7 +37,7 @@
#include <QStandardItemModel>
#include <QSortFilterProxyModel>
#include <QDesktopServices>
#include <QBasicTimer>
#include <QTimer>
#include <QSettings>
#include <QClipboard>
#include <QColor>
@ -89,8 +89,9 @@ TransferListWidget::TransferListWidget(QWidget *parent, bittorrent *_BTSession): @@ -89,8 +89,9 @@ TransferListWidget::TransferListWidget(QWidget *parent, bittorrent *_BTSession):
connect(header(), SIGNAL(customContextMenuRequested(const QPoint&)), this, SLOT(displayDLHoSMenu(const QPoint&)));
// Refresh timer
refreshTimer = new QBasicTimer();
refreshTimer->start(settings.value("Preferences/General/RefreshInterval", 1500).toInt(), this);
refreshTimer = new QTimer();
refreshTimer->start(settings.value("Preferences/General/RefreshInterval", 1500).toInt());
connect(refreshTimer, SIGNAL(timeout()), this, SLOT(refreshList()));
}
TransferListWidget::~TransferListWidget() {
@ -101,10 +102,6 @@ TransferListWidget::~TransferListWidget() { @@ -101,10 +102,6 @@ TransferListWidget::~TransferListWidget() {
delete listDelegate;
}
void TransferListWidget::timerEvent(QTimerEvent*) {
refreshList();
}
void TransferListWidget::addTorrent(QTorrentHandle& h) {
if(!h.is_valid()) return;
int row = listModel->rowCount();
@ -146,7 +143,6 @@ void TransferListWidget::pauseTorrent(QString hash) { @@ -146,7 +143,6 @@ void TransferListWidget::pauseTorrent(QString hash) {
}
void TransferListWidget::pauseTorrent(int row) {
qDebug("Torrent visibly paused");
listModel->setData(listModel->index(row, DLSPEED), QVariant((double)0.0));
listModel->setData(listModel->index(row, UPSPEED), QVariant((double)0.0));
listModel->setData(listModel->index(row, ETA), QVariant((qlonglong)-1));
@ -263,7 +259,7 @@ void TransferListWidget::setFinished(QTorrentHandle &h) { @@ -263,7 +259,7 @@ void TransferListWidget::setFinished(QTorrentHandle &h) {
}
void TransferListWidget::setRefreshInterval(int t) {
refreshTimer->start(t, this);
refreshTimer->start(t);
}
void TransferListWidget::refreshList() {
@ -343,7 +339,6 @@ void TransferListWidget::pauseSelectedTorrents() { @@ -343,7 +339,6 @@ void TransferListWidget::pauseSelectedTorrents() {
QTorrentHandle h = BTSession->getTorrentHandle(hash);
if(h.is_valid() && !h.is_paused()) {
h.pause();
qDebug("row: %d", index.row());
pauseTorrent(index.row());
}
}

5
src/TransferListWidget.h

@ -38,7 +38,7 @@ class TransferListDelegate; @@ -38,7 +38,7 @@ class TransferListDelegate;
class QStandardItemModel;
class QSortFilterProxyModel;
class bittorrent;
class QBasicTimer;
class QTimer;
class TransferListWidget: public QTreeView {
Q_OBJECT
@ -48,14 +48,13 @@ private: @@ -48,14 +48,13 @@ private:
QStandardItemModel *listModel;
QSortFilterProxyModel *proxyModel;
bittorrent* BTSession;
QBasicTimer *refreshTimer;
QTimer *refreshTimer;
public:
TransferListWidget(QWidget *parent, bittorrent* BTSession);
~TransferListWidget();
protected:
void timerEvent(QTimerEvent*);
int getRowFromHash(QString hash) const;
QString getHashFromRow(int row) const;

Loading…
Cancel
Save