1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-18 20:40:43 +01:00

Wait 2 seconds after the fadeout finished before destroying the pipeline, to allow for delays in the sound server/driver. Fixes issue #294.

This commit is contained in:
David Sansome 2010-05-15 17:55:36 +00:00
parent f7c08d375a
commit 694c5e9f9e
2 changed files with 30 additions and 2 deletions

View File

@ -20,6 +20,9 @@
#include <QDebug>
const int GstEnginePipeline::kGstStateTimeoutNanosecs = 10000000;
const int GstEnginePipeline::kFaderFudgeMsec = 2000;
GstEnginePipeline::GstEnginePipeline(GstEngine* engine)
: QObject(NULL),
engine_(engine),
@ -359,10 +362,26 @@ void GstEnginePipeline::StartFader(int duration_msec,
fader_ = new QTimeLine(duration_msec, this);
connect(fader_, SIGNAL(valueChanged(qreal)), SLOT(SetVolumeModifier(qreal)));
connect(fader_, SIGNAL(finished()), SIGNAL(FaderFinished()));
connect(fader_, SIGNAL(finished()), SLOT(FaderTimelineFinished()));
fader_->setDirection(direction);
fader_->setCurveShape(shape);
fader_->start();
SetVolumeModifier(fader_->currentValue());
}
void GstEnginePipeline::FaderTimelineFinished() {
// Wait a little while longer before emitting the finished signal (and
// probably distroying the pipeline) to account for delays in the audio
// server/driver.
fader_fudge_timer_.start(kFaderFudgeMsec, this);
}
void GstEnginePipeline::timerEvent(QTimerEvent* e) {
if (e->timerId() == fader_fudge_timer_.timerId()) {
emit FaderFinished();
return;
}
QObject::timerEvent(e);
}

View File

@ -20,6 +20,7 @@
#include <QObject>
#include <QUrl>
#include <QTimeLine>
#include <QBasicTimer>
#include <gst/gst.h>
@ -74,6 +75,9 @@ class GstEnginePipeline : public QObject {
void Error(const QString& message);
void FaderFinished();
protected:
void timerEvent(QTimerEvent *);
private:
// Static callbacks. The GstEnginePipeline instance is passed in the last
// argument.
@ -91,8 +95,12 @@ class GstEnginePipeline : public QObject {
void UpdateVolume();
bool ReplaceDecodeBin(const QUrl& url);
private slots:
void FaderTimelineFinished();
private:
static const int kGstStateTimeoutNanosecs = 10000000;
static const int kGstStateTimeoutNanosecs;
static const int kFaderFudgeMsec;
GstEngine* engine_;
@ -108,6 +116,7 @@ class GstEnginePipeline : public QObject {
qreal volume_modifier_;
QTimeLine* fader_;
QBasicTimer fader_fudge_timer_;
GstElement* pipeline_;