X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/87dc8352d448126f4d7f1e93c574277845cf4bef..89bb4eaf198a1427a1000f3f77dcabaee5fdae93:/src/iconmanager.cpp diff --git a/src/iconmanager.cpp b/src/iconmanager.cpp index 77e773167..a5e72eabf 100644 --- a/src/iconmanager.cpp +++ b/src/iconmanager.cpp @@ -20,6 +20,7 @@ #include "iconmanager.h" #include "dolphinmodel.h" +#include "dolphinsortfilterproxymodel.h" #include #include @@ -28,17 +29,21 @@ #include #include +#include #include #include -IconManager::IconManager(QObject* parent, DolphinModel* model) : +IconManager::IconManager(QAbstractItemView* parent, DolphinSortFilterProxyModel* model) : QObject(parent), m_showPreview(false), + m_view(parent), m_previewJobs(), - m_dolphinModel(model), + m_dolphinModel(0), + m_proxyModel(model), m_cutItemsCache() { - connect(model->dirLister(), SIGNAL(newItems(const KFileItemList&)), + m_dolphinModel = static_cast(m_proxyModel->sourceModel()); + connect(m_dolphinModel->dirLister(), SIGNAL(newItems(const KFileItemList&)), this, SLOT(generatePreviews(const KFileItemList&))); QClipboard* clipboard = QApplication::clipboard(); @@ -71,7 +76,23 @@ void IconManager::generatePreviews(const KFileItemList& items) return; } - KIO::PreviewJob* job = KIO::filePreview(items, 128); + const QRect visibleArea = m_view->viewport()->rect(); + + // Order the items in a way that the preview for the visible items + // is generated first, as this improves the feeled performance a lot. + KFileItemList orderedItems; + foreach (KFileItem item, items) { + const QModelIndex dirIndex = m_dolphinModel->indexForItem(item); + const QModelIndex proxyIndex = m_proxyModel->mapFromSource(dirIndex); + const QRect itemRect = m_view->visualRect(proxyIndex); + if (itemRect.intersects(visibleArea)) { + orderedItems.insert(0, item); + } else { + orderedItems.append(item); + } + } + + KIO::PreviewJob* job = KIO::filePreview(orderedItems, 128); connect(job, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)), this, SLOT(replaceIcon(const KFileItem&, const QPixmap&))); connect(job, SIGNAL(finished(KJob*)), @@ -104,7 +125,6 @@ void IconManager::replaceIcon(const KFileItem& item, const QPixmap& pixmap) } } - void IconManager::slotPreviewJobFinished(KJob* job) { const int index = m_previewJobs.indexOf(job);