~ubuntu-branches/ubuntu/natty/phonon/natty

« back to all changes in this revision

Viewing changes to gstreamer/volumefadereffect.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Jonathan Riddell
  • Date: 2011-01-24 10:12:11 UTC
  • mfrom: (0.5.2 upstream)
  • Revision ID: james.westby@ubuntu.com-20110124101211-w9rew7q0dmwbwhqx
Tags: 4:4.7.0really4.4.4-0ubuntu1
* New upstream release
* Xine and GStreamer backends now split out source, remove build-deps and
  binary packages from debian/control
* Remove 02_no_rpath.patch, now upstream
* Disable kubuntu04_no_va_mangle.patch, no longer applies
* Remove kubuntu_05_gst_codec_installer_window_id.diff, kubuntu_06_forward_events.diff,
  kubuntu_07_include_fix.diff, gstreamer now separate

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*  This file is part of the KDE project.
2
 
 
3
 
    Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4
 
 
5
 
    This library is free software: you can redistribute it and/or modify
6
 
    it under the terms of the GNU Lesser General Public License as published by
7
 
    the Free Software Foundation, either version 2.1 or 3 of the License.
8
 
 
9
 
    This library is distributed in the hope that it will be useful,
10
 
    but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
    GNU Lesser General Public License for more details.
13
 
 
14
 
    You should have received a copy of the GNU Lesser General Public License
15
 
    along with this library.  If not, see <http://www.gnu.org/licenses/>.
16
 
*/
17
 
 
18
 
#include "volumefadereffect.h"
19
 
#include "common.h"
20
 
 
21
 
#include <gst/gstbin.h>
22
 
#include <gst/gstghostpad.h>
23
 
#include <gst/gstutils.h>
24
 
 
25
 
#include <QtCore/QEvent>
26
 
 
27
 
QT_BEGIN_NAMESPACE
28
 
 
29
 
#ifndef QT_NO_PHONON_VOLUMEFADEREFFECT
30
 
namespace Phonon
31
 
