Commit 1f02594b authored by Thomas Guillem's avatar Thomas Guillem

audiotrack: Add a define to fetch or not native sample rate

If activated, most of  the resampling  will be done by VLC.

Deactivated for now since android resampler is better than the ugly resampler.
parent ec6c8366
...@@ -108,6 +108,10 @@ struct aout_sys_t { ...@@ -108,6 +108,10 @@ struct aout_sys_t {
//#define AUDIOTRACK_USE_FLOAT //#define AUDIOTRACK_USE_FLOAT
//#define AUDIOTRACK_HW_LATENCY //#define AUDIOTRACK_HW_LATENCY
/* Get AudioTrack native sample rate: if activated, most of the resampling
* will be done by VLC */
//#define AUDIOTRACK_NATIVE_SAMPLERATE
#define AUDIO_CHAN_TEXT N_("Audio output channels") #define AUDIO_CHAN_TEXT N_("Audio output channels")
#define AUDIO_CHAN_LONGTEXT N_("Channels available for audio output. " \ #define AUDIO_CHAN_LONGTEXT N_("Channels available for audio output. " \
"If the input has more channels than the output, it will be down-mixed. " \ "If the input has more channels than the output, it will be down-mixed. " \
...@@ -279,8 +283,10 @@ InitJNIFields( audio_output_t *p_aout ) ...@@ -279,8 +283,10 @@ InitJNIFields( audio_output_t *p_aout )
GET_ID( GetStaticMethodID, AudioTrack.getMinBufferSize, "getMinBufferSize", GET_ID( GetStaticMethodID, AudioTrack.getMinBufferSize, "getMinBufferSize",
"(III)I", true ); "(III)I", true );
#ifdef AUDIOTRACK_NATIVE_SAMPLERATE
GET_ID( GetStaticMethodID, AudioTrack.getNativeOutputSampleRate, GET_ID( GetStaticMethodID, AudioTrack.getNativeOutputSampleRate,
"getNativeOutputSampleRate", "(I)I", true ); "getNativeOutputSampleRate", "(I)I", true );
#endif
GET_CONST_INT( AudioTrack.STATE_INITIALIZED, "STATE_INITIALIZED", true ); GET_CONST_INT( AudioTrack.STATE_INITIALIZED, "STATE_INITIALIZED", true );
GET_CONST_INT( AudioTrack.MODE_STREAM, "MODE_STREAM", true ); GET_CONST_INT( AudioTrack.MODE_STREAM, "MODE_STREAM", true );
GET_CONST_INT( AudioTrack.ERROR, "ERROR", true ); GET_CONST_INT( AudioTrack.ERROR, "ERROR", true );
...@@ -831,7 +837,7 @@ Start( audio_output_t *p_aout, audio_sample_format_t *restrict p_fmt ) ...@@ -831,7 +837,7 @@ Start( audio_output_t *p_aout, audio_sample_format_t *restrict p_fmt )
JNIEnv *env; JNIEnv *env;
jobject p_audiotrack = NULL; jobject p_audiotrack = NULL;
int i_nb_channels, i_max_channels, i_audiotrack_size, i_bytes_per_frame, int i_nb_channels, i_max_channels, i_audiotrack_size, i_bytes_per_frame,
i_native_rate; i_native_rate = 0;
unsigned int i_rate; unsigned int i_rate;
bool b_spdif; bool b_spdif;
...@@ -853,13 +859,11 @@ Start( audio_output_t *p_aout, audio_sample_format_t *restrict p_fmt ) ...@@ -853,13 +859,11 @@ Start( audio_output_t *p_aout, audio_sample_format_t *restrict p_fmt )
} }
else else
{ {
i_native_rate = JNI_AT_CALL_STATIC_INT( getNativeOutputSampleRate, if (jfields.AudioTrack.getNativeOutputSampleRate)
jfields.AudioManager.STREAM_MUSIC ); i_native_rate = JNI_AT_CALL_STATIC_INT( getNativeOutputSampleRate,
jfields.AudioManager.STREAM_MUSIC );
if( i_native_rate <= 0 ) if( i_native_rate <= 0 )
{
msg_Warn( p_aout, "negative native rate ? Should not happen !" );
i_native_rate = VLC_CLIP( p_sys->fmt.i_rate, 4000, 48000 ); i_native_rate = VLC_CLIP( p_sys->fmt.i_rate, 4000, 48000 );
}
} }
/* We can only accept U8, S16N, FL32, and AC3 */ /* We can only accept U8, S16N, FL32, and AC3 */
......
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