首先,我只是gstreamer的初學者,我正在開發一個應用程序,它將視頻數據發送給監聽器,監聽器將其解碼並播放。爲此我正在使用gstreamer。 但之前,我試圖瞭解gstreamer。使用typefind播放Gstreamer
我有一個獨立的代碼,它產生一個pad-added信號並且回叫被打。Iam使用I.MX6板進行播放。
我用gst-launch使用下面的命令播放「ts文件和mp4文件」,它可以工作。
gst-launch-0.10 filesrc location=/opt/zu/test/stream2.ts typefind=true ! aiurdemux name=demux demux. ! queue ! beepdec ! audioconvert ! autoaudiosink demux. ! queue ! vpudec! mfw_v4lsink
然後我把它帶入代碼,完美地使用了分流器和所需的元件。
這裏我發現設置了「typefind = true」,我不確定如何將它帶入代碼。據我所知,typefind在找到CAP後設置了src焊盤。 這就是我使用獨立的typefind。
<?xml version="1.0"?>
<Capabilities>
<Caps1>video/mpegts, systemstream=(boolean)true, packetsize=(int)188</Caps1>
</Capabilities>
上限=視頻/ MPEGTS
在運行我的GStreamer獨立播放TS文件,我得到了以下信息
「管道狀態改變從NULL到READY:」 和它不播放。它只是繼續運行。以下是我的獨立代碼
data.source = gst_element_factory_make ("filesrc", "source");
g_object_set (data.source, "location", argv[1], NULL);
data.typefind = gst_element_factory_make ("typefind", "typefinder");
data.demuxer = gst_element_factory_make ("aiurdemux", "demuxer");
data.audioqueue = gst_element_factory_make("queue","audioqueue");
data.videoqueue = gst_element_factory_make("queue","videoqueue");
data.audio_decoder = gst_element_factory_make ("beepdec", "audio_decoder");
data.audio_convert = gst_element_factory_make ("audioconvert", "audio_convert");
data.audio_sink = gst_element_factory_make ("autoaudiosink", "audio_sink");
data.video_decoder = gst_element_factory_make("vpudec","video_decoder");
data.video_sink = gst_element_factory_make("mfw_v4lsink","video_sink");
if (!gst_element_link(data.source,data.demuxer)) {
g_printerr ("Elements could not be linked.\n");
gst_object_unref (data.pipeline);
return -1;
}
if (!gst_element_link_many (data.audioqueue,data.audio_decoder,data.audio_convert, data.audio_sink,NULL)) {
g_printerr (" audio Elements could not be linked.\n");
gst_object_unref (data.pipeline);
return -1;
}
if (!gst_element_link_many(data.videoqueue,data.video_decoder, data.video_sink,NULL)) {
g_printerr("video Elements could not be linked.\n");
gst_object_unref(data.pipeline);
return -1;
}
//g_object_set (data.source, "location", argv[1], NULL);
g_signal_connect (data.demuxer, "pad-added", G_CALLBACK (pad_added_handler), &data);
/* Start playing */
// CALLBACK FUNCTION
static void pad_added_handler (GstElement *src, GstPad *new_pad, CustomData *data) {
g_print("Inside the pad_added_handler method \n");
printf("Inside the pad_added_handler method \n");
GstPad *sink_pad_audio = gst_element_get_static_pad (data->audioqueue, "sink");
GstPad *sink_pad_video = gst_element_get_static_pad (data->videoqueue, "sink");
GstPadLinkReturn ret;
GstCaps *new_pad_caps = NULL;
GstStructure *new_pad_struct = NULL;
const gchar *new_pad_type = NULL;
g_print ("Received new pad '%s' from '%s':\n", GST_PAD_NAME (new_pad), GST_ELEMENT_NAME (src));
new_pad_caps = gst_pad_get_caps (new_pad);
new_pad_struct = gst_caps_get_structure (new_pad_caps, 0);
new_pad_type = gst_structure_get_name (new_pad_struct);
if (g_str_has_prefix (new_pad_type,/*"audio/x-vorbis"*/ "audio/mpeg"))
{
ret = gst_pad_link (new_pad, sink_pad_audio);
if (GST_PAD_LINK_FAILED (ret))
{
g_print (" Type is '%s' but link failed.\n", new_pad_type);
}
else
{
g_print (" Link succeeded (type '%s').\n", new_pad_type);
}
}
//else if (g_str_has_prefix (new_pad_type, /*"video/x-theora"*/"video/x-h264"))
else if (g_str_has_prefix (new_pad_type, /*"video/x-theora"*/"video/mpegts"))
{
ret = gst_pad_link (new_pad, sink_pad_video);
if (GST_PAD_LINK_FAILED (ret))
{
g_print (" Type is '%s' but link failed.\n", new_pad_type);
}
else
{
g_print (" Link succeeded (type '%s').\n", new_pad_type);
}
}
else {
g_print (" It has type '%s' which is not raw audio. Ignoring.\n", new_pad_type);
goto exit;
}
exit:
if (new_pad_caps != NULL)
gst_caps_unref (new_pad_caps);
gst_object_unref (sink_pad_audio);
gst_object_unref (sink_pad_video);
}
我減少了一些代碼。你能指導Iam在這裏失蹤嗎?.. Iam不知道如何將類型查找帶入代碼。
謝謝