{
32
 
namespace Gstreamer
33
 
{
34
 
VolumeFaderEffect::VolumeFaderEffect(Backend *backend, QObject *parent)
35
 
    : Effect(backend, parent, AudioSource | AudioSink)
36
 
    , m_fadeCurve(Phonon::VolumeFaderEffect::Fade3Decibel)
37
 
    , m_fadeTimer(0)
38
 
    , m_fadeDuration(0)
39
 
    , m_fadeFromVolume(0)
40
 
    , m_fadeToVolume(0)
41
 
{
42
 
    m_effectElement = gst_element_factory_make ("volume", NULL);
43
 
    if (m_effectElement)
44
 
        init();
45
 
}
46
 
 
47
 
VolumeFaderEffect::~VolumeFaderEffect()
48
 
{
49
 
    if (m_fadeTimer)
50
 
        killTimer(m_fadeTimer);
51
 
}
52
 
 
53
 
GstElement* VolumeFaderEffect::createEffectBin()
54
 
{
55
 
    GstElement *audioBin = gst_bin_new(NULL);
56
 
 
57
 
    // We need a queue to handle tee-connections from parent node
58
 
    GstElement *queue= gst_element_factory_make ("queue", NULL);
59
 
    gst_bin_add(GST_BIN(audioBin), queue);
60
 
 
61
 
    GstElement *mconv= gst_element_factory_make ("audioconvert", NULL);
62
 
    gst_bin_add(GST_BIN(audioBin), mconv);
63
 
    gst_bin_add(GST_BIN(audioBin), m_effectElement);
64
 
 
65
 
    // Link src pad
66
 
    GstPad *srcPad= gst_element_get_pad (m_effectElement, "src");
67
 
    gst_element_add_pad (audioBin, gst_ghost_pad_new ("src", srcPad));
68
 
    gst_object_unref (srcPad);
69
 
 
70
 
    // Link sink pad
71
 
    gst_element_link_many(queue, mconv, m_effectElement, (const char*)NULL);
72
 
    GstPad *sinkpad = gst_element_get_pad (queue, "sink");
73
 
    gst_element_add_pad (audioBin, gst_ghost_pad_new ("sink", sinkpad));
74
 
    gst_object_unref (sinkpad);
75
 
    return audioBin;
76
 
}
77
 
 
78
 
float VolumeFaderEffect::volume() const
79
 
{
80
 
    gdouble val = 0.0;
81
 
    if (m_effectElement)
82
 
        g_object_get(G_OBJECT(m_effectElement), "volume", &val, (const char*)NULL);
83
 
    return (float)val;
84
 
}
85
 
 
86
 
void VolumeFaderEffect::setVolume(float volume)
87
 
{
88
 
    g_object_set(G_OBJECT(m_effectElement), "volume", volume, (const char*)NULL);
89
 
}
90
 
 
91
 
Phonon::VolumeFaderEffect::FadeCurve VolumeFaderEffect::fadeCurve() const
92
 
{
93
 
    return m_fadeCurve;
94
 
}
95
 
 
96
 
void VolumeFaderEffect::setFadeCurve(Phonon::VolumeFaderEffect::FadeCurve fadeCurve)
97
 
{
98
 
    m_fadeCurve = fadeCurve;
99
 
}
100
 
 
101
 
void VolumeFaderEffect::fadeTo(float targetVolume, int fadeTime)
102
 
{
103
 
    m_fadeToVolume = targetVolume;
104
 
    m_fadeDuration = fadeTime;
105
 
    m_fadeFromVolume = volume();
106
 
    m_fadeStartTime.start();
107
 
 
108
 
    if (m_fadeTimer)
109
 
        killTimer(m_fadeTimer);
110
 
    m_fadeTimer = startTimer(30);
111
 
}
112
 
 
113
 
void VolumeFaderEffect::updateFade()
114
 
{
115
 
    double currVal = 0.0;
116
 
    float step = float(m_fadeStartTime.elapsed()) / float(m_fadeDuration);
117
 
    if (step > 1){
118
 
        step = 1;
119
 
        if (m_fadeTimer) {
120
 
            killTimer(m_fadeTimer);
121
 
            m_fadeTimer = 0;
122
 
        }
123
 
    }
124
 
    // This is a very loose and interpretation of the API
125
 
    // But in fact when fading between arbitrary values, the decibel values make no sense
126
 
    // Note : seems like we will change the API to re-use names from QTimeline for this
127
 
    switch (fadeCurve()) {
128
 
        case Phonon::VolumeFaderEffect::Fade3Decibel: // Slow in the beginning
129
 
            currVal = step * step;
130
 
            break;
131
 
        case Phonon::VolumeFaderEffect::Fade6Decibel: // Linear fade
132
 
            currVal = step;
133
 
            break;
134
 
        case Phonon::VolumeFaderEffect::Fade9Decibel: // Fast in the beginning / Linear
135
 
            currVal = step * 0.5 + (1.0-(1.0-step)*(1.0-step)) * 0.5;
136
 
            break;
137
 
        case Phonon::VolumeFaderEffect::Fade12Decibel: // Fast in the beginning
138
 
            currVal = 1.0 - (1.0-step) * (1.0-step);
139
 
            break;
140
 
        default:
141
 
            break;
142
 
    }
143
 
    const double volume = (1.0 - currVal) * m_fadeFromVolume + currVal * m_fadeToVolume;
144
 
    setVolume(volume);
145
 
}
146
 
 
147
 
bool VolumeFaderEffect::event(QEvent *event)
148
 
{
149
 
    switch (event->type()){
150
 
        case QEvent::Timer:
151
 
        {
152
 
            QTimerEvent *timerEvent = static_cast<QTimerEvent *>(event);
153
 
            if (timerEvent->timerId() == m_fadeTimer)
154
 
                updateFade();
155
 
            break;
156
 
        }
157
 
        default:
158
 
            break;
159
 
    }
160
 
    return QObject::event(event);
161
 
}
162
 
 
163
 
}} //namespace Phonon::Gstreamer
164
 
#endif //QT_NO_PHONON_VOLUMEFADEREFFECT
165
 
QT_END_NAMESPACE
166
 
 
167
 
#include "moc_volumefadereffect.cpp"