fallbacksrc
Live source with uridecodebin3 or custom source, and fallback stream
Hierarchy
GObject ╰──GInitiallyUnowned ╰──GstObject ╰──GstElement ╰──GstBin ╰──fallbacksrc
Implemented interfaces
Factory details
Authors: – Sebastian Dröge
Classification: – Generic/Source
Rank – none
Plugin – fallbackswitch
Package – gst-plugin-fallbackswitch
Pad Templates
Signals
map-streams
GstStructure * map_streams_callback (GstElement * map, GstStructure * main_collection, GstStreamCollection * fallback_collection, GstStreamCollection * arg2, gpointer udata)
def map_streams_callback (map, main_collection, fallback_collection, arg2, udata):
#python callback for the 'map-streams' signal
function map_streams_callback(map: GstElement * map, main_collection: GstStructure * main_collection, fallback_collection: GstStreamCollection * fallback_collection, arg2: GstStreamCollection * arg2, udata: gpointer udata): {
// javascript callback for the 'map-streams' signal
}
The map contains the following structure: { "our_stream_id": { "main": "main_stream_id", "fallback": "fallback_stream_id" } }
Consumers should only change the fallback IDs and leave other fields untouched. If any other changes are detected, the new map will be ignored. If the current mapping is fine, the map should be returned as is.
This signal is emitted when either the fallback source posts a new stream collection, or the main source posts a new stream collection after the fallback source has posted one. Internally, streams will be relinked immediately after this signal is handled.
Parameters:
map
–
A GstStructure containing the map of our streams to main and fallback streams
main_collection
–
A GstStreamCollection posted by the main source
fallback_collection
–
A GstStreamCollection posted by the fallback source
arg2
–
udata
–
An updated GstStructure containing the mapping of our stream IDs to main and fallback stream IDs.
Flags: Run Last
update-uri
gchararray update_uri_callback (GstElement * param_0, gchararray arg0, gpointer udata)
def update_uri_callback (param_0, arg0, udata):
#python callback for the 'update-uri' signal
function update_uri_callback(param_0: GstElement * param_0, arg0: gchararray arg0, udata: gpointer udata): {
// javascript callback for the 'update-uri' signal
}
Parameters:
param_0
–
arg0
–
udata
–
Flags: Run Last
Action Signals
unblock
g_signal_emit_by_name (param_0, "unblock");
ret = param_0.emit ("unblock")
let ret = param_0.emit ("unblock");
Parameters:
Properties
buffer-duration
“buffer-duration” gint64
Buffer duration when buffering streams (-1 default value)
Flags : Read / Write
Default value : 18446744073709551615
enable-audio
“enable-audio” gboolean
Enable the audio stream, this will output silence if there's no audio in the configured URI
Flags : Read / Write
Default value : true
enable-video
“enable-video” gboolean
Enable the video stream, this will output black or the fallback video if there's no video in the configured URI
Flags : Read / Write
Default value : true
fallback-audio-caps
“fallback-audio-caps” GstCaps *
Raw audio caps for fallback stream
Flags : Read / Write
Default value :
ANY
fallback-uri
“fallback-uri” gchararray
Fallback URI to use for video in case the main stream doesn't work
Flags : Read / Write
Default value : NULL
fallback-video-caps
“fallback-video-caps” GstCaps *
Raw video caps for fallback stream
Flags : Read / Write
Default value :
ANY
immediate-fallback
“immediate-fallback” gboolean
Forward the fallback streams immediately at startup, when the primary streams are slow to start up and immediate output is required
Flags : Read / Write
Default value : false
manual-unblock
“manual-unblock” gboolean
When enabled, the application must call the unblock signal, except for live streams
Flags : Read / Write
Default value : false
min-latency
“min-latency” guint64
When the main source has a higher latency than the fallback source this allows to configure a minimum latency that would be configured if initially the fallback is enabled
Flags : Read / Write
Default value : 0
restart-on-eos
“restart-on-eos” gboolean
Restart source on EOS
Flags : Read / Write
Default value : false
restart-timeout
“restart-timeout” guint64
Timeout for restarting an active source
Flags : Read / Write
Default value : 5000000000
retry-timeout
“retry-timeout” guint64
Timeout for stopping after repeated failure
Flags : Read / Write
Default value : 60000000000
statistics
“statistics” GstStructure *
Various statistics
Flags : Read
Default value :
application/x-fallbacksrc-stats, num-retry=(guint64)0, num-fallback-retry=(guint64)0, last-retry-reason=(GstFallbackSourceRetryReason)none, last-fallback-retry-reason=(GstFallbackSourceRetryReason)none, buffering-percent=(int)100, fallback-buffering-percent=(int)100;
status
“status” Fallback-source-status *
Current source status
Flags : Read
Default value : stopped (0)
timeout
“timeout” guint64
Timeout for switching to the fallback URI
Flags : Read / Write
Default value : 5000000000
Named constants
Fallback-source-status
Members
stopped
(0) – Stopped
buffering
(1) – Buffering
retrying
(2) – Retrying
running
(3) – Running
The results of the search are