move audio sample calculator to mlt_frame and use from ffmpeg and mcmpeg, add mlt_fra...
[melted] / src / tests / dan.c
index ee76bb0..a896b14 100644 (file)
@@ -1,16 +1,5 @@
-#include "mlt_producer.h"
-#include "mlt_consumer.h"
-#include "mlt_filter.h"
-#include "mlt_tractor.h"
-#include "mlt_transition.h"
-#include "mlt_multitrack.h"
-
-#include "producer_libdv.h"
-#include "filter_deinterlace.h"
-#include "consumer_sdl.h"
-#include "producer_ppm.h"
-#include "producer_pixbuf.h"
-#include "transition_composite.h"
+
+#include <framework/mlt.h>
 
 #include <stdio.h>
 
@@ -20,50 +9,90 @@ int main( int argc, char **argv )
        char *file1 = NULL;
        char *file2 = NULL;
 
+       mlt_factory_init( "../modules" );
+
        if ( argc >= 2 )
                file1 = argv[ 1 ];
        if ( argc >= 3 )
                file2 = argv[ 2 ];
 
        // Start the consumer...
-       mlt_consumer sdl_out = consumer_sdl_init( NULL );
+       int vstd = mlt_video_standard_ntsc;
+       //mlt_consumer consumer = mlt_factory_consumer( "bluefish", &vstd );
+       mlt_consumer consumer = mlt_factory_consumer( "sdl", "NTSC" );
 
        // Create the producer(s)
-       mlt_producer dv1 = producer_libdv_init( file1 );
+       mlt_producer dv1 = mlt_factory_producer( "mcdv", file1 );
+       mlt_producer_set_in_and_out( dv1, 300.0, 303.0 );
+       
+       mlt_producer dv2 = mlt_factory_producer( "mcmpeg", file2 );
+       //mlt_producer_set_in_and_out( dv2, 10.0, 30.0 );
+
+#if 0
+       // Connect the consumer to the producer
+       mlt_consumer_connect( consumer, mlt_producer_service( dv2 ) );
+
+       // Do stuff until we're told otherwise...
+       fprintf( stderr, "Press return to continue\n" );
+       fgets( temp, 132, stdin );
+       mlt_consumer_close( consumer );
+       return 0;
+#endif
+
        //mlt_producer dv1 = producer_pixbuf_init( file1 );
        //mlt_producer dv2 = producer_libdv_init( file2 );
-       mlt_producer dv2 = producer_pixbuf_init( file2 );
+       //mlt_producer dv2 = mlt_factory_producer( "pixbuf", file2 );
+#if 0
+       mlt_producer dv2 = mlt_factory_producer( "pango", NULL ); //"<span font_desc=\"Sans Bold 36\">Mutton <span font_desc=\"Luxi Serif Bold Oblique 36\">Lettuce</span> Tomato</span>" );
+       mlt_properties_set( mlt_producer_properties( dv2 ), "font", "Sans Bold 36" );
+       mlt_properties_set( mlt_producer_properties( dv2 ), "text", "Mutton Lettuce\nTomato" );
+       mlt_properties_set_int( mlt_producer_properties( dv2 ), "video_standard", mlt_video_standard_ntsc );
+       mlt_properties_set_int( mlt_producer_properties( dv2 ), "bgcolor", 0x0000007f );
+       mlt_properties_set_int( mlt_producer_properties( dv2 ), "pad", 8 );
+       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 = filter_deinterlace_init( 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 = transition_composite_init( NULL );
-       mlt_transition_connect( transition, mlt_filter_service( filter ), 0, 1 );
-       mlt_transition_set_in_and_out( transition, 0, 1000 );
+       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, 3.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( );
        mlt_tractor_connect( tractor, mlt_transition_service( transition ) );
 
        // Connect the tractor to the consumer
-       mlt_consumer_connect( sdl_out, mlt_tractor_service( tractor ) );
+       mlt_consumer_connect( consumer, mlt_tractor_service( tractor ) );
 
        // Do stuff until we're told otherwise...
        fprintf( stderr, "Press return to continue\n" );
        fgets( temp, 132, stdin );
 
        // Close everything...
-       mlt_consumer_close( sdl_out );
+       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 );