Merge branch 'fadeeffect'

Conflicts:
	kcmkwin/kwincompositing/main.cpp

svn path=/trunk/KDE/kdebase/workspace/; revision=911326
This commit is contained in:
Lucas Murray 2009-01-15 09:55:15 +00:00
parent d8f46c3974
commit 117c719c7d
5 changed files with 194 additions and 1 deletions

View file

@ -40,6 +40,7 @@ SET(kwin4_effect_builtins_sources
diminactive.cpp diminactive.cpp
dimscreen.cpp dimscreen.cpp
fade.cpp fade.cpp
fadedesktop.cpp
fallapart.cpp fallapart.cpp
login.cpp login.cpp
logout.cpp logout.cpp
@ -64,6 +65,7 @@ install( FILES
diminactive.desktop diminactive.desktop
dimscreen.desktop dimscreen.desktop
fade.desktop fade.desktop
fadedesktop.desktop
fallapart.desktop fallapart.desktop
login.desktop login.desktop
logout.desktop logout.desktop

109
effects/fadedesktop.cpp Normal file
View file

@ -0,0 +1,109 @@
/********************************************************************
KWin - the KDE window manager
This file is part of the KDE project.
Copyright (C) 2009 Lucas Murray <lmurray@undefinedfire.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************/
#include "fadedesktop.h"
#include <math.h>
namespace KWin
{
KWIN_EFFECT( fadedesktop, FadeDesktopEffect )
FadeDesktopEffect::FadeDesktopEffect()
: m_fading( false )
{
m_timeline.setCurveShape( TimeLine::LinearCurve );
reconfigure( ReconfigureAll );
}
void FadeDesktopEffect::reconfigure( ReconfigureFlags )
{
m_timeline.setDuration( animationTime( 250 ));
}
void FadeDesktopEffect::prePaintScreen( ScreenPrePaintData &data, int time )
{
if( m_fading )
{
m_timeline.addTime( time );
// PAINT_SCREEN_BACKGROUND_FIRST is needed because screen will be actually painted more than once,
// so with normal screen painting second screen paint would erase parts of the first paint
if( m_timeline.value() != 1.0 )
data.mask |= PAINT_SCREEN_TRANSFORMED | PAINT_SCREEN_BACKGROUND_FIRST;
else
{
m_fading = false;
m_timeline.setProgress( 0.0 );
effects->setActiveFullScreenEffect( NULL );
}
}
effects->prePaintScreen( data, time );
}
void FadeDesktopEffect::postPaintScreen()
{
if( m_fading )
effects->addRepaintFull();
effects->postPaintScreen();
}
void FadeDesktopEffect::prePaintWindow( EffectWindow *w, WindowPrePaintData &data, int time )
{
if( m_fading )
{
if( w->isOnDesktop( m_oldDesktop ))
w->enablePainting( EffectWindow::PAINT_DISABLED_BY_DESKTOP );
data.setTranslucent();
}
effects->prePaintWindow( w, data, time );
}
void FadeDesktopEffect::paintWindow( EffectWindow *w, int mask, QRegion region, WindowPaintData &data )
{
if( m_fading && !( w->isOnCurrentDesktop() && w->isOnDesktop( m_oldDesktop )))
{
if( w->isOnDesktop( m_oldDesktop ))
data.opacity *= 1 - m_timeline.value();
else
data.opacity *= m_timeline.value();
}
effects->paintWindow( w, mask, region, data );
}
void FadeDesktopEffect::desktopChanged( int old )
{
if( effects->activeFullScreenEffect() && effects->activeFullScreenEffect() != this )
return;
// TODO: Fix glitches when fading while a previous fade is still happening
effects->setActiveFullScreenEffect( this );
m_fading = true;
m_timeline.setProgress( 0 );
m_oldDesktop = old;
effects->addRepaintFull();
}
} // namespace
#include "fadedesktop.moc"

View file

@ -0,0 +1,17 @@
[Desktop Entry]
Name=Fade Desktop
Icon=preferences-system-windows-effect-fadedesktop
Comment=Fade between virtual desktops when switching between them
Type=Service
X-KDE-ServiceTypes=KWin/Effect
X-KDE-PluginInfo-Author=Lucas Murray
X-KDE-PluginInfo-Email=lmurray@undefinedfire.com
X-KDE-PluginInfo-Name=kwin4_effect_fadedesktop
X-KDE-PluginInfo-Version=0.1.0
X-KDE-PluginInfo-Category=Appearance
X-KDE-PluginInfo-Depends=
X-KDE-PluginInfo-License=GPL
X-KDE-PluginInfo-EnabledByDefault=false
X-KDE-Library=kwin4_effect_builtins
X-KDE-Ordering=50

51
effects/fadedesktop.h Normal file
View file

@ -0,0 +1,51 @@
/********************************************************************
KWin - the KDE window manager
This file is part of the KDE project.
Copyright (C) 2009 Lucas Murray <lmurray@undefinedfire.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************/
#ifndef KWIN_FADEDESKTOP_H
#define KWIN_FADEDESKTOP_H
#include <kwineffects.h>
#include <QObject>
namespace KWin
{
class FadeDesktopEffect
: public QObject, public Effect
{
Q_OBJECT
public:
FadeDesktopEffect();
virtual void reconfigure( ReconfigureFlags );
virtual void prePaintScreen( ScreenPrePaintData &data, int time );
virtual void postPaintScreen();
virtual void prePaintWindow( EffectWindow *w, WindowPrePaintData &data, int time );
virtual void paintWindow( EffectWindow *w, int mask, QRegion region, WindowPaintData &data );
virtual void desktopChanged( int old );
private:
bool m_fading;
TimeLine m_timeline;
int m_oldDesktop;
};
} // namespace
#endif

View file

@ -163,7 +163,7 @@ KWinCompositingConfig::KWinCompositingConfig(QWidget *parent, const QVariantList
// search the effect names // search the effect names
KServiceTypeTrader* trader = KServiceTypeTrader::self(); KServiceTypeTrader* trader = KServiceTypeTrader::self();
KService::List services; KService::List services;
QString boxswitch, presentwindows, coverswitch, flipswitch, slide, cube; QString boxswitch, presentwindows, coverswitch, flipswitch, slide, cube, fadedesktop;
// window switcher // window switcher
services = trader->query("KWin/Effect", "[X-KDE-PluginInfo-Name] == 'kwin4_effect_boxswitch'"); services = trader->query("KWin/Effect", "[X-KDE-PluginInfo-Name] == 'kwin4_effect_boxswitch'");
if( !services.isEmpty() ) if( !services.isEmpty() )
@ -184,6 +184,9 @@ KWinCompositingConfig::KWinCompositingConfig(QWidget *parent, const QVariantList
services = trader->query("KWin/Effect", "[X-KDE-PluginInfo-Name] == 'kwin4_effect_cube'"); services = trader->query("KWin/Effect", "[X-KDE-PluginInfo-Name] == 'kwin4_effect_cube'");
if( !services.isEmpty() ) if( !services.isEmpty() )
cube = services.first()->name(); cube = services.first()->name();
services = trader->query("KWin/Effect", "[X-KDE-PluginInfo-Name] == 'kwin4_effect_fadedesktop'");
if( !services.isEmpty() )
fadedesktop = services.first()->name();
// init the combo boxes // init the combo boxes
ui.windowSwitchingCombo->addItem(i18n("No Effect")); ui.windowSwitchingCombo->addItem(i18n("No Effect"));
ui.windowSwitchingCombo->addItem(boxswitch); ui.windowSwitchingCombo->addItem(boxswitch);
@ -194,6 +197,7 @@ KWinCompositingConfig::KWinCompositingConfig(QWidget *parent, const QVariantList
ui.desktopSwitchingCombo->addItem(i18n("No Effect")); ui.desktopSwitchingCombo->addItem(i18n("No Effect"));
ui.desktopSwitchingCombo->addItem(slide); ui.desktopSwitchingCombo->addItem(slide);
ui.desktopSwitchingCombo->addItem(cube); ui.desktopSwitchingCombo->addItem(cube);
ui.desktopSwitchingCombo->addItem(fadedesktop);
} }
KWinCompositingConfig::~KWinCompositingConfig() KWinCompositingConfig::~KWinCompositingConfig()
@ -338,6 +342,8 @@ void KWinCompositingConfig::loadGeneralTab()
KConfigGroup cubeconfig(mKWinConfig, "Effect-Cube"); KConfigGroup cubeconfig(mKWinConfig, "Effect-Cube");
if( effectEnabled( "cube", effectconfig ) && cubeconfig.readEntry("AnimateDesktopChange", false)) if( effectEnabled( "cube", effectconfig ) && cubeconfig.readEntry("AnimateDesktopChange", false))
ui.desktopSwitchingCombo->setCurrentIndex( 2 ); ui.desktopSwitchingCombo->setCurrentIndex( 2 );
if( effectEnabled( "fadedesktop", effectconfig ))
ui.desktopSwitchingCombo->setCurrentIndex( 3 );
} }
bool KWinCompositingConfig::effectEnabled( const QString& effect, const KConfigGroup& cfg ) const bool KWinCompositingConfig::effectEnabled( const QString& effect, const KConfigGroup& cfg ) const
@ -472,16 +478,24 @@ void KWinCompositingConfig::saveGeneralTab()
case 0: case 0:
// no effect // no effect
effectconfig.writeEntry("kwin4_effect_slideEnabled", false); effectconfig.writeEntry("kwin4_effect_slideEnabled", false);
effectconfig.writeEntry("kwin4_effect_fadedesktopEnabled", false);
break; break;
case 1: case 1:
// slide // slide
effectconfig.writeEntry("kwin4_effect_slideEnabled", true); effectconfig.writeEntry("kwin4_effect_slideEnabled", true);
effectconfig.writeEntry("kwin4_effect_fadedesktopEnabled", false);
break; break;
case 2: case 2:
// cube // cube
cubeDesktopSwitching = true; cubeDesktopSwitching = true;
effectconfig.writeEntry("kwin4_effect_slideEnabled", false); effectconfig.writeEntry("kwin4_effect_slideEnabled", false);
effectconfig.writeEntry("kwin4_effect_cubeEnabled", true); effectconfig.writeEntry("kwin4_effect_cubeEnabled", true);
effectconfig.writeEntry("kwin4_effect_fadedesktopEnabled", false);
break;
case 3:
// fadedesktop
effectconfig.writeEntry("kwin4_effect_slideEnabled", false);
effectconfig.writeEntry("kwin4_effect_fadedesktopEnabled", true);
break; break;
} }
KConfigGroup cubeconfig(mKWinConfig, "Effect-Cube"); KConfigGroup cubeconfig(mKWinConfig, "Effect-Cube");