X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/462982faa361c79daab43ce526ae64646b1ea63c..e018ecafca79a73f1e9d76c577b9529fc3a7ae03:/src/views/tooltips/tooltipmanager.cpp diff --git a/src/views/tooltips/tooltipmanager.cpp b/src/views/tooltips/tooltipmanager.cpp index 7e901bfcd..0f540e162 100644 --- a/src/views/tooltips/tooltipmanager.cpp +++ b/src/views/tooltips/tooltipmanager.cpp @@ -8,21 +8,20 @@ #include "dolphinfilemetadatawidget.h" -#include +#include #include +#include #include +#include #include -#include #include -#include -#include -#include #include #include #include -class IconLoaderSingleton { +class IconLoaderSingleton +{ public: IconLoaderSingleton() = default; @@ -31,18 +30,17 @@ public: Q_GLOBAL_STATIC(IconLoaderSingleton, iconLoader) -ToolTipManager::ToolTipManager(QWidget* parent) : - QObject(parent), - m_showToolTipTimer(nullptr), - m_contentRetrievalTimer(nullptr), - m_transientParent(nullptr), - m_fileMetaDataWidget(nullptr), - m_toolTipRequested(false), - m_metaDataRequested(false), - m_appliedWaitCursor(false), - m_margin(4), - m_item(), - m_itemRect() +ToolTipManager::ToolTipManager(QWidget *parent) + : QObject(parent) + , m_showToolTipTimer(nullptr) + , m_contentRetrievalTimer(nullptr) + , m_transientParent(nullptr) + , m_toolTipRequested(false) + , m_metaDataRequested(false) + , m_appliedWaitCursor(false) + , m_margin(4) + , m_item() + , m_itemRect() { if (parent) { m_margin = qMax(m_margin, parent->style()->pixelMetric(QStyle::PM_ToolTipLabelFrameWidth)); @@ -63,11 +61,14 @@ ToolTipManager::ToolTipManager(QWidget* parent) : ToolTipManager::~ToolTipManager() { + if (!m_fileMetaDatWidgetOwnershipTransferred) { + delete m_fileMetaDataWidget; + } } -void ToolTipManager::showToolTip(const KFileItem& item, const QRectF& itemRect, QWindow *transientParent) +void ToolTipManager::showToolTip(const KFileItem &item, const QRectF &itemRect, QWindow *transientParent) { - hideToolTip(); + hideToolTip(HideBehavior::Instantly); m_itemRect = itemRect.toRect(); @@ -79,11 +80,11 @@ void ToolTipManager::showToolTip(const KFileItem& item, const QRectF& itemRect, // Only start the retrieving of the content, when the mouse has been over this // item for 200 milliseconds. This prevents a lot of useless preview jobs and // meta data retrieval, when passing rapidly over a lot of items. - m_fileMetaDataWidget.reset(new DolphinFileMetaDataWidget()); - connect(m_fileMetaDataWidget.data(), &DolphinFileMetaDataWidget::metaDataRequestFinished, - this, &ToolTipManager::slotMetaDataRequestFinished); - connect(m_fileMetaDataWidget.data(), &DolphinFileMetaDataWidget::urlActivated, - this, &ToolTipManager::urlActivated); + if (!m_fileMetaDataWidget) { + m_fileMetaDataWidget = new DolphinFileMetaDataWidget(); + connect(m_fileMetaDataWidget, &DolphinFileMetaDataWidget::metaDataRequestFinished, this, &ToolTipManager::slotMetaDataRequestFinished); + connect(m_fileMetaDataWidget, &DolphinFileMetaDataWidget::urlActivated, this, &ToolTipManager::urlActivated); + } m_contentRetrievalTimer->start(); m_showToolTipTimer->start(); @@ -132,24 +133,20 @@ void ToolTipManager::startContentRetrieval() // Request a preview of the item m_fileMetaDataWidget->setPreview(QPixmap()); - QStringList plugins = KIO::PreviewJob::availablePlugins(); - KIO::PreviewJob* job = new KIO::PreviewJob(KFileItemList() << m_item, - QSize(256, 256), - &plugins); - job->setIgnoreMaximumSize(m_item.isLocalFile()); + const KConfigGroup globalConfig(KSharedConfig::openConfig(), QLatin1String("PreviewSettings")); + const QStringList plugins = globalConfig.readEntry("Plugins", KIO::PreviewJob::defaultPlugins()); + KIO::PreviewJob *job = new KIO::PreviewJob(KFileItemList() << m_item, QSize(512, 512), &plugins); + job->setDevicePixelRatio(m_fileMetaDataWidget->devicePixelRatioF()); + job->setIgnoreMaximumSize(m_item.isLocalFile() && !m_item.isSlow()); if (job->uiDelegate()) { KJobWidgets::setWindow(job, qApp->activeWindow()); } - connect(job, &KIO::PreviewJob::gotPreview, - this, &ToolTipManager::setPreviewPix); - connect(job, &KIO::PreviewJob::failed, - this, &ToolTipManager::previewFailed); + connect(job, &KIO::PreviewJob::gotPreview, this, &ToolTipManager::setPreviewPix); + connect(job, &KIO::PreviewJob::failed, this, &ToolTipManager::previewFailed); } - -void ToolTipManager::setPreviewPix(const KFileItem& item, - const QPixmap& pixmap) +void ToolTipManager::setPreviewPix(const KFileItem &item, const QPixmap &pixmap) { if (!m_toolTipRequested || (m_item.url() != item.url())) { // No tooltip is requested anymore or an old preview has been received @@ -172,7 +169,7 @@ void ToolTipManager::previewFailed() return; } QPalette pal; - for (auto state : { QPalette::Active, QPalette::Inactive, QPalette::Disabled }) { + for (auto state : {QPalette::Active, QPalette::Inactive, QPalette::Disabled}) { pal.setBrush(state, QPalette::WindowText, pal.toolTipText()); pal.setBrush(state, QPalette::Window, pal.toolTipBase()); } @@ -217,7 +214,11 @@ void ToolTipManager::showToolTip() if (!m_tooltipWidget) { m_tooltipWidget.reset(new KToolTipWidget()); } - m_tooltipWidget->showBelow(m_itemRect, m_fileMetaDataWidget.data(), m_transientParent); + m_tooltipWidget->showBelow(m_itemRect, m_fileMetaDataWidget, m_transientParent); + // At this point KToolTipWidget adopted our parent-less metadata widget. + m_fileMetaDatWidgetOwnershipTransferred = true; + m_toolTipRequested = false; } +#include "moc_tooltipmanager.cpp"