/* * Copyright 2009 Mehmet Ali Akmanalp <makmanalp@wpi.edu> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU Library General Public License as * published by the Free Software Foundation; either version 2, 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 Library General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ /** * @file This file contains the definition for the Fade effect. */ #ifndef PLASMA_ANIMATIONS_FADE_P_H #define PLASMA_ANIMATIONS_FADE_P_H #include <plasma/animations/animation.h> #include <plasma/plasma_export.h> namespace Plasma { /** * @class Fade plasma/animations/fade.h * @short Fade effect * * Effect that slowly transforms the opacity of the object from a starting * value to a target value. The range is 0 (full translucent) to 1 (full * opaque). */ class FadeAnimation : public Animation { Q_OBJECT Q_PROPERTY(qreal startOpacity READ startOpacity WRITE setStartOpacity) Q_PROPERTY(qreal targetOpacity READ targetOpacity WRITE setTargetOpacity) public: /** Default constructor */ explicit FadeAnimation(QObject *parent = 0); /** Destructor */ virtual ~FadeAnimation(); /** * Access start opacity of the target widget. * * You can set both a start and an end opacity for an widget when * using this animation class. See \ref setStartOpacity. * @return The opacity (range is 0 to 1). */ qreal startOpacity() const; /** * Set the start opacity of the target widget. * * See also \ref targetOpacity. * @param qreal The opacity (range is 0 to 1). */ void setStartOpacity(qreal); /** * Access final opacity of the target widget. * * You can set both a start and an end opacity for an widget when * using this animation class. See \ref setTargetOpacity. * @return The opacity (range is 0 to 1). */ qreal targetOpacity() const; /** * Set the final opacity of the target widget. * * See also \ref startOpacity. * @param qreal The opacity (range is 0 to 1). */ void setTargetOpacity(qreal); protected: void updateState(QAbstractAnimation::State newState, QAbstractAnimation::State oldState); void updateCurrentTime(int currentTime); private: /** Initial opacity */ qreal m_startOpacity; /** Final opacity */ qreal m_targetOpacity; }; } #endif // PLASMA_ANIMATIONS_FADE_P_H