[vlc-devel] [PATCH v2 9/9] libvlc: Adapt to new equalizer code with extra sets of ISO bands
Ronald Wright
logiconcepts819 at gmail.com
Sun Nov 29 00:11:23 CET 2015
Note: This patch cannot be applied without patch 4, which depends on patches 1
and 2. Patch 3 is also required so that all the new symbol definitions from
patches 1 and 2 are included in VLC. Patches 4 through 9 must be applied all
together.
---
lib/audio.c | 18 +++++++++---------
lib/media_player.c | 14 ++++++++++++--
lib/media_player_internal.h | 2 +-
3 files changed, 22 insertions(+), 12 deletions(-)
diff --git a/lib/audio.c b/lib/audio.c
index 7901c64..7f89ce2 100644
--- a/lib/audio.c
+++ b/lib/audio.c
@@ -529,7 +529,7 @@ const char *libvlc_audio_equalizer_get_preset_name( unsigned u_index )
*****************************************************************************/
unsigned libvlc_audio_equalizer_get_band_count( void )
{
- return EQZ_BANDS_MAX;
+ return EQZ_ISO10_BANDS_MAX;
}
/*****************************************************************************
@@ -537,10 +537,10 @@ unsigned libvlc_audio_equalizer_get_band_count( void )
*****************************************************************************/
float libvlc_audio_equalizer_get_band_frequency( unsigned u_index )
{
- if ( u_index >= EQZ_BANDS_MAX )
+ if ( u_index >= EQZ_ISO10_BANDS_MAX )
return -1.f;
- return f_iso_frequency_table_10b[ u_index ];
+ return iso_frequency_table_10b.f_frequencies[ u_index ];
}
/*****************************************************************************
@@ -554,7 +554,7 @@ libvlc_equalizer_t *libvlc_audio_equalizer_new( void )
return NULL;
p_equalizer->f_preamp = 0.f;
- for ( unsigned i = 0; i < EQZ_BANDS_MAX; i++ )
+ for ( unsigned i = 0; i < EQZ_ISO10_BANDS_MAX; i++ )
p_equalizer->f_amp[ i ] = 0.f;
return p_equalizer;
@@ -574,10 +574,10 @@ libvlc_equalizer_t *libvlc_audio_equalizer_new_from_preset( unsigned u_index )
if ( unlikely( p_equalizer == NULL ) )
return NULL;
- p_equalizer->f_preamp = eqz_preset_10b[ u_index ].f_preamp;
+ p_equalizer->f_preamp = eqz_preset_iso_10b[ u_index ].f_preamp;
- for ( unsigned i = 0; i < EQZ_BANDS_MAX; i++ )
- p_equalizer->f_amp[ i ] = eqz_preset_10b[ u_index ].f_amp[ i ];
+ for ( unsigned i = 0; i < EQZ_ISO10_BANDS_MAX; i++ )
+ p_equalizer->f_amp[ i ] = eqz_preset_iso_10b[ u_index ].f_amp[ i ];
return p_equalizer;
}
@@ -619,7 +619,7 @@ float libvlc_audio_equalizer_get_preamp( libvlc_equalizer_t *p_equalizer )
*****************************************************************************/
int libvlc_audio_equalizer_set_amp_at_index( libvlc_equalizer_t *p_equalizer, float f_amp, unsigned u_band )
{
- if( u_band >= EQZ_BANDS_MAX || isnan(f_amp) )
+ if( u_band >= EQZ_ISO10_BANDS_MAX || isnan(f_amp) )
return -1;
@@ -637,7 +637,7 @@ int libvlc_audio_equalizer_set_amp_at_index( libvlc_equalizer_t *p_equalizer, fl
*****************************************************************************/
float libvlc_audio_equalizer_get_amp_at_index( libvlc_equalizer_t *p_equalizer, unsigned u_band )
{
- if ( u_band >= EQZ_BANDS_MAX )
+ if ( u_band >= EQZ_ISO10_BANDS_MAX )
return nanf("");
return p_equalizer->f_amp[ u_band ];
diff --git a/lib/media_player.c b/lib/media_player.c
index 8b6938c..b30efab 100644
--- a/lib/media_player.c
+++ b/lib/media_player.c
@@ -668,6 +668,7 @@ libvlc_media_player_new( libvlc_instance_t *instance )
/* Equalizer */
var_Create (mp, "equalizer-preamp", VLC_VAR_FLOAT);
var_Create (mp, "equalizer-vlcfreqs", VLC_VAR_BOOL);
+ var_Create (mp, "equalizer-band-count", VLC_VAR_STRING);
var_Create (mp, "equalizer-bands", VLC_VAR_STRING);
mp->p_md = NULL;
@@ -1875,11 +1876,12 @@ 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 )
{
- char bands[EQZ_BANDS_MAX * EQZ_BAND_VALUE_SIZE + 1];
+ char bands[EQZ_ISO10_BANDS_MAX * EQZ_BAND_VALUE_SIZE + 3];
if( p_equalizer != NULL )
{
- for( unsigned i = 0, c = 0; i < EQZ_BANDS_MAX; i++ )
+ unsigned int c = 0;
+ for( unsigned i = 0; i < EQZ_ISO10_BANDS_MAX; i++ )
{
c += snprintf( bands + c, sizeof(bands) - c, " %.07f",
p_equalizer->f_amp[i] );
@@ -1887,7 +1889,14 @@ int libvlc_media_player_set_equalizer( libvlc_media_player_t *p_mi, libvlc_equal
return -1;
}
+ /* We use ISO bands in libvlc */
+ c += snprintf( bands + c, sizeof(bands) - c, " %c",
+ EQZ_ISO_IDENTIFIER );
+ if( unlikely( c >= sizeof( bands ) ) )
+ return -1;
+
var_SetFloat( p_mi, "equalizer-preamp", p_equalizer->f_preamp );
+ var_SetString( p_mi, "equalizer-band-count", eqz_band_counts[0] );
var_SetString( p_mi, "equalizer-bands", bands );
}
var_SetString( p_mi, "audio-filter", p_equalizer ? "equalizer" : "" );
@@ -1898,6 +1907,7 @@ int libvlc_media_player_set_equalizer( libvlc_media_player_t *p_mi, libvlc_equal
if( p_equalizer != NULL )
{
var_SetFloat( p_aout, "equalizer-preamp", p_equalizer->f_preamp );
+ var_SetString( p_aout, "equalizer-band-count", eqz_band_counts[0] );
var_SetString( p_aout, "equalizer-bands", bands );
}
diff --git a/lib/media_player_internal.h b/lib/media_player_internal.h
index 27fbf1f..3de3265 100644
--- a/lib/media_player_internal.h
+++ b/lib/media_player_internal.h
@@ -70,7 +70,7 @@ libvlc_track_description_t * libvlc_get_track_description(
struct libvlc_equalizer_t
{
float f_preamp;
- float f_amp[EQZ_BANDS_MAX];
+ float f_amp[EQZ_ISO10_BANDS_MAX];
};
#endif
--
1.9.1
More information about the vlc-devel
mailing list