AppSrc与Playbin2的结合使用

前端之家收集整理的这篇文章主要介绍了AppSrc与Playbin2的结合使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

前面关于AppSrc的文章记录了使用AppSrc时,Pipeline的构建过程,这中间需要手动设置一些Element的属性。如果使用Playbin的话,可以省去这些过程。
Playbin支持URI解析,而AppSrc支持的URI格式为appsrc://。因此,只需要将Playbin的uri属性设置为appsrc://,则playbin就会自动查找到appsrc组件,并将其作为pipeline的source组件。对于AppSrc相关的signal的设置,只要在playbin提供的source-setup事件中处理即可。参考代码如下:

_pipeline   =   gst_element_factory_make( "playbin2","playbin" );
g_signal_connect( _pipeline,"source-setup",G_CALLBACK( setupSrc ),NULL );

AppSrc作为source组件,如果需要支持seek操作,需要设置其stream-type属性。该属性为枚举类型:

(0): stream           - GST_APP_STREAM_TYPE_STREAM
(1): seekable         - GST_APP_STREAM_TYPE_SEEKABLE
(2): random-access    - GST_APP_STREAM_TYPE_RANDOM_ACCESS

属性的设置可以在source-setup的处理函数中进行:

/*
 * ===  FUNCTION  ======================================================================
 *         Name:  setupSrc
 *  Description:
 * =====================================================================================
 */
static void setupSrc( GstElement * object,GstElement * arg0,gpointer user_data )
{
    gint64 _size;
    g_message( "%s",__func__ );
    fseek( fp,SEEK_END );

    _size   =   ftell( fp );
    g_object_set( arg0,"size",_size,NULL );
    fseek( fp,SEEK_SET );
    g_object_set( arg0,"stream-type",GST_APP_STREAM_TYPE_RANDOM_ACCESS,NULL );

    g_signal_connect ( arg0,"need-data",G_CALLBACK( _needData ),NULL );
    g_signal_connect ( arg0,"enough-data",G_CALLBACK( _enoughData ),"seek-data",G_CALLBACK( _seekData ),NULL );
}       /* -----  end of static function setupSrc  ----- */

附:
支持uri解析的element都会实现GstURIHandler接口,因此,查找gstreamer支持uri解析的element可以按如下方式执行(还不知道是否有更好的方法,用gst-inspect一个一个查太慢且容易出错):

$cd <source_of_gstreamer>
$grep get_protocols ./ -rnw --include=*.c

猜你在找的设计模式相关文章