Enable DeviceCoordinateCacheMode by default. Overload update() to give

it invalidate-like behavior, and remove invalidate(). Revert last change
to analogclock, cached behavior is now enabled for all applets. If you
want to disable caching, call setCachePaintMode(NoCacheMode) from your
applet's constructor.


svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=710764
This commit is contained in:
Andreas Aardal Hanssen 2007-09-10 20:44:24 +00:00
parent 6828d212bb
commit 1cf7d7c0f6
2 changed files with 9 additions and 12 deletions

View File

@ -89,6 +89,7 @@ Widget::Widget(QGraphicsItem *parent,QObject* parentObject)
{ {
setFlag(QGraphicsItem::ItemClipsToShape, true); setFlag(QGraphicsItem::ItemClipsToShape, true);
setFlag(QGraphicsItem::ItemClipsChildrenToShape, true); setFlag(QGraphicsItem::ItemClipsChildrenToShape, true);
setCachePaintMode(DeviceCoordinateCacheMode);
d->parent = dynamic_cast<Widget *>(parent); d->parent = dynamic_cast<Widget *>(parent);
if (d->parent) { if (d->parent) {
@ -114,17 +115,13 @@ qreal Widget::opacity() const
void Widget::setCachePaintMode(CachePaintMode mode, const QSize &size) void Widget::setCachePaintMode(CachePaintMode mode, const QSize &size)
{ {
d->cachePaintMode = mode; d->cachePaintMode = mode;
d->cacheSize = size;
if (mode == NoCacheMode) { if (mode == NoCacheMode) {
QPixmapCache::remove(d->cacheKey); QPixmapCache::remove(d->cacheKey);
d->cacheKey.clear(); d->cacheKey.clear();
update();
} else { } else {
if (mode == ItemCoordinateCacheMode) { d->cacheKey = QString("%1").arg(long(this));
d->cacheKey = QString("%1").arg(long(this)); if (mode == ItemCoordinateCacheMode)
d->cacheSize = size; d->cacheSize = size.isNull() ? boundingRect().size().toSize() : size;
}
invalidate();
} }
} }
@ -133,11 +130,11 @@ Widget::CachePaintMode Widget::cachePaintMode() const
return d->cachePaintMode; return d->cachePaintMode;
} }
void Widget::invalidate(const QRectF &rect) void Widget::update(const QRectF &rect)
{ {
if (d->cachePaintMode != NoCacheMode) if (d->cachePaintMode != NoCacheMode)
d->cacheInvalidated |= rect.isNull() ? boundingRect() : rect; d->cacheInvalidated |= rect.isNull() ? boundingRect() : rect;
update(rect); QGraphicsItem::update(rect);
} }
Qt::Orientations Widget::expandingDirections() const Qt::Orientations Widget::expandingDirections() const

View File

@ -225,9 +225,9 @@ public:
* Invalidates the widget's cache paint mode for a given item rectangle. * Invalidates the widget's cache paint mode for a given item rectangle.
* @param rect the optional invalidated rectangle; if null, defaults to boundingRect(). * @param rect the optional invalidated rectangle; if null, defaults to boundingRect().
*/ */
void invalidate(const QRectF &rect = QRectF()); void update(const QRectF &rect = QRectF());
inline void invalidate(qreal _x, qreal _y, qreal w, qreal h) inline void update(qreal _x, qreal _y, qreal w, qreal h)
{ invalidate(QRectF(_x, _y, w, h)); } { update(QRectF(_x, _y, w, h)); }
virtual QGraphicsItem* graphicsItem(); virtual QGraphicsItem* graphicsItem();