summaryrefslogtreecommitdiffstats
path: root/src/plugins/pulseaudio
diff options
context:
space:
mode:
authorhawcroft <derick.hawcroft@nokia.com>2011-09-28 13:20:26 +1000
committerQt by Nokia <qt-info@nokia.com>2011-09-28 05:33:38 +0200
commita645b75e35b2d545d4bd5c9f592f4efc9c303a11 (patch)
treeb94edef32718aab8385fc49e23f87e7138974a90 /src/plugins/pulseaudio
parent788175b4f490303fc658b7565a658b4c37c56317 (diff)
Add QAudioOutput volume API and pulseaudio backend implementation.
Change-Id: I70784e8d17522a23f6467713d58384b30557694b Reviewed-on: http://codereview.qt-project.org/5663 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: derick hawcroft <derick.hawcroft@nokia.com>
Diffstat (limited to 'src/plugins/pulseaudio')
-rw-r--r--src/plugins/pulseaudio/qaudiooutput_pulse.cpp50
-rw-r--r--src/plugins/pulseaudio/qaudiooutput_pulse.h7
2 files changed, 56 insertions, 1 deletions
diff --git a/src/plugins/pulseaudio/qaudiooutput_pulse.cpp b/src/plugins/pulseaudio/qaudiooutput_pulse.cpp
index 927cbc791..b638d07fe 100644
--- a/src/plugins/pulseaudio/qaudiooutput_pulse.cpp
+++ b/src/plugins/pulseaudio/qaudiooutput_pulse.cpp
@@ -41,6 +41,7 @@
#include <QtCore/qcoreapplication.h>
#include <QtCore/qdebug.h>
+#include <QtCore/qmath.h>
#include "qaudiooutput_pulse.h"
#include "qaudiodeviceinfo_pulse.h"
@@ -150,6 +151,7 @@ QPulseAudioOutput::QPulseAudioOutput(const QByteArray &device)
, m_tickTimer(new QTimer(this))
, m_audioBuffer(0)
, m_resuming(false)
+ , m_volume(1.0)
{
connect(m_tickTimer, SIGNAL(timeout()), SLOT(userFeed()));
}
@@ -247,6 +249,7 @@ bool QPulseAudioOutput::open()
return false;
}
+ m_spec = spec;
m_totalTimeValue = 0;
m_elapsedTimeOffset = 0;
m_timeStamp.restart();
@@ -272,7 +275,16 @@ bool QPulseAudioOutput::open()
pa_stream_set_overflow_callback(m_stream, outputStreamOverflowCallback, this);
pa_stream_set_latency_update_callback(m_stream, outputStreamLatencyCallback, this);
- if (pa_stream_connect_playback(m_stream, m_device.data(), NULL, (pa_stream_flags_t)0, NULL, NULL) < 0) {
+ pa_volume_t paVolume;
+ if (qFuzzyCompare(m_volume, 0.0)) {
+ paVolume = PA_VOLUME_MUTED;
+ m_volume = 0.0;
+ } else {
+ paVolume = qFloor(m_volume * PA_VOLUME_NORM + 0.5);
+ }
+ pa_cvolume_set(&m_chVolume, m_spec.channels, paVolume);
+
+ if (pa_stream_connect_playback(m_stream, m_device.data(), NULL, (pa_stream_flags_t)0, &m_chVolume, NULL) < 0) {
qWarning() << "pa_stream_connect_playback() failed!";
return false;
}
@@ -568,6 +580,42 @@ qint64 OutputPrivate::writeData(const char *data, qint64 len)
return written;
}
+void QPulseAudioOutput::setVolume(qreal vol)
+{
+ if (vol >= 0.0 && vol <= 1.0) {
+ if (!qFuzzyCompare(m_volume, vol)) {
+ m_volume = vol;
+ if (m_opened) {
+ QPulseAudioEngine *pulseEngine = QPulseAudioEngine::instance();
+ pa_threaded_mainloop_lock(pulseEngine->mainloop());
+ pa_volume_t paVolume;
+ if (qFuzzyCompare(vol, 0.0)) {
+ pa_cvolume_mute(&m_chVolume, m_spec.channels);
+ m_volume = 0.0;
+ } else {
+ paVolume = qFloor(m_volume * PA_VOLUME_NORM + 0.5);
+ pa_cvolume_set(&m_chVolume, m_spec.channels, paVolume);
+ }
+ pa_operation *op = pa_context_set_sink_input_volume(pulseEngine->context(),
+ pa_stream_get_index(m_stream),
+ &m_chVolume,
+ NULL,
+ NULL);
+ if (op == NULL)
+ qWarning()<<"QAudioOutput: Failed to set volume";
+ else
+ pa_operation_unref(op);
+ pa_threaded_mainloop_unlock(pulseEngine->mainloop());
+ }
+ }
+ }
+}
+
+qreal QPulseAudioOutput::volume() const
+{
+ return m_volume;
+}
+
QT_END_NAMESPACE
#include "moc_qaudiooutput_pulse.cpp"
diff --git a/src/plugins/pulseaudio/qaudiooutput_pulse.h b/src/plugins/pulseaudio/qaudiooutput_pulse.h
index f6f6282db..884164e3c 100644
--- a/src/plugins/pulseaudio/qaudiooutput_pulse.h
+++ b/src/plugins/pulseaudio/qaudiooutput_pulse.h
@@ -95,6 +95,9 @@ public:
void setFormat(const QAudioFormat &format);
QAudioFormat format() const;
+ void setVolume(qreal volume);
+ qreal volume() const;
+
public:
void streamUnderflowCallback();
@@ -129,6 +132,10 @@ private:
QTime m_timeStamp;
qint64 m_elapsedTimeOffset;
bool m_resuming;
+
+ qreal m_volume;
+ pa_cvolume m_chVolume;
+ pa_sample_spec m_spec;
};
class OutputPrivate : public QIODevice