From 3924d218a4aa8f2e20d9c1f1696d64df376922dc Mon Sep 17 00:00:00 2001 From: Aaron Seigo Date: Wed, 16 Feb 2011 11:41:18 -0800 Subject: [PATCH] cache the values for size and resize method the main advantage to this is that only when the object signals a change will the values be re-checked, which means that the wallpaper pointer can be deleted behind our backs and we won't care --- private/packages.cpp | 23 +++++++++++++++-------- private/packages_p.h | 2 ++ 2 files changed, 17 insertions(+), 8 deletions(-) diff --git a/private/packages.cpp b/private/packages.cpp index 43ec8dd93..5e064d92b 100644 --- a/private/packages.cpp +++ b/private/packages.cpp @@ -213,7 +213,9 @@ ThemePackage::ThemePackage(QObject *parent) WallpaperPackage::WallpaperPackage(Wallpaper *paper, QObject *parent) : PackageStructure(parent, "Background"), m_paper(paper), - m_fullPackage(true) + m_fullPackage(true), + m_targetSize(100000, 100000), + m_resizeMethod(Wallpaper::ScaledResize) { QStringList mimetypes; mimetypes << "image/svg" << "image/png" << "image/jpeg" << "image/jpg"; @@ -225,13 +227,21 @@ WallpaperPackage::WallpaperPackage(Wallpaper *paper, QObject *parent) setAllowExternalPaths(true); if (m_paper) { - connect(paper, SIGNAL(renderHintsChanged()), this, SLOT(renderHintsChanged())); + m_targetSize = m_paper->d->targetSize.toSize(); + m_resizeMethod = m_paper->d->lastResizeMethod; + + connect(m_paper, SIGNAL(renderHintsChanged()), this, SLOT(renderHintsChanged())); connect(m_paper, SIGNAL(destroyed(QObject*)), this, SLOT(paperDestroyed())); } } void WallpaperPackage::renderHintsChanged() { + if (m_paper) { + m_targetSize = m_paper->d->targetSize.toSize(); + m_resizeMethod = m_paper->d->lastResizeMethod; + } + if (m_fullPackage) { findBestPaper(); } @@ -248,14 +258,14 @@ void WallpaperPackage::pathChanged() guard = true; QFileInfo info(path()); - m_fullPackage = info.isDir(); + removeDefinition("preferred"); + if (m_fullPackage) { setContentsPrefixPaths(QStringList() << "contents/"); findBestPaper(); } else { // dirty trick to support having a file passed in instead of a directory - removeDefinition("preferred"); addFileDefinition("preferred", info.fileName(), i18n("Recommended wallpaper file")); setContentsPrefixPaths(QStringList()); //kDebug() << "changing" << path() << "to" << info.path(); @@ -287,9 +297,6 @@ void WallpaperPackage::findBestPaper() // choose the nearest resolution float best = FLT_MAX; - const QSize size = m_paper ? m_paper->d->targetSize.toSize() : QSize(100000, 100000); - const Wallpaper::ResizeMethod method = m_paper ? m_paper->d->lastResizeMethod - : Wallpaper::ScaledResize; QString bestImage; foreach (const QString &entry, images) { @@ -298,7 +305,7 @@ void WallpaperPackage::findBestPaper() continue; } - double dist = distance(candidate, size, method); + double dist = distance(candidate, m_targetSize, m_resizeMethod); //kDebug() << "candidate" << candidate << "distance" << dist; if (bestImage.isEmpty() || dist < best) { bestImage = entry; diff --git a/private/packages_p.h b/private/packages_p.h index dfce64d8a..15fde4171 100644 --- a/private/packages_p.h +++ b/private/packages_p.h @@ -94,6 +94,8 @@ private Q_SLOTS: private: Wallpaper *m_paper; bool m_fullPackage; + QSize m_targetSize; + Wallpaper::ResizeMethod m_resizeMethod; }; class ContainmentActionsPackage : public PackageStructure