* clear() the panels list after deleting the items (fixes crash)

* resize -> resizePanel ... resolves a semantically annoying ambiguity now that it subclasses Svg
* don't use the [] accessor more than necessary
* slightly clearer code in places


svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=800283
This commit is contained in:
Aaron J. Seigo 2008-04-23 20:38:09 +00:00
parent 710be86ffd
commit 2e71b7a700
2 changed files with 169 additions and 180 deletions

View File

@ -77,7 +77,7 @@ public:
qDeleteAll(panels); qDeleteAll(panels);
} }
void generateBackground(); void generateBackground(PanelData *panel);
void updateSizes(); void updateSizes();
void updateAndSignalSizes(); void updateAndSignalSizes();
@ -116,8 +116,8 @@ void PanelSvg::setImagePath(const QString& path)
qDeleteAll(d->panels); qDeleteAll(d->panels);
d->panels.insert(QString(), new PanelData()); d->panels.insert(QString(), new PanelData());
d->updateSizes();
d->panels[QString()]->panelSize = size(); d->panels[QString()]->panelSize = size();
d->updateSizes();
} }
void PanelSvg::setEnabledBorders(const EnabledBorders borders) void PanelSvg::setEnabledBorders(const EnabledBorders borders)
@ -195,7 +195,7 @@ QString PanelSvg::prefix()
return d->prefix.left(d->prefix.size() - 1); return d->prefix.left(d->prefix.size() - 1);
} }
void PanelSvg::resize(const QSizeF& size) void PanelSvg::resizePanel(const QSizeF& size)
{ {
if (!size.isValid() || size.width() < 1 || size.height() < 1 || size == d->panels[d->prefix]->panelSize) { if (!size.isValid() || size.width() < 1 || size.height() < 1 || size == d->panels[d->prefix]->panelSize) {
return; return;
@ -205,11 +205,6 @@ void PanelSvg::resize(const QSizeF& size)
d->updateSizes(); d->updateSizes();
} }
void PanelSvg::resize(qreal width, qreal height)
{
resize(QSize(width, height));
}
qreal PanelSvg::marginSize(const Plasma::MarginEdge edge) const qreal PanelSvg::marginSize(const Plasma::MarginEdge edge) const
{ {
if (d->panels[d->prefix]->noBorderPadding) { if (d->panels[d->prefix]->noBorderPadding) {
@ -238,11 +233,13 @@ qreal PanelSvg::marginSize(const Plasma::MarginEdge edge) const
QBitmap PanelSvg::mask() const QBitmap PanelSvg::mask() const
{ {
if (!d->panels[d->prefix]->cachedBackground) { PanelData *panel = d->panels[d->prefix];
d->generateBackground(); if (!panel->cachedBackground) {
d->generateBackground(panel);
Q_ASSERT(panel->cachedBackground);
} }
return d->panels[d->prefix]->cachedBackground->alphaChannel().createMaskFromColor(Qt::black); return panel->cachedBackground->alphaChannel().createMaskFromColor(Qt::black);
} }
void PanelSvg::setCacheAllRenderedPanels(bool cache) void PanelSvg::setCacheAllRenderedPanels(bool cache)
@ -262,37 +259,38 @@ bool PanelSvg::cacheAllRenderedPanels() const
void PanelSvg::clearCache() void PanelSvg::clearCache()
{ {
qDeleteAll(d->panels); qDeleteAll(d->panels);
d->panels.clear();
if (!d->panels.contains(d->prefix)) {
d->panels.insert(d->prefix, new PanelData()); d->panels.insert(d->prefix, new PanelData());
} }
}
void PanelSvg::paint(QPainter* painter, const QRectF& rect, const QPointF& pos) void PanelSvg::paint(QPainter* painter, const QRectF& rect, const QPointF& pos)
{ {
if (!d->panels[d->prefix]->cachedBackground) { PanelData *panel = d->panels[d->prefix];
d->generateBackground(); if (!panel->cachedBackground) {
d->generateBackground(panel);
Q_ASSERT(panel->cachedBackground);
} }
//FIXME: this is redundant with generatebackground for now //FIXME: this is redundant with generatebackground for now
bool origined = d->panels[d->prefix]->contentAtOrigin; bool origined = panel->contentAtOrigin;
const int topOffset = origined ? 0 - d->panels[d->prefix]->topHeight : 0; const int topOffset = origined ? 0 - panel->topHeight : 0;
const int leftOffset = origined ? 0 - d->panels[d->prefix]->leftWidth : 0; const int leftOffset = origined ? 0 - panel->leftWidth : 0;
painter->drawPixmap(rect, *d->panels[d->prefix]->cachedBackground, rect.translated(-pos.x()-leftOffset,-pos.y()-topOffset)); painter->drawPixmap(rect, *(panel->cachedBackground), rect.translated(-pos.x()-leftOffset,-pos.y()-topOffset));
} }
void PanelSvg::Private::generateBackground() void PanelSvg::Private::generateBackground(PanelData *panel)
{ {
PanelData *panel = panels[prefix];
bool origined = panel->contentAtOrigin; bool origined = panel->contentAtOrigin;
const int topWidth = q->elementSize(prefix + "top").width(); const int topWidth = q->elementSize(prefix + "top").width();
const int leftHeight = q->elementSize(prefix + "left").height(); const int leftHeight = q->elementSize(prefix + "left").height();
const int topOffset = origined ? 0 - panel->topHeight : 0; const int topOffset = origined ? 0 - panel->topHeight : 0;
const int leftOffset = origined ? 0 - panel->leftWidth : 0; const int leftOffset = origined ? 0 - panel->leftWidth : 0;
if (!panel->cachedBackground) { if (panel->cachedBackground) {
return;
}
const int contentWidth = panel->panelSize.width() - panel->leftWidth - panel->rightWidth; const int contentWidth = panel->panelSize.width() - panel->leftWidth - panel->rightWidth;
const int contentHeight = panel->panelSize.height() - panel->topHeight - panel->bottomHeight; const int contentHeight = panel->panelSize.height() - panel->topHeight - panel->bottomHeight;
int contentTop = 0; int contentTop = 0;
@ -463,7 +461,6 @@ void PanelSvg::Private::generateBackground()
//q->Svg::resize(contentWidth, contentHeight); //q->Svg::resize(contentWidth, contentHeight);
//paint(&p, QRect(contentLeft, contentTop, contentWidth, contentHeight), "center"); //paint(&p, QRect(contentLeft, contentTop, contentWidth, contentHeight), "center");
} }
}
void PanelSvg::Private::updateSizes() void PanelSvg::Private::updateSizes()
{ {

View File

@ -94,15 +94,7 @@ class PLASMA_EXPORT PanelSvg : public Svg
* Resize the panel maintaining the same border size * Resize the panel maintaining the same border size
* @arg size the new size of the panel * @arg size the new size of the panel
*/ */
void resize(const QSizeF& size); void resizePanel(const QSizeF& size);
/**
* Resize the panel maintaining the same border size
* This is an overloaded function provided for convenience
* @arg width the new width
* @arg height the new height
**/
void resize(qreal width, qreal height);
/** /**
* Returns the margin size given the margin edge we want * Returns the margin size given the margin edge we want