* 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:
parent
710be86ffd
commit
2e71b7a700
47
panelsvg.cpp
47
panelsvg.cpp
@ -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()
|
||||||
{
|
{
|
||||||
|
10
panelsvg.h
10
panelsvg.h
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user