• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • applications API Reference
  • KDE Home
  • Contact Us
 

Kate

  • kde-4.14
  • applications
  • kate
  • part
  • view
katefadeeffect.cpp
Go to the documentation of this file.
1 /* This file is part of the KDE and the Kate project
2  *
3  * Copyright (C) 2013 Dominik Haumann <dhaumann@kde.org>
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Library General Public
7  * License as published by the Free Software Foundation; either
8  * version 2 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * Library General Public License for more details.
14  *
15  * You should have received a copy of the GNU Library General Public License
16  * along with this library; see the file COPYING.LIB. If not, write to
17  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18  * Boston, MA 02110-1301, USA.
19  */
20 
21 #include "katefadeeffect.h"
22 #include "katefadeeffect.moc"
23 
24 #include <QWidget>
25 #include <QTimeLine>
26 #include <QGraphicsOpacityEffect>
27 #include <QDebug>
28 
29 KateFadeEffect::KateFadeEffect(QWidget* widget)
30  : QObject(widget)
31  , m_widget(widget)
32  , m_effect(0) // effect only exists during fading animation
33 {
34  m_timeLine = new QTimeLine(500, this);
35  m_timeLine->setUpdateInterval(40);
36 
37  connect(m_timeLine, SIGNAL(valueChanged(qreal)), this, SLOT(opacityChanged(qreal)));
38  connect(m_timeLine, SIGNAL(finished()), this, SLOT(animationFinished()));
39 }
40 
41 void KateFadeEffect::fadeIn()
42 {
43  // stop time line if still running
44  if (m_timeLine->state() == QTimeLine::Running) {
45  m_timeLine->stop();
46  }
47 
48  // assign new graphics effect, old one is deleted in setGraphicsEffect()
49  m_effect = new QGraphicsOpacityEffect(this);
50  m_effect->setOpacity(0.0);
51  m_widget->setGraphicsEffect(m_effect);
52 
53  // show widget and start fade in animation
54  m_widget->show();
55  m_timeLine->setDirection(QTimeLine::Forward);
56  m_timeLine->start();
57 }
58 
59 void KateFadeEffect::fadeOut()
60 {
61  // stop time line if still running
62  if (m_timeLine->state() == QTimeLine::Running) {
63  m_timeLine->stop();
64  }
65 
66  // assign new graphics effect, old one is deleted in setGraphicsEffect()
67  m_effect = new QGraphicsOpacityEffect(this);
68  m_effect->setOpacity(1.0);
69  m_widget->setGraphicsEffect(m_effect);
70 
71  // start fade out animation
72  m_timeLine->setDirection(QTimeLine::Backward);
73  m_timeLine->start();
74 }
75 
76 void KateFadeEffect::opacityChanged(qreal value)
77 {
78  Q_ASSERT(m_effect);
79  m_effect->setOpacity(value);
80 }
81 
82 void KateFadeEffect::animationFinished()
83 {
84  // fading finished: remove graphics effect, deletes the effect as well
85  m_widget->setGraphicsEffect(0);
86  Q_ASSERT(!m_effect);
87 
88  if (m_timeLine->direction() == QTimeLine::Backward) {
89  m_widget->hide();
90  emit widgetHidden();
91  }
92 }
93 
94 // kate: space-indent on; indent-width 2; replace-tabs on;
QWidget
KateFadeEffect::KateFadeEffect
KateFadeEffect(QWidget *widget=0)
Constructor.
Definition: katefadeeffect.cpp:29
katefadeeffect.h
KateFadeEffect::fadeIn
void fadeIn()
Call to show and fade in the widget.
Definition: katefadeeffect.cpp:41
QObject
KateFadeEffect::fadeOut
void fadeOut()
Call to fade out and hide the widget.
Definition: katefadeeffect.cpp:59
KateFadeEffect::widgetHidden
void widgetHidden()
This signal is emitted when the hiding animation is finished.
KateFadeEffect::animationFinished
void animationFinished()
When the animation is finished, hide the widget if fading out.
Definition: katefadeeffect.cpp:82
QTimeLine::stop
void stop()
QTimeLine
QGraphicsOpacityEffect
KateFadeEffect::opacityChanged
void opacityChanged(qreal value)
Helper to update opacity value.
Definition: katefadeeffect.cpp:76
QTimeLine::setUpdateInterval
void setUpdateInterval(int interval)
QObject::connect
bool connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
QTimeLine::start
void start()
QTimeLine::state
State state() const
QTimeLine::setDirection
void setDirection(Direction direction)
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Sat May 9 2020 03:56:58 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

Kate

Skip menu "Kate"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

applications API Reference

Skip menu "applications API Reference"
  •   kate
  •       kate
  •   KTextEditor
  •   Kate
  • Konsole

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal