summaryrefslogtreecommitdiffstats
path: root/src/gsttools/qgstreameraudioprobecontrol.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gsttools/qgstreameraudioprobecontrol.cpp')
-rw-r--r--src/gsttools/qgstreameraudioprobecontrol.cpp47
1 files changed, 32 insertions, 15 deletions
diff --git a/src/gsttools/qgstreameraudioprobecontrol.cpp b/src/gsttools/qgstreameraudioprobecontrol.cpp
index 3baca530f..9670d0f19 100644
--- a/src/gsttools/qgstreameraudioprobecontrol.cpp
+++ b/src/gsttools/qgstreameraudioprobecontrol.cpp
@@ -37,32 +37,48 @@
QGstreamerAudioProbeControl::QGstreamerAudioProbeControl(QObject *parent)
: QMediaAudioProbeControl(parent)
{
-
}
QGstreamerAudioProbeControl::~QGstreamerAudioProbeControl()
{
-
}
-void QGstreamerAudioProbeControl::bufferProbed(GstBuffer* buffer)
+void QGstreamerAudioProbeControl::probeCaps(GstCaps *caps)
{
- GstCaps* caps = gst_buffer_get_caps(buffer);
- if (!caps)
- return;
-
QAudioFormat format = QGstUtils::audioFormatForCaps(caps);
- gst_caps_unref(caps);
- if (!format.isValid())
- return;
- QAudioBuffer audioBuffer = QAudioBuffer(QByteArray((const char*)buffer->data, buffer->size), format);
+ QMutexLocker locker(&m_bufferMutex);
+ m_format = format;
+}
- {
- QMutexLocker locker(&m_bufferMutex);
- m_pendingBuffer = audioBuffer;
- QMetaObject::invokeMethod(this, "bufferProbed", Qt::QueuedConnection);
+bool QGstreamerAudioProbeControl::probeBuffer(GstBuffer *buffer)
+{
+ qint64 position = GST_BUFFER_TIMESTAMP(buffer);
+ position = position >= 0
+ ? position / G_GINT64_CONSTANT(1000) // microseconds
+ : -1;
+
+ QByteArray data;
+#if GST_CHECK_VERSION(1,0,0)
+ GstMapInfo info;
+ if (gst_buffer_map(buffer, &info, GST_MAP_READ)) {
+ data = QByteArray(reinterpret_cast<const char *>(info.data), info.size);
+ gst_buffer_unmap(buffer, &info);
+ } else {
+ return true;
+ }
+#else
+ data = QByteArray(reinterpret_cast<const char *>(buffer->data), buffer->size);
+#endif
+
+ QMutexLocker locker(&m_bufferMutex);
+ if (m_format.isValid()) {
+ if (!m_pendingBuffer.isValid())
+ QMetaObject::invokeMethod(this, "bufferProbed", Qt::QueuedConnection);
+ m_pendingBuffer = QAudioBuffer(data, m_format, position);
}
+
+ return true;
}
void QGstreamerAudioProbeControl::bufferProbed()
@@ -73,6 +89,7 @@ void QGstreamerAudioProbeControl::bufferProbed()
if (!m_pendingBuffer.isValid())
return;
audioBuffer = m_pendingBuffer;
+ m_pendingBuffer = QAudioBuffer();
}
emit audioBufferProbed(audioBuffer);
}