Commit 4fb068fc authored by Jacob Walser's avatar Jacob Walser

Make VideoReceiver members non-static

parent 1efd240d
...@@ -23,20 +23,13 @@ ...@@ -23,20 +23,13 @@
QGC_LOGGING_CATEGORY(VideoReceiverLog, "VideoReceiverLog") QGC_LOGGING_CATEGORY(VideoReceiverLog, "VideoReceiverLog")
VideoReceiver::Sink* VideoReceiver::_sink = NULL;
GstElement* VideoReceiver::_pipeline = NULL;
GstElement* VideoReceiver::_pipeline2 = NULL;
GstElement* VideoReceiver::_tee = NULL;
// -EOS has appeared on the bus of the temporary pipeline // -EOS has appeared on the bus of the temporary pipeline
// -At this point all of the recoring elements have been flushed, and the video file has been finalized // -At this point all of the recoring elements have been flushed, and the video file has been finalized
// -Now we can remove the temporary pipeline and its elements // -Now we can remove the temporary pipeline and its elements
#if defined(QGC_GST_STREAMING) #if defined(QGC_GST_STREAMING)
gboolean VideoReceiver::_eosCB(GstBus* bus, GstMessage* message, gpointer user_data) void VideoReceiver::_eosCB(GstMessage* message)
{ {
Q_UNUSED(bus); Q_UNUSED(message)
Q_UNUSED(message);
Q_UNUSED(user_data);
gst_bin_remove(GST_BIN(_pipeline2), _sink->queue); gst_bin_remove(GST_BIN(_pipeline2), _sink->queue);
gst_bin_remove(GST_BIN(_pipeline2), _sink->mux); gst_bin_remove(GST_BIN(_pipeline2), _sink->mux);
...@@ -56,7 +49,8 @@ gboolean VideoReceiver::_eosCB(GstBus* bus, GstMessage* message, gpointer user_d ...@@ -56,7 +49,8 @@ gboolean VideoReceiver::_eosCB(GstBus* bus, GstMessage* message, gpointer user_d
delete _sink; delete _sink;
_sink = NULL; _sink = NULL;
return true; _recording = false;
emit recordingChanged();
} }
#endif #endif
...@@ -65,15 +59,9 @@ gboolean VideoReceiver::_eosCB(GstBus* bus, GstMessage* message, gpointer user_d ...@@ -65,15 +59,9 @@ gboolean VideoReceiver::_eosCB(GstBus* bus, GstMessage* message, gpointer user_d
// -Setup watch and handler for EOS event on the temporary pipeline's bus // -Setup watch and handler for EOS event on the temporary pipeline's bus
// -Send an EOS event at the beginning of that pipeline and set up a callback for // -Send an EOS event at the beginning of that pipeline and set up a callback for
#if defined(QGC_GST_STREAMING) #if defined(QGC_GST_STREAMING)
GstPadProbeReturn VideoReceiver::_unlinkCB(GstPad* pad, GstPadProbeInfo* info, gpointer user_data) void VideoReceiver::_unlinkCB(GstPadProbeInfo* info)
{ {
Q_UNUSED(pad); Q_UNUSED(info)
Q_UNUSED(info);
Q_UNUSED(user_data);
// We will only execute once
if(!g_atomic_int_compare_and_exchange(&_sink->removing, FALSE, TRUE))
return GST_PAD_PROBE_OK;
// Also unlinks and unrefs // Also unlinks and unrefs
gst_bin_remove_many(GST_BIN(_pipeline), _sink->queue, _sink->mux, _sink->filesink, NULL); gst_bin_remove_many(GST_BIN(_pipeline), _sink->queue, _sink->mux, _sink->filesink, NULL);
...@@ -92,7 +80,7 @@ GstPadProbeReturn VideoReceiver::_unlinkCB(GstPad* pad, GstPadProbeInfo* info, g ...@@ -92,7 +80,7 @@ GstPadProbeReturn VideoReceiver::_unlinkCB(GstPad* pad, GstPadProbeInfo* info, g
// Add watch for EOS event // Add watch for EOS event
GstBus* bus = gst_pipeline_get_bus(GST_PIPELINE(_pipeline2)); GstBus* bus = gst_pipeline_get_bus(GST_PIPELINE(_pipeline2));
gst_bus_add_signal_watch(bus); gst_bus_add_signal_watch(bus);
g_signal_connect(bus, "message::eos", G_CALLBACK(_eosCB), NULL); g_signal_connect(bus, "message::eos", G_CALLBACK(_eosCallBack), this);
gst_object_unref(bus); gst_object_unref(bus);
if(gst_element_set_state(_pipeline2, GST_STATE_PLAYING) == GST_STATE_CHANGE_FAILURE) { if(gst_element_set_state(_pipeline2, GST_STATE_PLAYING) == GST_STATE_CHANGE_FAILURE) {
...@@ -104,8 +92,33 @@ GstPadProbeReturn VideoReceiver::_unlinkCB(GstPad* pad, GstPadProbeInfo* info, g ...@@ -104,8 +92,33 @@ GstPadProbeReturn VideoReceiver::_unlinkCB(GstPad* pad, GstPadProbeInfo* info, g
gst_pad_send_event(sinkpad, gst_event_new_eos()); gst_pad_send_event(sinkpad, gst_event_new_eos());
gst_object_unref(sinkpad); gst_object_unref(sinkpad);
}
#endif
#if defined(QGC_GST_STREAMING)
gboolean VideoReceiver::_eosCallBack(GstBus* bus, GstMessage* message, gpointer user_data)
{
Q_UNUSED(bus)
Q_ASSERT(message != NULL && user_data != NULL);
VideoReceiver* pThis = (VideoReceiver*)user_data;
pThis->_eosCB(message);
return FALSE;
}
#endif
#if defined(QGC_GST_STREAMING)
GstPadProbeReturn VideoReceiver::_unlinkCallBack(GstPad* pad, GstPadProbeInfo* info, gpointer user_data)
{
Q_UNUSED(pad);
Q_ASSERT(info != NULL && user_data != NULL);
VideoReceiver* pThis = (VideoReceiver*)user_data;
// We will only execute once
if(!g_atomic_int_compare_and_exchange(&pThis->_sink->removing, FALSE, TRUE))
return GST_PAD_PROBE_REMOVE;
pThis->_unlinkCB(info);
return GST_PAD_PROBE_REMOVE; return GST_PAD_PROBE_REMOVE;
} }
#endif #endif
// When we finish our pipeline will look like this: // When we finish our pipeline will look like this:
...@@ -140,6 +153,7 @@ void VideoReceiver::startRecording(void) ...@@ -140,6 +153,7 @@ void VideoReceiver::startRecording(void)
} else { } else {
fileName = _path + "/QGC-" + QDateTime::currentDateTime().toString("yyyy-MM-dd-hh:mm:ss") + ".mkv"; fileName = _path + "/QGC-" + QDateTime::currentDateTime().toString("yyyy-MM-dd-hh:mm:ss") + ".mkv";
} }
g_object_set(G_OBJECT(_sink->filesink), "location", qPrintable(fileName), NULL); g_object_set(G_OBJECT(_sink->filesink), "location", qPrintable(fileName), NULL);
qCDebug(VideoReceiverLog) << "New video file:" << fileName; qCDebug(VideoReceiverLog) << "New video file:" << fileName;
...@@ -172,9 +186,7 @@ void VideoReceiver::stopRecording(void) ...@@ -172,9 +186,7 @@ void VideoReceiver::stopRecording(void)
} }
// Wait for data block before unlinking // Wait for data block before unlinking
gst_pad_add_probe(_sink->teepad, GST_PAD_PROBE_TYPE_IDLE, _unlinkCB, _sink, NULL); gst_pad_add_probe(_sink->teepad, GST_PAD_PROBE_TYPE_IDLE, _unlinkCallBack, this, NULL);
_recording = false;
emit recordingChanged();
#endif #endif
} }
...@@ -183,6 +195,10 @@ VideoReceiver::VideoReceiver(QObject* parent) ...@@ -183,6 +195,10 @@ VideoReceiver::VideoReceiver(QObject* parent)
, _recording(false) , _recording(false)
, _streaming(false) , _streaming(false)
#if defined(QGC_GST_STREAMING) #if defined(QGC_GST_STREAMING)
, _sink(NULL)
, _tee(NULL)
, _pipeline(NULL)
, _pipeline2(NULL)
, _videoSink(NULL) , _videoSink(NULL)
, _socket(NULL) , _socket(NULL)
, _serverPresent(false) , _serverPresent(false)
......
...@@ -78,13 +78,15 @@ private: ...@@ -78,13 +78,15 @@ private:
bool _recording; bool _recording;
bool _streaming; bool _streaming;
static Sink* _sink; Sink* _sink;
static GstElement* _tee; GstElement* _tee;
void _onBusMessage(GstMessage* message); void _onBusMessage(GstMessage* message);
static gboolean _onBusMessage(GstBus* bus, GstMessage* msg, gpointer user_data); void _eosCB(GstMessage* message);
static gboolean _eosCB(GstBus* bus, GstMessage* message, gpointer user_data); void _unlinkCB(GstPadProbeInfo* info);
static GstPadProbeReturn _unlinkCB(GstPad* pad, GstPadProbeInfo* info, gpointer user_data); static gboolean _onBusMessage(GstBus* bus, GstMessage* message, gpointer user_data);
static gboolean _eosCallBack(GstBus* bus, GstMessage* message, gpointer user_data);
static GstPadProbeReturn _unlinkCallBack(GstPad* pad, GstPadProbeInfo* info, gpointer user_data);
#endif #endif
...@@ -92,8 +94,8 @@ private: ...@@ -92,8 +94,8 @@ private:
QString _path; QString _path;
#if defined(QGC_GST_STREAMING) #if defined(QGC_GST_STREAMING)
static GstElement* _pipeline; GstElement* _pipeline;
static GstElement* _pipeline2; GstElement* _pipeline2;
GstElement* _videoSink; GstElement* _videoSink;
#endif #endif
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment