X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmodules%2Fopengl%2Ffilter_movit_resize.cpp;h=15480d1208063003adce5325297ccdbc4a40a520;hb=2c046e968db474d1eafbcf77b119495bf89e6ae5;hp=cc8f46cd9e3f85e852b98a5cd3e62b56f3f24073;hpb=6a498987705f134bc11ed8d7fc066bbf393186fc;p=mlt diff --git a/src/modules/opengl/filter_movit_resize.cpp b/src/modules/opengl/filter_movit_resize.cpp index cc8f46cd..15480d12 100644 --- a/src/modules/opengl/filter_movit_resize.cpp +++ b/src/modules/opengl/filter_movit_resize.cpp @@ -26,6 +26,7 @@ #include "filter_glsl_manager.h" #include #include +#include "optional_effect.h" static float alignment_parse( char* align ) { @@ -156,16 +157,22 @@ static int get_image( mlt_frame frame, uint8_t **image, mlt_image_format *format } if ( !error ) { + mlt_properties filter_properties = MLT_FILTER_PROPERTIES( filter ); GlslManager::get_instance()->lock_service( frame ); - Effect* effect = GlslManager::get_effect( filter, frame ); - if ( effect ) { - bool ok = effect->set_int( "width", *width ); - ok |= effect->set_int( "height", *height ); - ok |= effect->set_float( "left", rect.x ); - ok |= effect->set_float( "top", rect.y ); - assert(ok); - } + mlt_properties_set_int( filter_properties, "movit.parms.int.width", *width ); + mlt_properties_set_int( filter_properties, "movit.parms.int.height", *height ); + mlt_properties_set_double( filter_properties, "movit.parms.float.left", rect.x ); + mlt_properties_set_double( filter_properties, "movit.parms.float.top", rect.y ); + + bool disable = ( *width == owidth && *height == oheight ); + mlt_properties_set_int( filter_properties, "movit.parms.int.disable", disable ); + GlslManager::get_instance()->unlock_service( frame ); + + GlslManager::set_effect_input( MLT_FILTER_SERVICE( filter ), frame, (mlt_service) *image ); + GlslManager::set_effect( MLT_FILTER_SERVICE( filter ), frame, new OptionalEffect ); + *image = (uint8_t *) MLT_FILTER_SERVICE( filter ); + return error; } return error; @@ -173,8 +180,6 @@ static int get_image( mlt_frame frame, uint8_t **image, mlt_image_format *format static mlt_frame process( mlt_filter filter, mlt_frame frame ) { - if ( !GlslManager::get_effect( filter, frame ) ) - GlslManager::add_effect( filter, frame, new PaddingEffect ); mlt_frame_push_service( frame, filter ); mlt_frame_push_get_image( frame, get_image ); return frame;