2 * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
4 #include "emotion_gstreamer.h"
5 #include "emotion_gstreamer_pipeline.h"
8 static void dvd_pad_added_cb (GstElement *dvddemuxer,
12 static void dvd_no_more_pads_cb (GstElement *dvddemuxer,
15 static int no_more_pads = 0;
19 emotion_pipeline_dvd_build(void *video, const char *device)
21 GstElement *dvdreadsrc;
23 Emotion_Gstreamer_Video *ev;
25 ev = (Emotion_Gstreamer_Video *)video;
28 dvdreadsrc = gst_element_factory_make("dvdreadsrc", "src");
30 goto failure_dvdreadsrc;
32 g_object_set(G_OBJECT(dvdreadsrc), "device", device, NULL);
34 dvddemux = gst_element_factory_make("dvddemux", "dvddemux");
36 goto failure_dvddemux;
37 g_signal_connect(dvddemux, "pad-added",
38 G_CALLBACK(dvd_pad_added_cb), ev);
39 g_signal_connect(dvddemux, "no-more-pads",
40 G_CALLBACK(dvd_no_more_pads_cb), ev);
42 gst_bin_add_many(GST_BIN(ev->pipeline), dvdreadsrc, dvddemux, NULL);
43 if (!gst_element_link(dvdreadsrc, dvddemux))
46 if (!emotion_pipeline_pause(ev->pipeline))
47 goto failure_gstreamer_pause;
49 while (no_more_pads == 0)
55 /* We get the informations of streams */
56 ecore_list_first_goto(ev->video_sinks);
57 ecore_list_first_goto(ev->audio_sinks);
63 it = gst_element_iterate_src_pads(dvddemux);
64 while (gst_iterator_next(it, &data) == GST_ITERATOR_OK)
72 caps = gst_pad_get_caps(pad);
73 str = gst_caps_to_string(caps);
74 g_print("caps !! %s\n", str);
76 if (g_str_has_prefix(str, "video/mpeg"))
78 Emotion_Video_Sink *vsink;
82 vsink = (Emotion_Video_Sink *)ecore_list_next(ev->video_sinks);
83 sink_pad = gst_element_get_pad(gst_bin_get_by_name(GST_BIN(ev->pipeline), "mpeg2dec"), "src");
84 sink_caps = gst_pad_get_caps(sink_pad);
85 str = gst_caps_to_string(sink_caps);
86 g_print(" ** caps v !! %s\n", str);
88 emotion_video_sink_fill(vsink, sink_pad, sink_caps);
90 gst_caps_unref(sink_caps);
91 gst_object_unref(sink_pad);
94 else if (g_str_has_prefix(str, "audio/"))
96 Emotion_Audio_Sink *asink;
100 asink = (Emotion_Audio_Sink *)ecore_list_next(ev->audio_sinks);
101 sink_pad = gst_element_get_pad(gst_bin_get_by_name(GST_BIN(ev->pipeline), "a52dec"), "src");
102 sink_caps = gst_pad_get_caps(sink_pad);
104 emotion_audio_sink_fill(asink, sink_pad, sink_caps);
106 gst_caps_unref(caps);
108 gst_object_unref(pad);
110 gst_iterator_free(it);
113 /* The first vsink is a valid Emotion_Video_Sink * */
114 /* If no video stream is found, it's a visualisation sink */
116 Emotion_Video_Sink *vsink;
118 vsink = (Emotion_Video_Sink *)ecore_list_first_goto(ev->video_sinks);
119 if (vsink && vsink->sink)
121 g_object_set(G_OBJECT(vsink->sink), "sync", TRUE, NULL);
122 g_object_set(G_OBJECT(vsink->sink), "signal-handoffs", TRUE, NULL);
123 g_signal_connect(G_OBJECT(vsink->sink),
125 G_CALLBACK(cb_handoff), ev);
131 failure_gstreamer_pause:
133 gst_element_set_state(ev->pipeline, GST_STATE_NULL);
134 gst_bin_remove(GST_BIN(ev->pipeline), dvddemux);
136 gst_bin_remove(GST_BIN(ev->pipeline), dvdreadsrc);
143 dvd_pad_added_cb(GstElement *dvddemuxer,
147 Emotion_Gstreamer_Video *ev;
151 ev = (Emotion_Gstreamer_Video *)user_data;
152 caps = gst_pad_get_caps(GST_PAD(new_pad));
153 str = gst_caps_to_string(caps);
155 if (g_str_has_prefix(str, "video/mpeg"))
157 Emotion_Video_Sink *vsink;
162 vsink = (Emotion_Video_Sink *)malloc(sizeof(Emotion_Video_Sink));
164 if (!ecore_list_append(ev->video_sinks, vsink))
170 queue = gst_element_factory_make("queue", NULL);
171 decoder = gst_element_factory_make("mpeg2dec", "mpeg2dec");
172 vsink->sink = gst_element_factory_make("fakesink", "videosink");
173 gst_bin_add_many(GST_BIN(ev->pipeline), queue, decoder, vsink->sink, NULL);
174 gst_element_link(queue, decoder);
175 gst_element_link(decoder, vsink->sink);
176 videopad = gst_element_get_pad(queue, "sink");
177 gst_pad_link(GST_PAD(new_pad), videopad);
178 gst_object_unref(videopad);
179 if (ecore_list_count(ev->video_sinks) == 1)
181 ev->ratio = (double)vsink->width / (double)vsink->height;
183 gst_element_set_state(queue, GST_STATE_PAUSED);
184 gst_element_set_state(decoder, GST_STATE_PAUSED);
185 gst_element_set_state(vsink->sink, GST_STATE_PAUSED);
188 else if (g_str_has_prefix(str, "audio/"))
190 Emotion_Audio_Sink *asink;
194 GstElement *resample;
199 asink = (Emotion_Audio_Sink *)malloc(sizeof(Emotion_Audio_Sink));
201 if (!ecore_list_append(ev->audio_sinks, asink))
207 queue = gst_element_factory_make("queue", NULL);
208 decoder = gst_element_factory_make("a52dec", "a52dec");
209 conv = gst_element_factory_make("audioconvert", NULL);
210 resample = gst_element_factory_make("audioresample", NULL);
211 volume = gst_element_factory_make("volume", "volume");
212 g_object_get(G_OBJECT(volume), "volume", &vol, NULL);
213 ev->volume = vol / 10.0;
215 /* FIXME: must manage several audio streams */
216 asink->sink = gst_element_factory_make("fakesink", NULL);
218 gst_bin_add_many(GST_BIN(ev->pipeline),
219 queue, decoder, conv, resample, volume, asink->sink, NULL);
220 gst_element_link_many(queue, decoder, conv, resample, volume, asink->sink, NULL);
222 audiopad = gst_element_get_pad(queue, "sink");
223 gst_pad_link(GST_PAD(new_pad), audiopad);
224 gst_object_unref(audiopad);
226 gst_element_set_state(queue, GST_STATE_PAUSED);
227 gst_element_set_state(decoder, GST_STATE_PAUSED);
228 gst_element_set_state(conv, GST_STATE_PAUSED);
229 gst_element_set_state(resample, GST_STATE_PAUSED);
230 gst_element_set_state(volume, GST_STATE_PAUSED);
231 gst_element_set_state(asink->sink, GST_STATE_PAUSED);
236 dvd_no_more_pads_cb(GstElement *dvddemuxer,