Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
4fb068fc
Commit
4fb068fc
authored
Jan 05, 2017
by
Jacob Walser
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make VideoReceiver members non-static
parent
1efd240d
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
49 additions
and
31 deletions
+49
-31
QGCToolbox.h
src/QGCToolbox.h
+1
-1
VideoReceiver.cc
src/VideoStreaming/VideoReceiver.cc
+38
-22
VideoReceiver.h
src/VideoStreaming/VideoReceiver.h
+10
-8
No files found.
src/QGCToolbox.h
View file @
4fb068fc
src/VideoStreaming/VideoReceiver.cc
View file @
4fb068fc
...
@@ -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
(
_eosC
B
),
NULL
);
g_signal_connect
(
bus
,
"message::eos"
,
G_CALLBACK
(
_eosC
allBack
),
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
)
...
...
src/VideoStreaming/VideoReceiver.h
View file @
4fb068fc
...
@@ -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
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment