test frame services
[melted] / src / tests / charlie.c
1 #include <framework/mlt.h>
2 #include <stdio.h>
3 #include <string.h>
4
5 mlt_producer create_producer( char *file )
6 {
7 mlt_producer result = NULL;
8
9 // 1st Line preferences
10 if ( strstr( file, ".mpg" ) )
11 result = mlt_factory_producer( "mcmpeg", file );
12 else if ( strstr( file, ".mpeg" ) )
13 result = mlt_factory_producer( "mcmpeg", file );
14 else if ( strstr( file, ".dv" ) )
15 result = mlt_factory_producer( "mcdv", file );
16 else if ( strstr( file, ".jpg" ) )
17 result = mlt_factory_producer( "pixbuf", file );
18 else if ( strstr( file, ".png" ) )
19 result = mlt_factory_producer( "pixbuf", file );
20
21 // 2nd Line fallbacks
22 if ( result == NULL && strstr( file, ".dv" ) )
23 result = mlt_factory_producer( "libdv", file );
24
25 return result;
26 }
27
28 mlt_consumer create_consumer( char *id )
29 {
30 return mlt_factory_consumer( id, NULL );
31 }
32
33 void set_properties( mlt_service service, char *namevalue )
34 {
35 mlt_properties properties = mlt_service_properties( service );
36 mlt_properties_parse( properties, namevalue );
37 }
38
39 void transport( mlt_producer producer )
40 {
41 char temp[ 132 ];
42 fprintf( stderr, "Press return to continue\n" );
43 fgets( temp, 132, stdin );
44 }
45
46 int main( int argc, char **argv )
47 {
48 int i;
49 mlt_service service = NULL;
50 mlt_consumer consumer = NULL;
51 mlt_producer producer = NULL;
52
53 mlt_factory_init( "../modules" );
54
55 // Parse the arguments
56 for ( i = 1; i < argc; i ++ )
57 {
58 if ( !strcmp( argv[ i ], "-vo" ) )
59 {
60 consumer = create_consumer( argv[ ++ i ] );
61 service = mlt_consumer_service( consumer );
62 }
63 else if ( strstr( argv[ i ], "=" ) )
64 {
65 set_properties( service, argv[ i ] );
66 }
67 else
68 {
69 producer = create_producer( argv[ i ] );
70 service = mlt_producer_service( producer );
71 }
72 }
73
74 // If we have no consumer, default to sdl
75 if ( consumer == NULL )
76 consumer= mlt_factory_consumer( "sdl", NULL );
77
78 // Connect producer to consumer
79 mlt_consumer_connect( consumer, mlt_producer_service( producer ) );
80
81 // Transport functionality
82 transport( producer );
83
84 /*
85 // Create the producer(s)
86 mlt_producer dv1 = mlt_factory_producer( "mcmpeg", file1 );
87 mlt_producer dv2 = mlt_factory_producer( "mcmpeg", file2 );
88 //mlt_producer dv1 = producer_ppm_init( NULL );
89 //mlt_producer dv2 = producer_ppm_init( NULL );
90
91 // Connect a producer to our sdl consumer
92 mlt_consumer_connect( sdl_out, mlt_producer_service( dv1 ) );
93
94 fprintf( stderr, "Press return to continue\n" );
95 fgets( temp, 132, stdin );
96
97 // Register producers(s) with a multitrack object
98 mlt_multitrack multitrack = mlt_multitrack_init( );
99 mlt_multitrack_connect( multitrack, dv1, 0 );
100 mlt_multitrack_connect( multitrack, dv2, 1 );
101
102 // Create a filter and associate it to track 0
103 mlt_filter filter = mlt_factory_filter( "deinterlace", NULL );
104 mlt_filter_connect( filter, mlt_multitrack_service( multitrack ), 0 );
105 mlt_filter_set_in_and_out( filter, 0, 5 );
106
107 // Create another
108 mlt_filter greyscale = mlt_factory_filter( "greyscale", NULL );
109 mlt_filter_connect( greyscale, mlt_filter_service( filter ), 0 );
110 mlt_filter_set_in_and_out( greyscale, 0, 10 );
111
112 // Buy a tractor and connect it to the filter
113 mlt_tractor tractor = mlt_tractor_init( );
114 mlt_tractor_connect( tractor, mlt_filter_service( greyscale ) );
115
116 // Connect the tractor to the consumer
117 mlt_consumer_connect( sdl_out, mlt_tractor_service( tractor ) );
118
119 // Do stuff until we're told otherwise...
120
121 // Close everything...
122 //mlt_consumer_close( sdl_out );
123 //mlt_tractor_close( tractor );
124 //mlt_filter_close( filter );
125 //mlt_filter_close( greyscale );
126 //mlt_multitrack_close( multitrack );
127 //mlt_producer_close( dv1 );
128 //mlt_producer_close( dv2 );
129 */
130
131 mlt_factory_close( );
132
133 return 0;
134 }