2014-09-02 3 views
1

시작하려면 gstreamer의 초보자이며 비디오 데이터를 수신기로 보내고 수신기에서 재생하도록 디코딩하는 응용 프로그램을 개발하는 중입니다. 이를 위해 gstreamer를 사용하고 있습니다. 하지만 그 전에는 gstreamer를 이해하려고합니다.typefind를 사용한 Gstreamer 재생

나는 패드가 추가 된 신호를 생성하고 콜백 (call back)이 발생하는 독립형 코드를 가지고있다. 재생을 위해 I.MX6 보드를 사용하는 Iam.

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 

그러면 나는 demuxer와 필수 요소를 사용하여 코드를 완벽하게 가져 왔습니다.

여기에 "typefind = true"가 설정되어 있는데 코드에 가져 오는 방법을 모르겠습니다. 멀리 내가 CAP를 찾은 후 src 패드를 typefind 설정 이해합니다. 이것은 typefind에 대해 독립형을 사용하고있는 것입니다. "파이프 라인 상태 NULL에서 READY로 변경 :"

<?xml version="1.0"?> 
<Capabilities> 
<Caps1>video/mpegts, systemstream=(boolean)true, packetsize=(int)188</Caps1> 
</Capabilities> 

은 = 비디오/MPEGTS

TS 파일을 재생하는 내 gstreamer를 독립형을 실행하는 동안, 나는

는 아래의 메시지를 얻을 캡과 재생을 나던. 그냥 계속 달리고 있어요. 아래는 내 독립형 코드입니다.

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); 

} 

일부 코드가 감소했습니다. 여기서 누락 된 부분을 안내해 주시겠습니까? ... 코드에 유형을 가져 오는 방법을 모르겠습니다.

고마워요.

답변

0

마지막으로 typefind를 사용하지 않고이 문제를 해결했습니다.

이 게시물을 읽는 사람이 있다면,이 사람이 유용 할 수 있기를 바랍니다.

typefind가 필요하지 않은 것처럼 보입니다. 다음 코드를 사용했습니다.

GstCaps *caps; 
/* for mp4 playback use "video/quicktime", if it is ts file use "video/mpegts" , likewise corresponding to other files. You can find what to use as caps using gst-discoverer command for the file*/ 
caps = gst_caps_new_simple("video/quicktime",NULL); 
//After creating caps link using link_filtered to the demuxer 
if (!gst_element_link_filtered(data.source,data.demuxer,caps)) 
     g_printerr ("Elements could not be linked.\n"); 
       gst_object_unref (data.pipeline); 
       return -1; 
     } 
gst_caps_unref(caps); //unref after use, then the normal code continues with generating //pad-added signal. 

위의 코드는 truefind를 사용하여 대문자를 찾는 대신 수동으로 대문자를 설정합니다. 희망이 있으면 도움이됩니다.

관련 문제