diff options
| author | Peter Penz <[email protected]> | 2007-12-11 19:19:44 +0000 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2007-12-11 19:19:44 +0000 |
| commit | 1ab719d490d467218d65f2b03b3ec0ec717515b5 (patch) | |
| tree | 91bd5d3e59b4dedac5f3c7cd65f0e6d26661c1a8 /src/dolphincolumnwidget.cpp | |
| parent | 4e43b5465fa54f13273e7a15985a8a2b941ae60e (diff) | |
fixed issue that turning off the preview during the preview job still was active did not work as expected
TODO for 4.1: provide a preview helper class which can be shared between DolphinView and the special use case of DolphinColumnViewWidget
BUG: 153816
svn path=/trunk/KDE/kdebase/apps/; revision=747348
Diffstat (limited to 'src/dolphincolumnwidget.cpp')
| -rw-r--r-- | src/dolphincolumnwidget.cpp | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/src/dolphincolumnwidget.cpp b/src/dolphincolumnwidget.cpp index ad18f03bb..8872dea38 100644 --- a/src/dolphincolumnwidget.cpp +++ b/src/dolphincolumnwidget.cpp @@ -35,6 +35,7 @@ #include <kfileitem.h> #include <kio/previewjob.h> #include <kiconeffect.h> +#include <kjob.h> #include <kmimetyperesolver.h> #include <konqmimedata.h> @@ -60,6 +61,7 @@ DolphinColumnWidget::DolphinColumnWidget(QWidget* parent, m_dirLister(0), m_dolphinModel(0), m_proxyModel(0), + m_previewJob(0), m_dragging(false), m_dropRect() { @@ -132,6 +134,11 @@ DolphinColumnWidget::~DolphinColumnWidget() delete m_dolphinModel; m_dolphinModel = 0; m_dirLister = 0; // deleted by m_dolphinModel + + if (m_previewJob != 0) { + m_previewJob->kill(); + m_previewJob = 0; + } } void DolphinColumnWidget::setDecorationSize(const QSize& size) @@ -356,19 +363,27 @@ void DolphinColumnWidget::generatePreviews(const KFileItemList& items) // for generatePreviews(), showPreview() and isCutItem() if (m_view->m_controller->dolphinView()->showPreview()) { - KIO::PreviewJob* job = KIO::filePreview(items, 128); - connect(job, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)), - this, SLOT(showPreview(const KFileItem&, const QPixmap&))); + if (m_previewJob != 0) { + m_previewJob->kill(); + m_previewJob = 0; + } + + m_previewJob = KIO::filePreview(items, 128); + connect(m_previewJob, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)), + this, SLOT(replaceIcon(const KFileItem&, const QPixmap&))); + connect(m_previewJob, SIGNAL(finished(KJob*)), + this, SLOT(slotPreviewJobFinished(KJob*))); } } -void DolphinColumnWidget::showPreview(const KFileItem& item, const QPixmap& pixmap) +void DolphinColumnWidget::replaceIcon(const KFileItem& item, const QPixmap& pixmap) { // TODO: same implementation as in DolphinView; create helper class // for generatePreviews(), showPreview() and isCutItem() Q_ASSERT(!item.isNull()); - if (item.url().directory() != m_dirLister->url().path()) { + const bool showPreview = m_view->m_controller->dolphinView()->showPreview(); + if (!showPreview || (item.url().directory() != m_dirLister->url().path())) { // the preview job is still working on items of an older URL, hence // the item is not part of the directory model anymore return; @@ -394,6 +409,12 @@ void DolphinColumnWidget::slotEntered(const QModelIndex& index) m_view->m_controller->emitItemEntered(item); } +void DolphinColumnWidget::slotPreviewJobFinished(KJob* job) +{ + Q_ASSERT(job == m_previewJob); + m_previewJob = 0; +} + void DolphinColumnWidget::activate() { setFocus(Qt::OtherFocusReason); |
