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:
parent
d22d6468c7
commit
90207020f2
@ -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;
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user