fix a performance issue: add a new insertintocache function, the new

parameter is used to identify pixmaps that shouldn't be inserted in the
pixmap cache on disk

BUG: 200313

svn path=/trunk/KDE/kdelibs/; revision=1000100
This commit is contained in:
Marco Martin 2009-07-20 20:30:07 +00:00
parent 83396186c2
commit 94f3c6a498
4 changed files with 52 additions and 14 deletions

View File

@ -621,13 +621,13 @@ void FrameSvgPrivate::cacheFrame(const QString &prefixToSave)
//kDebug()<<"Saving to cache frame"<<id; //kDebug()<<"Saving to cache frame"<<id;
Theme::defaultTheme()->insertIntoCache(id, frame->cachedBackground); Theme::defaultTheme()->insertIntoCache(id, frame->cachedBackground, QString::number((int)q)+prefixToSave);
//insert overlay //insert overlay
id = QString::fromLatin1("overlay_%7_%6_%5_%4_%3_%2_%1_"). id = QString::fromLatin1("overlay_%7_%6_%5_%4_%3_%2_%1_").
arg(overlayPos.y()).arg(overlayPos.x()).arg(frame->enabledBorders).arg(size.width()).arg(size.height()).arg(prefixToSave).arg(q->imagePath()); arg(overlayPos.y()).arg(overlayPos.x()).arg(frame->enabledBorders).arg(size.width()).arg(size.height()).arg(prefixToSave).arg(q->imagePath());
Theme::defaultTheme()->insertIntoCache(id, frame->cachedBackground); Theme::defaultTheme()->insertIntoCache(id, frame->cachedBackground, QString::number((int)q)+prefixToSave+"overlay");
} }
void FrameSvgPrivate::updateSizes() void FrameSvgPrivate::updateSizes()

View File

@ -238,7 +238,7 @@ class SvgPrivate
} }
if (cacheRendering) { if (cacheRendering) {
actualTheme()->insertIntoCache(id, p); actualTheme()->insertIntoCache(id, p, QString::number((int)q)+elementId);
} }
return p; return p;

View File

@ -23,6 +23,7 @@
#include <QFile> #include <QFile>
#include <QFileInfo> #include <QFileInfo>
#include <QTimer> #include <QTimer>
#include <QPair>
#ifdef Q_WS_X11 #ifdef Q_WS_X11
#include <QX11Info> #include <QX11Info>
#endif #endif
@ -152,6 +153,8 @@ public:
KSharedConfigPtr svgElementsCache; KSharedConfigPtr svgElementsCache;
QHash<QString, QSet<QString> > invalidElements; QHash<QString, QSet<QString> > invalidElements;
QHash<QString, QPixmap> pixmapsToCache; QHash<QString, QPixmap> pixmapsToCache;
QHash<QString, QString> keysToCache;
QHash<QString, QString> idsToCache;
QTimer *saveTimer; QTimer *saveTimer;
#ifdef Q_WS_X11 #ifdef Q_WS_X11
@ -238,16 +241,15 @@ void ThemePrivate::discardCache(bool recreateElementsCache)
void ThemePrivate::scheduledCacheUpdate() void ThemePrivate::scheduledCacheUpdate()
{ {
//kDebug()<< "Saving to cache:"; QHashIterator<QString, QPixmap> it(pixmapsToCache);
QHash<QString, QPixmap>::const_iterator it = pixmapsToCache.constBegin(); while (it.hasNext()) {
it.next();
while (it != pixmapsToCache.constEnd()) { pixmapCache->insert(idsToCache[it.key()], it.value());
//kDebug()<< "Saving item to cache: " << it.key();
pixmapCache->insert(it.key(), it.value());
++it;
} }
pixmapsToCache.clear(); pixmapsToCache.clear();
keysToCache.clear();
idsToCache.clear();
} }
void ThemePrivate::colorsChanged() void ThemePrivate::colorsChanged()
@ -672,8 +674,13 @@ bool Theme::useNativeWidgetStyle() const
bool Theme::findInCache(const QString &key, QPixmap &pix) bool Theme::findInCache(const QString &key, QPixmap &pix)
{ {
if (d->useCache()) { if (d->useCache()) {
if (d->pixmapsToCache.contains(key)) { if (!d->keysToCache.contains(key)) {
pix = d->pixmapsToCache.value(key); return false;
}
const QString id = d->keysToCache[key];
if (d->pixmapsToCache.contains(id)) {
pix = d->pixmapsToCache.value(id);
return true; return true;
} }
@ -696,8 +703,22 @@ bool Theme::findInCache(const QString &key, QPixmap &pix, unsigned int lastModif
void Theme::insertIntoCache(const QString& key, const QPixmap& pix) void Theme::insertIntoCache(const QString& key, const QPixmap& pix)
{ {
if (d->useCache()) { if (d->useCache()) {
d->pixmapsToCache.insert(key, pix); d->pixmapCache->insert(key, pix);
d->saveTimer->start(500); }
}
void Theme::insertIntoCache(const QString& key, const QPixmap& pix, const QString& id)
{
if (d->useCache()) {
d->pixmapsToCache.insert(id, pix);
if (d->idsToCache.contains(id)) {
d->keysToCache.remove(d->idsToCache[id]);
}
d->keysToCache.insert(key, id);
d->idsToCache.insert(id, key);
d->saveTimer->start(600);
} }
} }

17
theme.h
View File

@ -240,6 +240,23 @@ class PLASMA_EXPORT Theme : public QObject
**/ **/
void insertIntoCache(const QString& key, const QPixmap& pix); void insertIntoCache(const QString& key, const QPixmap& pix);
/**
* Insert specified pixmap into the cache.
* If the cache already contains pixmap with the specified key then it is
* overwritten.
* The actual insert is delayed for optimization reasons and the id
* parameter is used to discard repeated inserts in the delay time, useful
* when for instance the graphics to inser comes from a quickly resizing
* object: the frames between the start and destination sizes aren't
* useful in the cache and just cause overhead.
*
* @param key the name to use in the cache for this pixmap
* @param pix the pixmap data to store in the cache
* @param id a name that identifies the caller class of this function in an unique fashion
* @since 4.3
**/
void insertIntoCache(const QString& key, const QPixmap& pix, const QString& id);
/** /**
* Sets the maximum size of the cache (in kilobytes). If cache gets bigger * Sets the maximum size of the cache (in kilobytes). If cache gets bigger
* the limit then some entries are removed * the limit then some entries are removed