'original' recording while playing

classic Classic list List threaded Threaded
2 messages Options
Reply | Threaded
Open this post in threaded view
|

'original' recording while playing

Julien Isorce
Hi,

I am facing to a problem that I am sure it's pretty common for some of you.
Giving an uri, I am using uridecodebin to automatically select/connect the source and the decoders.
Then I am usually connecting an identity element to grab frames for image processing purposes.
I am also recording the stream but I re-encode it because I need to record what I analysed. (It's not exactly what I analysed
but I can see jerks and image contents, black frames etc..).

Now I would like to save the original stream. I mean before decoding it.
Here are the steps:

- use uridecodebin
- in autoplug-continue callback, retrieve the decodebin2 element, get its sink pad and call gst_pad_set_blocked_async(TRUE)
on the peer pad.
- in the associated GstPadBlockCallback, unlink those two pads in order to just insert a tee element and relink them.
- then create and connect a queue2->filesink to this tee element
- unblock the pad
- set the newer elements (tee, queue2, filesink) to playing state

So before to be demuxed, the stream is pushed into a file.

*The first problem is that I do not know how to properly and automatically select the file extension (ogg, flv, mp4...)
Note that for now I am using the uri extension maybe there is a proper way to do that.
*The second problem is at pipeline shutdown because now just sending an eos event from the pipeline is not working (eos message never comes on the bus)
So it's due to the add of the branch tee->queue2->filesink.
I have to block the queue2 's source pad, and send an eos event from this filesink element, then unlink queue2, set queue2 and filesink to NULL state, and finally send an eos event from the pipeline. In order to be able to catch an eos message on the bus.

Well I am not sure this is the best way to record a stream without decoding it. I know that the stream should be remuxed in order to have the correct origin for the timetsamps, and to have the index correctly written for some containers.

So my 3 questions are:

-- Is this goal really too specific and not common to be done in this manually way each time someone wants to achieve it ?

--In the case there is not a more immediate way, could we imagine a filename property on uridecodebin for this goal ?

--If something like the following functions do not exsit yet, would it be usefull to add api to dynamically insert new elements between existing playing elements:
(I can read a lot of mail where the solution is block a pad, unlink, set state, insert, send event, unblock, etc...) ?

gst_element_insert_downstream_async(element, new_element, callback) would try to insert 'new_element' the closest possible to 'element' in the dwonstream way.
gst_element_insert_upstream_async(element, new_element, callback).
gst_element_insert_between_async(downstream_element, up_stream_element, new_element, callback)
(well maybe gst_bin_... would be more appropriate, but gst_element_link has those kind of bin considerations too)

Sincerely
Julien

------------------------------------------------------------------------------
This SF.net email is sponsored by Sprint
What will you do first with EVO, the first 4G phone?
Visit sprint.com/first -- http://p.sf.net/sfu/sprint-com-first
_______________________________________________
gstreamer-devel mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/gstreamer-devel
Reply | Threaded
Open this post in threaded view
|

'original' recording while playing

Julien Isorce
Hi,

I am facing to a problem that I am sure it's pretty common for some of you.
Giving an uri, I am using uridecodebin to automatically select/connect the source and the decoders.
Then I am usually connecting an identity element to grab frames for image processing purposes.
I am also recording the stream but I re-encode it because I need to record what I analysed. (It's not exactly what I analysed
but I can see jerks and image contents, black frames etc..).

Now I would like to save the original stream. I mean before decoding it.
Here are the steps:

- use uridecodebin
- in autoplug-continue callback, retrieve the decodebin2 element, get its sink pad and call gst_pad_set_blocked_async(TRUE)
on the peer pad.
- in the associated GstPadBlockCallback, unlink those two pads in order to just insert a tee element and relink them.
- then create and connect a queue2->filesink to this tee element
- unblock the pad
- set the newer elements (tee, queue2, filesink) to playing state

So before to be demuxed, the stream is pushed into a file.

*The first problem is that I do not know how to properly and automatically select the file extension (ogg, flv, mp4...)
Note that for now I am using the uri extension maybe there is a proper way to do that.
*The second problem is at pipeline shutdown because now just sending an eos event from the pipeline is not working (eos message never comes on the bus)
So it's due to the add of the branch tee->queue2->filesink.
I have to block the queue2 's source pad, and send an eos event from this filesink element, then unlink queue2, set queue2 and filesink to NULL state, and finally send an eos event from the pipeline. In order to be able to catch an eos message on the bus.

Well I am not sure this is the best way to record a stream without decoding it. I know that the stream should be remuxed in order to have the correct origin for the timetsamps, and to have the index correctly written for some containers.

So my 3 questions are:

-- Is this goal really too specific and not common to be done in this manually way each time someone wants to achieve it ?

--In the case there is not a more immediate way, could we imagine a filename property on uridecodebin for this goal ?

--If something like the following functions do not exsit yet, would it be usefull to add api to dynamically insert new elements between existing playing elements:
(I can read a lot of mail where the solution is block a pad, unlink, set state, insert, send event, unblock, etc...) ?

gst_element_insert_downstream_async(element, new_element, callback) would try to insert 'new_element' the closest possible to 'element' in the dwonstream way.
gst_element_insert_upstream_async(element, new_element, callback).
gst_element_insert_between_async(downstream_element, up_stream_element, new_element, callback)
(well maybe gst_bin_... would be more appropriate, but gst_element_link has those kind of bin considerations too)

Sincerely
Julien


------------------------------------------------------------------------------
This SF.net email is sponsored by Sprint
What will you do first with EVO, the first 4G phone?
Visit sprint.com/first -- http://p.sf.net/sfu/sprint-com-first
_______________________________________________
gstreamer-devel mailing list
[hidden email]
https://lists.sourceforge.net/lists/listinfo/gstreamer-devel