X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Fframework%2Fmlt_multitrack.h;h=f0eaa70eccb846a8ddefdecda73d786b15935832;hb=c95736fd9ee742f5e6db06bbe579f23895f55eba;hp=19ead699b6e0ac0765f86148b82439ecbdc803c6;hpb=fa0d65478efe5d80e0affa58095109800a5cba71;p=melted diff --git a/src/framework/mlt_multitrack.h b/src/framework/mlt_multitrack.h index 19ead69..f0eaa70 100644 --- a/src/framework/mlt_multitrack.h +++ b/src/framework/mlt_multitrack.h @@ -23,9 +23,33 @@ #include "mlt_producer.h" +/** Private definition. +*/ + +struct mlt_track_s +{ + mlt_producer producer; + mlt_event event; +}; + +typedef struct mlt_track_s *mlt_track; + +struct mlt_multitrack_s +{ + // We're extending producer here + struct mlt_producer_s parent; + mlt_track *list; + int size; + int count; +}; + /** Public final methods */ +#define MLT_MULTITRACK_PRODUCER( multitrack ) ( &( multitrack )->parent ) +#define MLT_MULTITRACK_SERVICE( multitrack ) MLT_PRODUCER_SERVICE( MLT_MULTITRACK_PRODUCER( multitrack ) ) +#define MLT_MULTITRACK_PROPERTIES( multitrack ) MLT_SERVICE_PROPERTIES( MLT_MULTITRACK_SERVICE( multitrack ) ) + extern mlt_multitrack mlt_multitrack_init( ); extern mlt_producer mlt_multitrack_producer( mlt_multitrack self ); extern mlt_service mlt_multitrack_service( mlt_multitrack self ); @@ -34,6 +58,7 @@ extern int mlt_multitrack_connect( mlt_multitrack self, mlt_producer producer, i extern mlt_position mlt_multitrack_clip( mlt_multitrack self, mlt_whence whence, int index ); extern void mlt_multitrack_close( mlt_multitrack self ); extern int mlt_multitrack_count( mlt_multitrack self ); +extern void mlt_multitrack_refresh( mlt_multitrack self ); extern mlt_producer mlt_multitrack_track( mlt_multitrack self, int track ); #endif