kwin/effects/dialogparent.cpp
Luboš Luňák 0ae5a772e7 Add EffectWindow as a window representation for effects,
to hide the change from Client/Unmanaged and eventually also
act as the only API available to effects.


svn path=/branches/work/kwin_composite/; revision=626360
2007-01-22 22:57:22 +00:00

117 lines
3.6 KiB
C++

/*****************************************************************
KWin - the KDE window manager
This file is part of the KDE project.
Copyright (C) 2006 Rivo Laks <rivolaks@hot.ee>
You can Freely distribute this program under the GNU General Public
License. See the file "COPYING" for the exact licensing terms.
******************************************************************/
#include "dialogparent.h"
#include <client.h>
// Note that currently effects need to be manually enabled in the EffectsHandler
// class constructor (in effects.cpp).
namespace KWinInternal
{
void DialogParentEffect::prePaintWindow( EffectWindow* w, int* mask, QRegion* region, int time )
{
// How long does it take for the effect to get it's full strength (in ms)
const float changeTime = 200;
// Check if this window has a modal dialog and change the window's
// effect's strength accordingly
bool hasDialog = hasModalWindow(w->window());
if( hasDialog )
{
// Increase effect strength of this window
effectStrength[w] = qMin(1.0f, effectStrength[w] + time/changeTime);
}
else
{
effectStrength[w] = qMax(0.0f, effectStrength[w] - time/changeTime);
}
// Call the next effect
effects->prePaintWindow( w, mask, region, time );
}
void DialogParentEffect::paintWindow( EffectWindow* w, int mask, QRegion region, WindowPaintData& data )
{
float s = effectStrength[w];
if(s > 0.0f)
{
// Brightness will be within [1.0; 0.6]
data.brightness *= (1.0 - s * 0.4);
// Saturation within [1.0; 0.4]
data.saturation *= (1.0 - s * 0.6);
}
// Call the next effect.
effects->paintWindow( w, mask, region, data );
}
void DialogParentEffect::postPaintWindow( EffectWindow* w )
{
float s = effectStrength[w];
// If strength is between 0 and 1, the effect is still in progress and the
// window has to be repainted during the next pass
if( s > 0.0 && s < 1.0 )
w->window()->addDamageFull(); // trigger next animation repaint
// Call the next effect.
effects->postPaintWindow( w );
}
void DialogParentEffect::windowActivated( EffectWindow* t )
{
// If this window is a dialog, we need to damage it's parent window, so
// that the effect could be run for it
// Set the window to be faded (or NULL if no window is active).
Client* c = qobject_cast<Client *>(t?t->window():NULL);
if ( c && c->isModal() )
{
// c is a modal dialog
ClientList mainclients = c->mainClients();
foreach( Client* parent, mainclients )
parent->addDamageFull();
}
}
void DialogParentEffect::windowClosed( EffectWindow* t )
{
// If this window is a dialog, we need to damage it's parent window, so
// that the effect could be run for it
// Set the window to be faded (or NULL if no window is active).
Client* c = qobject_cast<Client *>(t->window());
if ( c && c->isModal() )
{
// c is a modal dialog
ClientList mainclients = c->mainClients();
foreach( Client* parent, mainclients )
parent->addDamageFull();
}
}
bool DialogParentEffect::hasModalWindow( Toplevel* t )
{
Client* c = qobject_cast<Client *>(t);
if( !c )
return false;
// Check if any of the direct transients (children) of this window is modal
for( ClientList::ConstIterator it = c->transients().begin(); it != c->transients().end(); ++it )
if( (*it)->isModal())
return true;
return false;
}
} // namespace