* performance: allow delayed setting of constraints so we get one call per set[Screen|Position..etc] set of calls

* save the geometry properly by just using geometry() now that we have that =)

svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=729442
This commit is contained in:
Aaron J. Seigo 2007-10-26 01:04:56 +00:00
parent ee8c24dcad
commit da0e4e39e2
2 changed files with 39 additions and 3 deletions

View File

@ -77,6 +77,7 @@ public:
configXml(0), configXml(0),
shadow(0), shadow(0),
cachedBackground(0), cachedBackground(0),
pendingConstraints(NoConstraint),
kioskImmutable(false), kioskImmutable(false),
immutable(false), immutable(false),
hasConfigurationInterface(false), hasConfigurationInterface(false),
@ -332,6 +333,14 @@ public:
} }
} }
void scheduleConstraintsUpdate(Plasma::Constraints c, Applet* applet)
{
if (pendingConstraints == NoConstraint) {
QTimer::singleShot(0, applet, SLOT(flushUpdatedConstraints()));
}
pendingConstraints |= c;
}
//TODO: examine the usage of memory here; there's a pretty large //TODO: examine the usage of memory here; there's a pretty large
// number of members at this point. // number of members at this point.
uint appletId; uint appletId;
@ -349,6 +358,7 @@ public:
ConfigXml* configXml; ConfigXml* configXml;
ShadowItem* shadow; ShadowItem* shadow;
QPixmap* cachedBackground; QPixmap* cachedBackground;
Plasma::Constraints pendingConstraints;
bool kioskImmutable : 1; bool kioskImmutable : 1;
bool immutable : 1; bool immutable : 1;
bool hasConfigurationInterface : 1; bool hasConfigurationInterface : 1;
@ -409,7 +419,9 @@ KConfigGroup Applet::config() const
void Applet::save(KConfigGroup* group) const void Applet::save(KConfigGroup* group) const
{ {
group->writeEntry("plugin", pluginName()); group->writeEntry("plugin", pluginName());
group->writeEntry("geometry", QRect(pos().toPoint(), boundingRect().size().toSize())); //FIXME: for containments, we need to have some special values here w/regards to
// screen affinity (e.g. "bottom of screen 0")
group->writeEntry("geometry", geometry());
Containment* c = containment(); Containment* c = containment();
if (c) { if (c) {
@ -483,8 +495,7 @@ const Package* Applet::package() const
void Applet::updateConstraints(Plasma::Constraints constraints) void Applet::updateConstraints(Plasma::Constraints constraints)
{ {
constraintsUpdated(constraints); d->scheduleConstraintsUpdate(constraints, this);
setShadowShown(formFactor() == Planar);
} }
void Applet::constraintsUpdated(Plasma::Constraints constraints) void Applet::constraintsUpdated(Plasma::Constraints constraints)
@ -660,6 +671,25 @@ void Applet::performSetupConfig()
showConfigurationInterface(); showConfigurationInterface();
} }
void Applet::flushUpdatedConstraints()
{
if (d->pendingConstraints == NoConstraint) {
return;
}
kDebug() << "fushing constraints: " << d->pendingConstraints << "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!";
Plasma::Constraints c = d->pendingConstraints;
d->pendingConstraints = NoConstraint;
constraintsUpdated(c);
if (layout()) {
layout()->update();
}
setShadowShown(formFactor() == Planar);
}
int Applet::type() const int Applet::type() const
{ {
return Type; return Type;

View File

@ -507,6 +507,12 @@ class PLASMA_EXPORT Applet : public Widget
*/ */
virtual void showConfigurationInterface(); virtual void showConfigurationInterface();
/**
* Sends all pending contraints updates to the applet. Will usually
* be called automatically, but can also be called manually if needed.
*/
void flushUpdatedConstraints();
protected: protected:
/** /**
* Called when a request to save the state of the applet is made * Called when a request to save the state of the applet is made