Commit 02950db1 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

deinterlace: simplify initialization

parent 3be2f980
...@@ -141,69 +141,56 @@ void SetFilterMethod( filter_t *p_filter, const char *psz_method ) ...@@ -141,69 +141,56 @@ void SetFilterMethod( filter_t *p_filter, const char *psz_method )
if( !psz_method ) if( !psz_method )
psz_method = ""; psz_method = "";
p_sys->b_double_rate = false;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = false;
if( !strcmp( psz_method, "mean" ) ) if( !strcmp( psz_method, "mean" ) )
{ {
p_sys->i_mode = DEINTERLACE_MEAN; p_sys->i_mode = DEINTERLACE_MEAN;
p_sys->b_double_rate = false;
p_sys->b_half_height = true; p_sys->b_half_height = true;
p_sys->b_use_frame_history = false;
} }
else if( !strcmp( psz_method, "bob" ) else if( !strcmp( psz_method, "bob" )
|| !strcmp( psz_method, "progressive-scan" ) ) || !strcmp( psz_method, "progressive-scan" ) )
{ {
p_sys->i_mode = DEINTERLACE_BOB; p_sys->i_mode = DEINTERLACE_BOB;
p_sys->b_double_rate = true; p_sys->b_double_rate = true;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = false;
} }
else if( !strcmp( psz_method, "linear" ) ) else if( !strcmp( psz_method, "linear" ) )
{ {
p_sys->i_mode = DEINTERLACE_LINEAR; p_sys->i_mode = DEINTERLACE_LINEAR;
p_sys->b_double_rate = true; p_sys->b_double_rate = true;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = false;
} }
else if( !strcmp( psz_method, "x" ) && p_sys->chroma->pixel_size == 1 ) else if( !strcmp( psz_method, "x" ) && p_sys->chroma->pixel_size == 1 )
{ {
p_sys->i_mode = DEINTERLACE_X; p_sys->i_mode = DEINTERLACE_X;
p_sys->b_double_rate = false;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = false;
} }
else if( !strcmp( psz_method, "yadif" ) ) else if( !strcmp( psz_method, "yadif" ) )
{ {
p_sys->i_mode = DEINTERLACE_YADIF; p_sys->i_mode = DEINTERLACE_YADIF;
p_sys->b_double_rate = false;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = true; p_sys->b_use_frame_history = true;
} }
else if( !strcmp( psz_method, "yadif2x" ) ) else if( !strcmp( psz_method, "yadif2x" ) )
{ {
p_sys->i_mode = DEINTERLACE_YADIF2X; p_sys->i_mode = DEINTERLACE_YADIF2X;
p_sys->b_double_rate = true; p_sys->b_double_rate = true;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = true; p_sys->b_use_frame_history = true;
} }
else if( !strcmp( psz_method, "phosphor" ) && p_sys->chroma->pixel_size == 1 ) else if( !strcmp( psz_method, "phosphor" ) && p_sys->chroma->pixel_size == 1 )
{ {
p_sys->i_mode = DEINTERLACE_PHOSPHOR; p_sys->i_mode = DEINTERLACE_PHOSPHOR;
p_sys->b_double_rate = true; p_sys->b_double_rate = true;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = true; p_sys->b_use_frame_history = true;
} }
else if( !strcmp( psz_method, "ivtc" ) && p_sys->chroma->pixel_size == 1 ) else if( !strcmp( psz_method, "ivtc" ) && p_sys->chroma->pixel_size == 1 )
{ {
p_sys->i_mode = DEINTERLACE_IVTC; p_sys->i_mode = DEINTERLACE_IVTC;
p_sys->b_double_rate = false;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = true; p_sys->b_use_frame_history = true;
} }
else if( !strcmp( psz_method, "discard" ) ) else if( !strcmp( psz_method, "discard" ) )
{ {
p_sys->i_mode = DEINTERLACE_DISCARD; p_sys->i_mode = DEINTERLACE_DISCARD;
p_sys->b_double_rate = false;
p_sys->b_half_height = true; p_sys->b_half_height = true;
p_sys->b_use_frame_history = false;
} }
else else
{ {
...@@ -212,9 +199,6 @@ void SetFilterMethod( filter_t *p_filter, const char *psz_method ) ...@@ -212,9 +199,6 @@ void SetFilterMethod( filter_t *p_filter, const char *psz_method )
"no valid/compatible deinterlace mode provided, using \"blend\"" ); "no valid/compatible deinterlace mode provided, using \"blend\"" );
p_sys->i_mode = DEINTERLACE_BLEND; p_sys->i_mode = DEINTERLACE_BLEND;
p_sys->b_double_rate = false;
p_sys->b_half_height = false;
p_sys->b_use_frame_history = false;
} }
p_sys->i_frame_offset = 0; /* reset to default when method changes */ p_sys->i_frame_offset = 0; /* reset to default when method changes */
...@@ -613,11 +597,13 @@ int Open( vlc_object_t *p_this ) ...@@ -613,11 +597,13 @@ int Open( vlc_object_t *p_this )
if( !p_sys ) if( !p_sys )
return VLC_ENOMEM; return VLC_ENOMEM;
config_ChainParse( p_filter, FILTER_CFG_PREFIX, ppsz_filter_options,
p_filter->p_cfg );
char *psz_mode = var_InheritString( p_filter, FILTER_CFG_PREFIX "mode" );
SetFilterMethod( p_filter, psz_mode );
free( psz_mode );
p_sys->chroma = chroma; p_sys->chroma = chroma;
p_sys->i_mode = DEINTERLACE_BLEND;
p_sys->b_double_rate = false;
p_sys->b_half_height = true;
p_sys->b_use_frame_history = false;
for( int i = 0; i < METADATA_SIZE; i++ ) for( int i = 0; i < METADATA_SIZE; i++ )
{ {
p_sys->meta.pi_date[i] = VLC_TS_INVALID; p_sys->meta.pi_date[i] = VLC_TS_INVALID;
...@@ -678,13 +664,6 @@ int Open( vlc_object_t *p_this ) ...@@ -678,13 +664,6 @@ int Open( vlc_object_t *p_this )
} }
/* */ /* */
config_ChainParse( p_filter, FILTER_CFG_PREFIX, ppsz_filter_options,
p_filter->p_cfg );
char *psz_mode = var_GetNonEmptyString( p_filter, FILTER_CFG_PREFIX "mode" );
SetFilterMethod( p_filter, psz_mode );
free( psz_mode );
if( p_sys->i_mode == DEINTERLACE_PHOSPHOR ) if( p_sys->i_mode == DEINTERLACE_PHOSPHOR )
{ {
int i_c420 = var_GetInteger( p_filter, int i_c420 = var_GetInteger( p_filter,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment