Some small fixes.

Original commit message from CVS:
Some small fixes.
This commit is contained in:
Wim Taymans 2001-06-27 20:20:07 +00:00
parent a8fd594d6b
commit 11f77f27f9
2 changed files with 93 additions and 109 deletions

View file

@ -16,6 +16,7 @@ main (int argc,char *argv[])
GstElement *src; GstElement *src;
GstElement *dvdec; GstElement *dvdec;
//GstElement *cspace; //GstElement *cspace;
GstElement *deint;
GstElement *videosink; GstElement *videosink;
GtkWidget *appwindow; GtkWidget *appwindow;
@ -40,6 +41,7 @@ main (int argc,char *argv[])
dvdec = gst_elementfactory_make ("dvdec", "decoder"); dvdec = gst_elementfactory_make ("dvdec", "decoder");
if (!dvdec) fprintf(stderr,"no dvdec\n"),exit(1); if (!dvdec) fprintf(stderr,"no dvdec\n"),exit(1);
// cspace = gst_elementfactory_make ("colorspace", "cspace"); // cspace = gst_elementfactory_make ("colorspace", "cspace");
deint = gst_elementfactory_make ("deinterlace", "deinterlace");
videosink = gst_elementfactory_make ("xvideosink", "videosink"); videosink = gst_elementfactory_make ("xvideosink", "videosink");
if (!videosink) fprintf(stderr,"no dvdec\n"),exit(1); if (!videosink) fprintf(stderr,"no dvdec\n"),exit(1);
gtk_object_set(GTK_OBJECT(videosink),"width",720,"height",576,NULL); gtk_object_set(GTK_OBJECT(videosink),"width",720,"height",576,NULL);
@ -52,7 +54,8 @@ main (int argc,char *argv[])
gst_element_connect(src,"src",dvdec,"sink"); gst_element_connect(src,"src",dvdec,"sink");
// gst_element_connect(cspace,"src",videosink,"sink"); // gst_element_connect(cspace,"src",videosink,"sink");
// gst_element_connect(dvdec,"video",cspace,"sink"); // gst_element_connect(dvdec,"video",cspace,"sink");
gst_element_connect(dvdec,"video",videosink,"sink"); gst_element_connect(dvdec,"video",deint,"sink");
gst_element_connect(deint,"src",videosink,"sink");
appwindow = gnome_app_new("Videotest","Videotest"); appwindow = gnome_app_new("Videotest","Videotest");

View file

