1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-02-03 18:34:28 +00:00

- Fix for media file preview

This commit is contained in:
Christophe Dumez 2009-11-27 11:38:42 +00:00
parent d22d6468c7
commit 90207020f2
6 changed files with 84 additions and 82 deletions

View File

@ -424,10 +424,6 @@ void GUI::on_actionExit_triggered() {
close(); close();
} }
void GUI::previewFile(QString filePath) {
QDesktopServices::openUrl(QString("file://")+filePath);
}
int GUI::getCurrentTabIndex() const { int GUI::getCurrentTabIndex() const {
if(isMinimized() || !isVisible()) if(isMinimized() || !isVisible())
return -1; return -1;

View File

@ -105,7 +105,6 @@ class GUI : public QMainWindow, private Ui::MainWindow{
void on_actionShow_console_triggered(); void on_actionShow_console_triggered();
void readParamsOnSocket(); void readParamsOnSocket();
void acceptConnection(); void acceptConnection();
void previewFile(QString filePath);
void balloonClicked(); void balloonClicked();
void writeSettings(); void writeSettings();
void readSettings(); void readSettings();

View File

@ -72,7 +72,7 @@ class FilterParserThread : public QThread {
parseP2PFilterFile(filePath); parseP2PFilterFile(filePath);
} else { } else {
if(filePath.endsWith(".p2p", Qt::CaseInsensitive)) { if(filePath.endsWith(".p2p", Qt::CaseInsensitive)) {
// PeerGuardian p2p file // PeerGuardian p2b file
parseP2BFilterFile(filePath); parseP2BFilterFile(filePath);
} else { } else {
// Default: eMule DAT format // Default: eMule DAT format

View File

@ -50,32 +50,32 @@ using namespace libtorrent;
class previewSelect: public QDialog, private Ui::preview { class previewSelect: public QDialog, private Ui::preview {
Q_OBJECT Q_OBJECT
private: private:
QStandardItemModel *previewListModel; QStandardItemModel *previewListModel;
PreviewListDelegate *listDelegate; PreviewListDelegate *listDelegate;
QTorrentHandle h; QTorrentHandle h;
QList<int> indexes; QList<int> indexes;
signals: signals:
void readyToPreviewFile(QString) const; void readyToPreviewFile(QString) const;
protected slots: protected slots:
void on_previewButton_clicked(){ void on_previewButton_clicked(){
QModelIndex index; QModelIndex index;
QModelIndexList selectedIndexes = previewList->selectionModel()->selectedIndexes(); QModelIndexList selectedIndexes = previewList->selectionModel()->selectedRows(NAME);
if(selectedIndexes.size() == 0) return; if(selectedIndexes.size() == 0) return;
QString path; QString path;
foreach(index, selectedIndexes){ foreach(index, selectedIndexes){
if(index.column() == NAME){
path = h.files_path().at(indexes.at(index.row())); path = h.files_path().at(indexes.at(index.row()));
// File // File
if(QFile::exists(path)){ if(QFile::exists(path)){
emit readyToPreviewFile(path); emit readyToPreviewFile(path);
} else {
QMessageBox::critical(0, tr("Preview impossible"), tr("Sorry, we can't preview this file"));
} }
close(); close();
return; return;
} }
}
qDebug("Cannot find file: %s", path.toLocal8Bit().data()); qDebug("Cannot find file: %s", path.toLocal8Bit().data());
QMessageBox::critical(0, tr("Preview impossible"), tr("Sorry, we can't preview this file")); QMessageBox::critical(0, tr("Preview impossible"), tr("Sorry, we can't preview this file"));
close(); close();
@ -85,7 +85,7 @@ class previewSelect: public QDialog, private Ui::preview {
close(); close();
} }
public: public:
previewSelect(QWidget* parent, QTorrentHandle h): QDialog(parent), h(h){ previewSelect(QWidget* parent, QTorrentHandle h): QDialog(parent), h(h){
setupUi(this); setupUi(this);
setAttribute(Qt::WA_DeleteOnClose); setAttribute(Qt::WA_DeleteOnClose);
@ -123,9 +123,11 @@ class previewSelect: public QDialog, private Ui::preview {
} }
connect(this, SIGNAL(readyToPreviewFile(QString)), parent, SLOT(previewFile(QString))); connect(this, SIGNAL(readyToPreviewFile(QString)), parent, SLOT(previewFile(QString)));
if(previewListModel->rowCount() == 1){ if(previewListModel->rowCount() == 1){
qDebug("Torrent file only contains one file, no need to display selection dialog before preview");
// Only one file : no choice // Only one file : no choice
on_previewButton_clicked(); on_previewButton_clicked();
}else{ }else{
qDebug("Displaying media file selection dialog for preview");
show(); show();
} }
} }

View File

@ -251,6 +251,10 @@ void TransferListWidget::updateMetadata(QTorrentHandle &h) {
} }
} }
void TransferListWidget::previewFile(QString filePath) {
QDesktopServices::openUrl(QString("file://")+filePath);
}
int TransferListWidget::updateTorrent(int row) { int TransferListWidget::updateTorrent(int row) {
TorrentState s = STATE_INVALID; TorrentState s = STATE_INVALID;
QString hash = getHashFromRow(row); QString hash = getHashFromRow(row);

View File

@ -108,6 +108,7 @@ public slots:
void hidePriorityColumn(bool hide); void hidePriorityColumn(bool hide);
void displayDLHoSMenu(const QPoint&); void displayDLHoSMenu(const QPoint&);
void applyFilter(int f); void applyFilter(int f);
void previewFile(QString filePath);
signals: signals:
void currentTorrentChanged(QTorrentHandle &h); void currentTorrentChanged(QTorrentHandle &h);