X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Fframework%2Fmlt_transition.h;h=0f9879a3087c8c389dabcf47fd7b616dbae17e41;hb=f4963a6aa07644399b273b5d2b1f9299c9047414;hp=7ac765c33a721580f000e615a1c4d8e4e04f3205;hpb=5bc34e35d56ebfae82b63fa24c91a8eb3eeac713;p=melted diff --git a/src/framework/mlt_transition.h b/src/framework/mlt_transition.h index 7ac765c..0f9879a 100644 --- a/src/framework/mlt_transition.h +++ b/src/framework/mlt_transition.h @@ -1,21 +1,24 @@ -/* - * mlt_transition.h -- abstraction for all transition services - * Copyright (C) 2003-2004 Ushodaya Enterprises Limited - * Author: Charles Yates +/** + * \file mlt_transition.h + * \brief abstraction for all transition services + * \see mlt_transition_s * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. + * Copyright (C) 2003-2009 Ushodaya Enterprises Limited + * \author Charles Yates * - * This program is distributed in the hope that it will be useful, + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software Foundation, - * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _MLT_TRANSITION_H_ @@ -23,43 +26,54 @@ #include "mlt_service.h" -/** The interface definition for all transitions. -*/ +/** \brief Transition abstract service class + * + * A transition may modify the output of a producer based on the output of a second producer. + * + * \extends mlt_service_s + * \properties \em a_track the track index (0-based) of a multitrack of the first producer + * \properties \em b_track the track index (0-based) of a multitrack of the second producer + * \properties \em accepts_blanks a flag to indicate if the transition should accept blank frames + * \properties \em always_active a flag to indicate that the in and out points do not apply + * \properties \em _transition_type 1 for video, 2 for audio + */ struct mlt_transition_s { - // We're implementing service here + /** We're implementing service here */ struct mlt_service_s parent; - // public virtual + /** public virtual */ void ( *close )( mlt_transition ); - // protected transition method + /** protected transition method */ mlt_frame ( *process )( mlt_transition, mlt_frame, mlt_frame ); - // Protected + /** Protected */ void *child; - - // track and in/out points + + /** track and in/out points */ mlt_service producer; - - // Private - mlt_frame a_frame; - mlt_frame b_frame; + + /** Private */ + mlt_frame *frames; + int held; }; -/** Public final methods -*/ +#define MLT_TRANSITION_SERVICE( transition ) ( &( transition )->parent ) +#define MLT_TRANSITION_PROPERTIES( transition ) MLT_SERVICE_PROPERTIES( MLT_TRANSITION_SERVICE( transition ) ) -extern int mlt_transition_init( mlt_transition this, void *child ); -extern mlt_service mlt_transition_service( mlt_transition this ); -extern mlt_properties mlt_transition_properties( mlt_transition this ); -extern int mlt_transition_connect( mlt_transition this, mlt_service producer, int a_track, int b_track ); -extern void mlt_transition_set_in_and_out( mlt_transition this, mlt_timecode in, mlt_timecode out ); -extern int mlt_transition_get_a_track( mlt_transition this ); -extern int mlt_transition_get_b_track( mlt_transition this ); -extern mlt_timecode mlt_transition_get_in( mlt_transition this ); -extern mlt_timecode mlt_transition_get_out( mlt_transition this ); -extern void mlt_transition_close( mlt_transition this ); +extern int mlt_transition_init( mlt_transition self, void *child ); +extern mlt_transition mlt_transition_new( ); +extern mlt_service mlt_transition_service( mlt_transition self ); +extern mlt_properties mlt_transition_properties( mlt_transition self ); +extern int mlt_transition_connect( mlt_transition self, mlt_service producer, int a_track, int b_track ); +extern void mlt_transition_set_in_and_out( mlt_transition self, mlt_position in, mlt_position out ); +extern int mlt_transition_get_a_track( mlt_transition self ); +extern int mlt_transition_get_b_track( mlt_transition self ); +extern mlt_position mlt_transition_get_in( mlt_transition self ); +extern mlt_position mlt_transition_get_out( mlt_transition self ); +extern mlt_frame mlt_transition_process( mlt_transition self, mlt_frame a_frame, mlt_frame b_frame ); +extern void mlt_transition_close( mlt_transition self ); #endif