<div><br><font color="#800080">hi all<br> i have a trouble when i use gstreamer to develop a small project </font>for sending and receiving udp packets with rtp payloaded <br><br>sender------->server|---------------->receiver_1<br> |--------------->receiver_2<br>*****************************************************************<br>sender:<br>gst-launch -v gstrtpbin name=rtpbin \<br>filesrc location=filesrc location=/home/xuxin/desktop/g_p/a.avi ! decodebin name=dec \<br>dec. ! queue ! x264enc byte-stream=false ! rtph264pay ! rtpbin.send_rtp_sink_0 \<br>rtpbin.send_rtp_src_0 ! udpsink port=5000 host=172.21.29.177 name=vrtpsink \<br>dec. ! queue ! audioresample ! audioconvert ! alawenc ! rtppcmapay ! rtpbin.send_rtp_sink_1 \<br>rtpbin.send_rtp_src_1 ! udpsink port=5002 host=172.21.29.177 ts-offset=0 name=artpsink <br><br>Server( ip:172.21.29.177)<br>gst-launch -v gstrtpbin name=rtpbin latency=200 \<br>udpsrc caps="application/x-rtp,media=(string)video,clock-rate=(int)90000,encoding-name=(string)H264" port=5000 ! rtpbin.recv_rtp_sink_0 \<br>rtpbin. ! udpsink port=5000 host=224.0.0.1 sync=false ts-offset=0 \<br>udpsrc caps="application/x-rtp,media=(string)audio,clock-rate=(int)8000,encoding-name=(string)PCMA" port=5002 ! rtpbin.recv_rtp_sink_1 \<br>rtpbin. ! udpsink port=5002 host=224.0.0.1 sync=false ts-offset=0 <br><br>receiver (in multigroup)<br><br>gst-launch -v gstrtpbin name=rtpbin latency=200 \<br>udpsrc multigroup="224.0.0.1" caps="application/x-rtp,media=(string)video,clock-rate=(int)90000,encoding-name=(string)H264" port=5000 ! rtpbin.recv_rtp_sink_0 \<br>rtpbin. ! rtph264depay ! decodebin ! xvimagesink \<br>udpsrc multigroup="224.0.0.1" caps="application/x-rtp,media=(string)audio,clock-rate=(int)8000,encoding-name=(string)PCMA" port=5002 ! rtpbin.recv_rtp_sink_1 \<br>rtpbin. ! rtppcmadepay ! decodebin ! audioconvert ! audioresample ! alsasink <br>**********************************************************************<br><font color="#f00000"> then I write "Server" in C language</font> ,the code is showed below<br>#include <gst/gst.h><br>#include <glib.h><br>#include <unistd.h><br>#include <stdlib.h><br><br>static gboolean<br>bus_call (GstBus *bus,<br> GstMessage *msg,<br> gpointer data)<br>{<br> GMainLoop *loop = (GMainLoop *) data;<br> switch (GST_MESSAGE_TYPE (msg)) {<br> case GST_MESSAGE_EOS:<br> g_print ("End of stream\n");<br> g_main_loop_quit (loop);<br> break;<br> case GST_MESSAGE_ERROR: {<br> gchar *debug;<br> GError *error;<br> gst_message_parse_error (msg, &error, &debug);<br> g_free (debug);<br> g_printerr ("Error: %s\n", error->message);<br> g_error_free (error);<br> g_main_loop_quit (loop);<br> break;<br> }<br> default:<br> break;<br> }<br> return TRUE;<br>}<br><br>static void on_pad_added(GstElement *element, GstPad *pad, gpointer data)<br>{<br> GstPad *sinkpad;<br> GstElement *udpsink = (GstElement *)data;<br> <br> g_print("Dynamic pad created, linking demuxer/decoder\n");<br> sinkpad = gst_element_get_static_pad(udpsink, "sink");<br> gst_pad_link(pad, sinkpad);<br> gst_object_unref(sinkpad);<br>}<br><br>int main(int argc, char **argv)<br>{<br> GMainLoop *loop;<br> GstBus *bus;<br> GstPad *pad;<br> GstCaps *videocap, *audiocap;<br> GstElement *pipeline, *gstrtpbin, *udpsrc1, *udpsrc2,<br> *udpsink1, *udpsink2;<br> <br> gst_init(&argc, &argv);<br> loop = g_main_loop_new(NULL, FALSE);<br> <br> pipeline = gst_pipeline_new("server");<br> gstrtpbin = gst_element_factory_make("gstrtpbin", "gst_rtpbin");<br> udpsrc1 = gst_element_factory_make("udpsrc", "udpsrc1");<br> udpsrc2 = gst_element_factory_make("udpsrc", "udpsrc2");<br> udpsink1 = gst_element_factory_make("udpsink", "udpsink1");<br> udpsink2 = gst_element_factory_make("udpsink", "udpsink2");<br> <br> if (argc != 4) {<br> g_printerr("argument error");<br> return -1;<br> }<br> <br> bus = gst_pipeline_get_bus(GST_PIPELINE(pipeline));<br> gst_bus_add_watch(bus, bus_call, loop);<br> gst_object_unref(bus);<br> <br> videocap = gst_caps_new_simple("application/x-rtp", <br> "media", G_TYPE_STRING, "video",<br> "clock-rate", G_TYPE_LONG, 90000,<br> "encoding-name", G_TYPE_STRING, "H264", NULL);<br> <br> audiocap = gst_caps_new_simple("application/x-rtp",<br> "media", G_TYPE_STRING, "audio",<br> "clock-rate", G_TYPE_LONG, 8000,<br> "encoding-name", G_TYPE_STRING, "PCMA", NULL);<br> <br> g_object_set(G_OBJECT(udpsrc1), "caps", videocap, NULL);<br> g_object_set(G_OBJECT(udpsrc2), "caps", audiocap, NULL);<br> g_object_set(G_OBJECT(udpsrc1), "port", (gint)atoi(argv[1]), NULL);<br> g_object_set(G_OBJECT(udpsrc2), "port", (gint)atoi(argv[2]), NULL);<br> g_object_set(G_OBJECT(udpsink1), "port", (gint)atoi(argv[1]), NULL);<br> g_object_set(G_OBJECT(udpsink2), "port", (gint)atoi(argv[2]), NULL);<br> g_object_set(G_OBJECT(udpsink1), "host", argv[3], NULL);<br> g_object_set(G_OBJECT(udpsink2), "host", argv[3], NULL);<br> <br> gst_caps_unref(videocap);<br> gst_caps_unref(audiocap);<br> <br> gst_bin_add_many(GST_BIN(pipeline), udpsrc1, udpsrc2, gstrtpbin, udpsink1, udpsink2, NULL);<br> <br> pad = gst_element_get_request_pad(gstrtpbin, "recv_rtp_sink_0");<br> gst_pad_link(gst_element_get_pad(udpsrc1, "src"), pad);<br> <br> pad = gst_element_get_request_pad(gstrtpbin, "recv_rtp_sink_1");<br> gst_pad_link(gst_element_get_pad(udpsrc2, "src"), pad);<br> <br> g_signal_connect(gstrtpbin, "pad-added", G_CALLBACK(on_pad_added), udpsink1);<br> g_signal_connect(gstrtpbin, "pad_added", G_CALLBACK(on_pad_added), udpsink2);<br> <br> gst_element_set_state(pipeline, GST_STATE_PLAYING);<br> <br> g_print("Running...\n");<br> g_main_loop_run(loop);<br> <br> /* Out of the main loop, clean up nicely */<br> g_print("Returned, stopping playback\n");<br> gst_element_set_state(pipeline, GST_STATE_NULL);<br> <br> g_print("Deleting pipeline\n");<br> gst_object_unref(GST_OBJECT(pipeline));<br> <br> return 0;<br>}<br>*********************************************************************<br><font color="#f00000">when i run the server writed in c on my computer , Error: internal data flow error<br>when i run the server which is not writed in c , Error : internal streamer error clock problem. <br>additional debug info: gstbin.c(2240):gst_bin_do_latency_func() : failed to configure latency of 0:00:00:00000000</font><br> <br>can anybody help me ,thank you very much <br><br></div><br><!-- footer --><br><span title="neteasefooter"/><hr/>
<a href="http://512.mail.163.com/mailstamp/stamp/dz/activity.do?from=footer">穿越地震带 纪念汶川地震一周年</a>
</span>