X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Ftests%2Fdan.c;fp=src%2Ftests%2Fdan.c;h=99469a8dddbde1948209a68c01e67f5cf9244985;hb=3e0edf239fc98d1180f73ff3ba4a0c1331147fae;hp=8e499bcdeb059b6001e81a1b686c22ce4147eedf;hpb=c369d4f7d2eefe0fb79accd8218400fac2d265fc;p=melted diff --git a/src/tests/dan.c b/src/tests/dan.c index 8e499bc..99469a8 100644 --- a/src/tests/dan.c +++ b/src/tests/dan.c @@ -22,10 +22,14 @@ int main( int argc, char **argv ) mlt_consumer consumer = mlt_factory_consumer( "sdl", "NTSC" ); // Create the producer(s) - mlt_producer dv1 = mlt_factory_producer( "mcmpeg", file1 ); + mlt_producer dv1 = mlt_factory_producer( "mcdv", file1 ); + mlt_producer_set_in_and_out( dv1, 0.0, 2.0 ); + + mlt_producer dv2 = mlt_factory_producer( "mcmpeg", file2 ); + //mlt_producer_set_in_and_out( dv2, 10.0, 30.0 ); #if 0 - // Connect the tractor to the consumer + // Connect the consumer to the producer mlt_consumer_connect( consumer, mlt_producer_service( dv1 ) ); // Do stuff until we're told otherwise... @@ -38,6 +42,7 @@ int main( int argc, char **argv ) //mlt_producer dv1 = producer_pixbuf_init( file1 ); //mlt_producer dv2 = producer_libdv_init( file2 ); //mlt_producer dv2 = mlt_factory_producer( "pixbuf", file2 ); +#if 0 mlt_producer dv2 = mlt_factory_producer( "pango", NULL ); //"Mutton Lettuce Tomato" ); mlt_properties_set( mlt_producer_properties( dv2 ), "font", "Sans Bold 36" ); mlt_properties_set( mlt_producer_properties( dv2 ), "text", "Mutton Lettuce\nTomato" ); @@ -47,21 +52,31 @@ int main( int argc, char **argv ) mlt_properties_set_int( mlt_producer_properties( dv2 ), "align", 1 ); mlt_properties_set_int( mlt_producer_properties( dv2 ), "x", -20 ); mlt_properties_set_int( mlt_producer_properties( dv2 ), "y", 40 ); +#endif + + mlt_playlist playlist1 = mlt_playlist_init(); + mlt_playlist_append( playlist1, dv1 ); + mlt_playlist playlist2 = mlt_playlist_init(); + mlt_playlist_blank( playlist2, 1.0 ); + mlt_playlist_append( playlist2, dv2 ); + // Register producers(s) with a multitrack object mlt_multitrack multitrack = mlt_multitrack_init( ); - mlt_multitrack_connect( multitrack, dv1, 0 ); - mlt_multitrack_connect( multitrack, dv2, 1 ); + mlt_multitrack_connect( multitrack, mlt_playlist_producer( playlist1 ), 0 ); + mlt_multitrack_connect( multitrack, mlt_playlist_producer( playlist2 ), 1 ); // Create a filter and associate it to track 0 - mlt_filter filter = mlt_factory_filter( "deinterlace", NULL ); - mlt_filter_connect( filter, mlt_multitrack_service( multitrack ), 0 ); - mlt_filter_set_in_and_out( filter, 0, 1000 ); + //mlt_filter filter = mlt_factory_filter( "deinterlace", NULL ); + //mlt_filter_connect( filter, mlt_multitrack_service( multitrack ), 0 ); + //mlt_filter_set_in_and_out( filter, 0, 1000 ); // Define a transition - mlt_transition transition = mlt_factory_transition( "composite", NULL ); - mlt_transition_connect( transition, mlt_filter_service( filter ), 0, 1 ); - mlt_transition_set_in_and_out( transition, 0, 5.0 ); + mlt_transition transition = mlt_factory_transition( "luma", NULL ); + mlt_transition_connect( transition, mlt_multitrack_service( multitrack ), 0, 1 ); + mlt_transition_set_in_and_out( transition, 1.0, 2.0 ); + mlt_properties_set( mlt_transition_properties( transition ), "filename", "clock.pgm" ); + mlt_properties_set_double( mlt_transition_properties( transition ), "softness", 0.1 ); // Buy a tractor and connect it to the filter mlt_tractor tractor = mlt_tractor_init( ); @@ -74,17 +89,10 @@ int main( int argc, char **argv ) fprintf( stderr, "Press return to continue\n" ); fgets( temp, 132, stdin ); - mlt_properties_set( mlt_producer_properties( dv2 ), "font", "Sans Oblique 36" ); - mlt_properties_set( mlt_producer_properties( dv2 ), "text", "Mutton\nLettuce Tomato" ); - - // Do stuff until we're told otherwise... - fprintf( stderr, "Press return to continue\n" ); - fgets( temp, 132, stdin ); - // Close everything... mlt_consumer_close( consumer ); mlt_tractor_close( tractor ); - //mlt_filter_close( filter ); +// mlt_filter_close( filter ); mlt_multitrack_close( multitrack ); mlt_producer_close( dv1 ); mlt_producer_close( dv2 );