From 8ed13c4df426331286687e2f45fecf7a2f0bf216 Mon Sep 17 00:00:00 2001 From: Ovnuniarchos Date: Thu, 21 Jan 2016 14:40:35 +0100 Subject: set_signed_data now works correctly on pcm8 samples. --- servers/audio_server.cpp | 53 +++++++++++++++++++++++++++++++++++------------- 1 file changed, 39 insertions(+), 14 deletions(-) (limited to 'servers') diff --git a/servers/audio_server.cpp b/servers/audio_server.cpp index 74f866afb7..1f0a2e403a 100644 --- a/servers/audio_server.cpp +++ b/servers/audio_server.cpp @@ -48,26 +48,51 @@ AudioServer *AudioServer::get_singleton() { void AudioServer::sample_set_signed_data(RID p_sample, const DVector& p_buffer) { + SampleFormat format = sample_get_format(p_sample); + + ERR_EXPLAIN("IMA ADPCM is not supported."); + ERR_FAIL_COND(format==SAMPLE_FORMAT_IMA_ADPCM); + int len = p_buffer.size(); ERR_FAIL_COND( len == 0 ); DVector data; - data.resize(len*2); - DVector::Write w=data.write(); - - int16_t *samples = (int16_t*)w.ptr(); - + DVector::Write w; DVector::Read r = p_buffer.read(); - for(int i=0;i32767) - sample=32767; - samples[i]=sample; + switch(format) { + case SAMPLE_FORMAT_PCM8: { + data.resize(len); + w=data.write(); + + int8_t *samples8 = (int8_t*)w.ptr(); + + for(int i=0;i127) + sample=127; + samples8[i]=sample; + } + } break; + case SAMPLE_FORMAT_PCM16: { + data.resize(len*2); + w=data.write(); + + int16_t *samples16 = (int16_t*)w.ptr(); + + for(int i=0;i32767) + sample=32767; + samples16[i]=sample; + } + } break; } w = DVector::Write(); -- cgit v1.2.3