Commit 0e63a3fc authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

lib: enable/disable the equalizer as needed, simplify

parent 585c2bc3
...@@ -469,6 +469,7 @@ libvlc_media_player_new( libvlc_instance_t *instance ) ...@@ -469,6 +469,7 @@ libvlc_media_player_new( libvlc_instance_t *instance )
var_Create (mp, "mute", VLC_VAR_BOOL); var_Create (mp, "mute", VLC_VAR_BOOL);
var_Create (mp, "volume", VLC_VAR_FLOAT); var_Create (mp, "volume", VLC_VAR_FLOAT);
var_Create (mp, "corks", VLC_VAR_INTEGER); var_Create (mp, "corks", VLC_VAR_INTEGER);
var_Create (mp, "audio-filter", VLC_VAR_STRING);
var_Create (mp, "amem-data", VLC_VAR_ADDRESS); var_Create (mp, "amem-data", VLC_VAR_ADDRESS);
var_Create (mp, "amem-setup", VLC_VAR_ADDRESS); var_Create (mp, "amem-setup", VLC_VAR_ADDRESS);
var_Create (mp, "amem-cleanup", VLC_VAR_ADDRESS); var_Create (mp, "amem-cleanup", VLC_VAR_ADDRESS);
...@@ -1472,49 +1473,35 @@ void libvlc_media_player_set_video_title_display( libvlc_media_player_t *p_mi, l ...@@ -1472,49 +1473,35 @@ void libvlc_media_player_set_video_title_display( libvlc_media_player_t *p_mi, l
int libvlc_media_player_set_equalizer( libvlc_media_player_t *p_mi, libvlc_equalizer_t *p_equalizer ) int libvlc_media_player_set_equalizer( libvlc_media_player_t *p_mi, libvlc_equalizer_t *p_equalizer )
{ {
float f_preamp; char bands[EQZ_BANDS_MAX * EQZ_BAND_VALUE_SIZE + 1];
char *psz_bands;
if ( p_equalizer ) if( p_equalizer != NULL )
{ {
f_preamp = p_equalizer->f_preamp; for( unsigned i = 0, c = 0; i < EQZ_BANDS_MAX; i++ )
psz_bands = malloc( EQZ_BANDS_MAX * EQZ_BAND_VALUE_SIZE + 1 );
if ( unlikely( psz_bands == NULL ) )
return -1;
char *p = psz_bands;
int c;
for ( int i = 0; i < EQZ_BANDS_MAX; i++ )
{ {
c = snprintf( p, EQZ_BAND_VALUE_SIZE + 1, " %.07f", p_equalizer->f_amp[i] ); c = snprintf( bands + c, sizeof(bands) - c, " %.07f",
if ( unlikely( c >= EQZ_BAND_VALUE_SIZE + 1 ) ) p_equalizer->f_amp[i] );
{ if( unlikely(c >= sizeof(bands)) )
free( psz_bands );
return -1; return -1;
}
p += c;
} }
}
else
{
f_preamp = 0.f;
psz_bands = NULL;
}
var_SetFloat( p_mi, "equalizer-preamp", f_preamp ); var_SetFloat( p_mi, "equalizer-preamp", p_equalizer->f_preamp );
var_SetString( p_mi, "equalizer-bands", psz_bands ); var_SetString( p_mi, "equalizer-bands", bands );
}
var_SetString( p_mi, "audio-filter", p_equalizer ? "equalizer" : "" );
audio_output_t *p_aout = input_resource_HoldAout( p_mi->input.p_resource ); audio_output_t *p_aout = input_resource_HoldAout( p_mi->input.p_resource );
if ( p_aout ) if( p_aout != NULL )
{ {
var_SetFloat( p_aout, "equalizer-preamp", f_preamp ); if( p_equalizer != NULL )
var_SetString( p_aout, "equalizer-bands", psz_bands ); {
var_SetFloat( p_aout, "equalizer-preamp", p_equalizer->f_preamp );
var_SetString( p_aout, "equalizer-bands", bands );
}
var_SetString( p_mi, "audio-filter", p_equalizer ? "equalizer" : "" );
vlc_object_release( p_aout ); vlc_object_release( p_aout );
} }
free( psz_bands );
return 0; return 0;
} }
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