]> git.sesse.net Git - mlt/commitdiff
Transitions ignore test frames
authorlilo_booter <lilo_booter@d19143bc-622f-0410-bfdd-b5b2a6649095>
Sat, 25 Sep 2004 07:25:49 +0000 (07:25 +0000)
committerlilo_booter <lilo_booter@d19143bc-622f-0410-bfdd-b5b2a6649095>
Sat, 25 Sep 2004 07:25:49 +0000 (07:25 +0000)
git-svn-id: https://mlt.svn.sourceforge.net/svnroot/mlt/trunk/mlt@444 d19143bc-622f-0410-bfdd-b5b2a6649095

src/framework/mlt_transition.c

index 13957752d2c39a5a1c428e0be31fa94f76c4b5fc..5996e14e6813e81aca5389e93e50701234eff4f4 100644 (file)
@@ -150,8 +150,10 @@ mlt_position mlt_transition_get_out( mlt_transition this )
 
 mlt_frame mlt_transition_process( mlt_transition this, mlt_frame a_frame, mlt_frame b_frame )
 {
-       if ( this->process == NULL )
+       if ( this->process == NULL || b_frame == NULL || ( mlt_frame_is_test_card( b_frame ) && mlt_frame_is_test_audio( b_frame ) ) )
                return a_frame;
+       else if ( a_frame == NULL || ( mlt_frame_is_test_card( a_frame ) && mlt_frame_is_test_audio( a_frame ) ) )
+               return b_frame;
        else
                return this->process( this, a_frame, b_frame );
 }
@@ -199,6 +201,12 @@ static int transition_get_frame( mlt_service service, mlt_frame_ptr frame, int i
                {
                        // Process the transition
                        *frame = mlt_transition_process( this, this->a_frame, this->b_frame );
+                       if ( *frame == this->b_frame )
+                       {
+                               mlt_frame t = this->a_frame;
+                               this->a_frame = this->b_frame;
+                               this->b_frame = t;
+                       }
                        if ( !mlt_properties_get_int( mlt_frame_properties( this->a_frame ), "test_image" ) )
                                mlt_properties_set_int( mlt_frame_properties( this->b_frame ), "test_image", 1 );
                        if ( !mlt_properties_get_int( mlt_frame_properties( this->a_frame ), "test_audio" ) )