@ -9,12 +9,16 @@
GstElement *mux; GstElement *mux;
GstElement *merge_subtitles; GstElement *merge_subtitles;
void eof(GstElement *src) { void
eof (GstElement *src)
{
g_print("have eos, quitting\n"); g_print("have eos, quitting\n");
exit(0); exit(0);
} }
void frame_encoded(GstElement *element, gint framenum, gpointer data) { void
frame_encoded (GstElement *element, gint framenum, gpointer data)
{
gulong frame_size; gulong frame_size;
static gulong total = 0; static gulong total = 0;
@ -25,8 +29,10 @@ void frame_encoded(GstElement *element, gint framenum, gpointer data) {
g_print("encoded frame %d %ld %ld\n", framenum, frame_size, total/(framenum+1)); g_print("encoded frame %d %ld %ld\n", framenum, frame_size, total/(framenum+1));
} }
void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) { void
GstElement *parse_audio, *parse_video, *decode, *decode_video, *play, *encode, *audio_resample; mp2tomp1_new_pad (GstElement *parser,GstPad *pad, GstElement *pipeline)
{
GstElement *parse_audio, *decode, *decode_video, *play, *encode, *audio_resample;
GstElement *smooth, *median; GstElement *smooth, *median;
GstElement *audio_queue, *video_queue; GstElement *audio_queue, *video_queue;
GstElement *audio_thread, *video_thread; GstElement *audio_thread, *video_thread;
@ -36,12 +42,9 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
gst_element_set_state(GST_ELEMENT(pipeline),GST_STATE_PAUSED); gst_element_set_state(GST_ELEMENT(pipeline),GST_STATE_PAUSED);
// connect to audio pad // connect to audio pad
if (0) { if (strncmp (gst_pad_get_name (pad), "private_stream_1.0", 18) == 0) {
//if (strncmp(gst_pad_get_name(pad), "private_stream_1.0", 18) == 0) { GstPad *newpad;
gst_plugin_load("ac3parse");
gst_plugin_load("ac3dec");
gst_plugin_load("audioscale");
gst_plugin_load("mpegaudio");
// construct internal pipeline elements // construct internal pipeline elements
parse_audio = gst_elementfactory_make("ac3parse","parse_audio"); parse_audio = gst_elementfactory_make("ac3parse","parse_audio");
g_return_if_fail(parse_audio != NULL); g_return_if_fail(parse_audio != NULL);
@ -53,31 +56,25 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
g_object_set(G_OBJECT(audio_resample),"frequency", 44100, NULL); g_object_set(G_OBJECT(audio_resample),"frequency", 44100, NULL);
audio_encode = gst_elementfactory_make("mpegaudio","audio_encode"); audio_encode = gst_elementfactory_make("mpegaudio","audio_encode");
//audio_encode = gst_elementfactory_make("pipefilter","audio_encode");
g_return_if_fail(audio_encode != NULL); g_return_if_fail(audio_encode != NULL);
//g_object_set(G_OBJECT(audio_encode),"command", "lame -x - -", NULL);
// create the thread and pack stuff into it // create the thread and pack stuff into it
audio_thread = gst_thread_new("audio_thread"); audio_thread = gst_thread_new("audio_thread");
g_return_if_fail(audio_thread != NULL); g_return_if_fail(audio_thread != NULL);
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(parse_audio));
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(decode)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(decode));
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(audio_resample)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(audio_resample));
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(audio_encode)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(audio_encode));
g_object_set(G_OBJECT(mux),"audio","00",NULL); newpad = gst_element_request_pad_by_name (mux, "audio_[00-08]");
g_assert (newpad != NULL);
// set up pad connections // set up pad connections
gst_element_add_ghost_pad(GST_ELEMENT(audio_thread), gst_element_add_ghost_pad(GST_ELEMENT(audio_thread),
gst_element_get_pad(parse_audio,"sink"),"sink"); gst_element_get_pad(decode, "sink"), "sink");
gst_pad_connect(gst_element_get_pad(parse_audio,"src"), gst_element_connect (decode, "src", audio_resample, "sink");
gst_element_get_pad(decode,"sink")); gst_element_connect (audio_resample, "src", audio_encode, "sink");
gst_pad_connect(gst_element_get_pad(decode,"src"), gst_pad_connect (gst_element_get_pad (audio_encode, "src"), newpad);
gst_element_get_pad(audio_resample,"sink"));
gst_pad_connect(gst_element_get_pad(audio_resample,"src"),
gst_element_get_pad(audio_encode,"sink"));
gst_pad_connect(gst_element_get_pad(audio_encode,"src"),
gst_element_get_pad(mux,"audio_00"));
// construct queue and connect everything in the main pipelie // construct queue and connect everything in the main pipelie
audio_queue = gst_elementfactory_make("queue","audio_queue"); audio_queue = gst_elementfactory_make("queue","audio_queue");
@ -97,8 +94,6 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
gst_pad_connect(pad, gst_pad_connect(pad,
gst_element_get_pad(merge_subtitles,"subtitle")); gst_element_get_pad(merge_subtitles,"subtitle"));
} else if (strncmp(gst_pad_get_name(pad), "audio_", 6) == 0) { } else if (strncmp(gst_pad_get_name(pad), "audio_", 6) == 0) {
gst_plugin_load("mp3parse");
gst_plugin_load("mpg123");
// construct internal pipeline elements // construct internal pipeline elements
parse_audio = gst_elementfactory_make("mp3parse","parse_audio"); parse_audio = gst_elementfactory_make("mp3parse","parse_audio");
g_return_if_fail(parse_audio != NULL); g_return_if_fail(parse_audio != NULL);
@ -110,18 +105,16 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
// create the thread and pack stuff into it // create the thread and pack stuff into it
audio_thread = gst_thread_new("audio_thread"); audio_thread = gst_thread_new("audio_thread");
g_return_if_fail(audio_thread != NULL); g_return_if_fail(audio_thread != NULL);
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(parse_audio)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(parse_audio));
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(decode)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(decode));
gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(play)); gst_bin_add(GST_BIN(audio_thread),GST_ELEMENT(play));
// set up pad connections // set up pad connections
gst_element_add_ghost_pad(GST_ELEMENT(audio_thread), gst_element_add_ghost_pad(GST_ELEMENT(audio_thread),
gst_element_get_pad(parse_audio,"sink"),"sink"); gst_element_get_pad(parse_audio,"sink"),"sink");
gst_pad_connect(gst_element_get_pad(parse_audio,"src"), gst_element_connect (parse_audio, "src", decode, "sink");
gst_element_get_pad(decode,"sink")); gst_element_connect (decode, "src", play, "sink");
gst_pad_connect(gst_element_get_pad(decode,"src"),
gst_element_get_pad(play,"sink"));
// construct queue and connect everything in the main pipelie // construct queue and connect everything in the main pipelie
audio_queue = gst_elementfactory_make("queue","audio_queue"); audio_queue = gst_elementfactory_make("queue","audio_queue");
@ -138,20 +131,10 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
g_print("setting to READY state\n"); g_print("setting to READY state\n");
gst_element_set_state(GST_ELEMENT(audio_thread),GST_STATE_READY); gst_element_set_state(GST_ELEMENT(audio_thread),GST_STATE_READY);
} else if (strncmp(gst_pad_get_name(pad), "video_", 6) == 0) { } else if (strncmp(gst_pad_get_name(pad), "video_", 6) == 0) {
//} else if (0) { GstPad *newpad;
gst_plugin_load("mp1videoparse");
gst_plugin_load("mpeg2play");
gst_plugin_load("mpeg2subt");
gst_plugin_load("smooth");
gst_plugin_load("median");
gst_plugin_load("videoscale");
gst_plugin_load("wincodec");
//gst_plugin_load("mpeg1encoder");
// construct internal pipeline elements // construct internal pipeline elements
parse_video = gst_elementfactory_make("mp1videoparse","parse_video"); decode_video = gst_elementfactory_make("mpeg2dec","decode_video");
g_return_if_fail(parse_video != NULL);
decode_video = gst_elementfactory_make("mpeg2play","decode_video");
g_return_if_fail(decode_video != NULL); g_return_if_fail(decode_video != NULL);
merge_subtitles = gst_elementfactory_make("mpeg2subt","merge_subtitles"); merge_subtitles = gst_elementfactory_make("mpeg2subt","merge_subtitles");
g_return_if_fail(merge_subtitles != NULL); g_return_if_fail(merge_subtitles != NULL);
@ -177,36 +160,33 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
//encode = gst_elementfactory_make("mpeg1encoder","encode"); //encode = gst_elementfactory_make("mpeg1encoder","encode");
//g_object_set(G_OBJECT(show),"width",640, "height", 480,NULL); //g_object_set(G_OBJECT(show),"width",640, "height", 480,NULL);
g_object_set(G_OBJECT(mux),"video","00:DIV3",NULL); newpad = gst_element_request_pad_by_name (mux, "video_[00-08]");
g_assert (newpad != NULL);
// create the thread and pack stuff into it // create the thread and pack stuff into it
video_thread = gst_thread_new("video_thread"); video_thread = gst_thread_new ("video_thread");
g_return_if_fail(video_thread != NULL); g_return_if_fail (video_thread != NULL);
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(parse_video)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (decode_video));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(decode_video)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (merge_subtitles));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(merge_subtitles)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (median));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(median)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (smooth));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(smooth)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (videoscale));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(videoscale)); gst_bin_add (GST_BIN (video_thread), GST_ELEMENT (encode));
gst_bin_add(GST_BIN(video_thread),GST_ELEMENT(encode));
// set up pad connections // set up pad connections
gst_element_add_ghost_pad(GST_ELEMENT(video_thread), gst_element_add_ghost_pad (GST_ELEMENT (video_thread),
gst_element_get_pad(parse_video,"sink"),"sink"); gst_element_get_pad (decode_video, "sink"), "sink");
gst_pad_connect(gst_element_get_pad(parse_video,"src"), gst_pad_connect (gst_element_get_pad (decode_video, "src"),
gst_element_get_pad(decode_video,"sink")); gst_element_get_pad (median, "sink"));
gst_pad_connect(gst_element_get_pad(decode_video,"src"), gst_pad_connect (gst_element_get_pad (median, "src"),
gst_element_get_pad(median,"sink")); gst_element_get_pad (merge_subtitles, "video"));
gst_pad_connect(gst_element_get_pad(median,"src"), gst_pad_connect (gst_element_get_pad (merge_subtitles, "src"),
gst_element_get_pad(merge_subtitles,"video")); gst_element_get_pad (videoscale, "sink"));
gst_pad_connect(gst_element_get_pad(merge_subtitles,"src"), gst_pad_connect (gst_element_get_pad (videoscale, "src"),
gst_element_get_pad(videoscale,"sink")); gst_element_get_pad (smooth, "sink"));
gst_pad_connect(gst_element_get_pad(videoscale,"src"), gst_pad_connect (gst_element_get_pad (smooth, "src"),
gst_element_get_pad(smooth,"sink")); gst_element_get_pad (encode, "sink"));
gst_pad_connect(gst_element_get_pad(smooth,"src"), gst_pad_connect (gst_element_get_pad (encode, "src"), newpad);
gst_element_get_pad(encode,"sink"));
gst_pad_connect(gst_element_get_pad(encode,"src"),
gst_element_get_pad(mux,"video_00"));
// construct queue and connect everything in the main pipeline // construct queue and connect everything in the main pipeline
video_queue = gst_elementfactory_make("queue","video_queue"); video_queue = gst_elementfactory_make("queue","video_queue");
@ -224,66 +204,67 @@ void mp2tomp1(GstElement *parser,GstPad *pad, GstElement *pipeline) {
gst_element_set_state(GST_ELEMENT(video_thread),GST_STATE_READY); gst_element_set_state(GST_ELEMENT(video_thread),GST_STATE_READY);
} }
g_print("\n"); g_print("\n");
gst_element_set_state(GST_ELEMENT(pipeline),GST_STATE_PLAYING); gst_element_set_state (GST_ELEMENT (pipeline), GST_STATE_PLAYING);
} }
int main(int argc,char *argv[]) { int
main (int argc,char *argv[])
{
GstElement *pipeline, *src, *parse; GstElement *pipeline, *src, *parse;
GstElement *fdsink; GstElement *fdsink;
GstElementFactory *fdsinkfactory;
int fd; int fd;
g_print("have %d args\n",argc); g_print ("have %d args\n", argc);
gst_init(&argc,&argv); gst_init (&argc ,&argv);
gst_plugin_load("mpeg2parse");
gst_plugin_load("aviencoder");
pipeline = gst_pipeline_new("pipeline"); pipeline = gst_pipeline_new ("pipeline");
g_return_val_if_fail(pipeline != NULL, -1); g_return_val_if_fail (pipeline != NULL, -1);
if (strstr(argv[1],"video_ts")) { /* create an input element */
src = gst_elementfactory_make("dvdsrc","src"); if (strstr (argv[1], "video_ts")) {
g_print("using DVD source\n"); src = gst_elementfactory_make ("dvdsrc", "src");
} else g_print ("using DVD source\n");
src = gst_elementfactory_make("disksrc","src"); } else {
src = gst_elementfactory_make ("disksrc", "src");
}
g_return_val_if_fail (src != NULL, -1);
gtk_object_set (GTK_OBJECT (src), "location", argv[1], NULL);
g_print ("should be using file '%s'\n", argv[1]);
g_return_val_if_fail(src != NULL, -1);
g_object_set(G_OBJECT(src),"location",argv[1],NULL);
g_print("should be using file '%s'\n",argv[1]);
g_print("should be using output file '%s'\n",argv[2]); g_print ("should be using output file '%s'\n", argv[2]);
parse = gst_elementfactory_make("mpeg2parse","parse"); /* the parser */
g_return_val_if_fail(parse != NULL, -1); parse = gst_elementfactory_make ("mpeg2parse", "parse");
g_return_val_if_fail (parse != NULL, -1);
mux = gst_elementfactory_make("aviencoder","mux"); /* the muxer */
g_return_val_if_fail(mux != NULL, -1); mux = gst_elementfactory_make ("avimux", "mux");
fd = open(argv[2],O_CREAT|O_RDWR|O_TRUNC, S_IREAD|S_IWRITE); g_return_val_if_fail (mux != NULL, -1);
fdsinkfactory = gst_elementfactory_find("fdsink");
g_return_val_if_fail(fdsinkfactory != NULL, -1);
fdsink = gst_elementfactory_create(fdsinkfactory,"fdsink");
g_return_val_if_fail(fdsink != NULL, -1);
g_object_set(G_OBJECT(fdsink),"fd",fd,NULL);
gst_bin_add(GST_BIN(pipeline),GST_ELEMENT(src)); /* create the output sink */
gst_bin_add(GST_BIN(pipeline),GST_ELEMENT(parse)); fd = open (argv[2], O_CREAT|O_RDWR|O_TRUNC, S_IREAD|S_IWRITE);
gst_bin_add(GST_BIN(pipeline),GST_ELEMENT(mux)); fdsink = gst_elementfactory_make ("fdsink", "fdsink");
gst_bin_add(GST_BIN(pipeline),GST_ELEMENT(fdsink)); g_return_val_if_fail (fdsink != NULL, -1);
gtk_object_set (GTK_OBJECT (fdsink), "fd", fd, NULL);
g_signal_connectc(G_OBJECT(parse),"new_pad",mp2tomp1, pipeline, FALSE); gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (src));
gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (parse));
gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (mux));
gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (fdsink));
g_signal_connectc(G_OBJECT(src),"eos",G_CALLBACK(eof),NULL, FALSE); gtk_signal_connect (GTK_OBJECT (parse), "new_pad", mp2tomp1_new_pad, pipeline);
gst_pad_connect(gst_element_get_pad(src,"src"), gtk_signal_connect (GTK_OBJECT (src), "eos", GTK_SIGNAL_FUNC (eof), NULL);
gst_element_get_pad(parse,"sink"));
gst_pad_connect(gst_element_get_pad(mux,"src"), gst_element_connect (src, "src", parse, "sink");
gst_element_get_pad(fdsink,"sink")); gst_element_connect (mux, "src", fdsink, "sink");
g_print("setting to READY state\n"); g_print("setting to READY state\n");
gst_element_set_state(GST_ELEMENT(pipeline),GST_STATE_PLAYING); gst_element_set_state (GST_ELEMENT (pipeline), GST_STATE_PLAYING);
while (1) { while (1) {
gst_bin_iterate(GST_BIN(pipeline)); gst_bin_iterate (GST_BIN (pipeline));
} }
} }