From c654dedb28b9f3f15eda261545daa333534a7177 Mon Sep 17 00:00:00 2001 From: peter1138 Date: Fri, 10 Jul 2009 18:22:04 +0000 Subject: [PATCH] (svn r16784) -Fix: Audio playback rate was fixed at 11025Hz regardless of the rate specified to the audio driver, resulting in incorrect playback speed. It is still preferable to use 11025Hz output rate if possible as OpenTTD's sample rate converter is very low quality. --- src/mixer.cpp | 2 +- src/openttd.cpp | 2 -- src/sound/allegro_s.cpp | 1 + src/sound/cocoa_s.cpp | 1 + src/sound/sdl_s.cpp | 1 + src/sound/win32_s.cpp | 2 ++ 6 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/mixer.cpp b/src/mixer.cpp index 3a55b7fadb..c6c5776dad 100644 --- a/src/mixer.cpp +++ b/src/mixer.cpp @@ -26,7 +26,7 @@ struct MixerChannel { }; static MixerChannel _channels[8]; -static uint32 _play_rate; +static uint32 _play_rate = 11025; /** * The theoretical maximum volume for a single sound sample. Multiple sound diff --git a/src/openttd.cpp b/src/openttd.cpp index 6f2cc48147..962a051433 100644 --- a/src/openttd.cpp +++ b/src/openttd.cpp @@ -18,7 +18,6 @@ #include "fontcache.h" #include "gfxinit.h" #include "gui.h" -#include "mixer.h" #include "sound_func.h" #include "window_func.h" @@ -584,7 +583,6 @@ int ttd_main(int argc, char *argv[]) /* Sample catalogue */ DEBUG(misc, 1, "Loading sound effects..."); - MxInitialize(11025); SoundInitialize("sample.cat"); /* Initialize FreeType */ diff --git a/src/sound/allegro_s.cpp b/src/sound/allegro_s.cpp index 069e473e5f..a94f6d2386 100644 --- a/src/sound/allegro_s.cpp +++ b/src/sound/allegro_s.cpp @@ -58,6 +58,7 @@ const char *SoundDriver_Allegro::Start(const char * const *parm) } _stream = play_audio_stream(BUFFER_SIZE, 16, true, 11025, 255, 128); + MxInitialize(11025); return NULL; } diff --git a/src/sound/cocoa_s.cpp b/src/sound/cocoa_s.cpp index 7e315fb75c..851136efab 100644 --- a/src/sound/cocoa_s.cpp +++ b/src/sound/cocoa_s.cpp @@ -69,6 +69,7 @@ const char *SoundDriver_Cocoa::Start(const char * const *parm) requestedDesc.mBytesPerFrame = requestedDesc.mBitsPerChannel * requestedDesc.mChannelsPerFrame / 8; requestedDesc.mBytesPerPacket = requestedDesc.mBytesPerFrame * requestedDesc.mFramesPerPacket; + MxInitialize(requestedDesc.mSampleRate); /* Locate the default output audio unit */ desc.componentType = kAudioUnitType_Output; diff --git a/src/sound/sdl_s.cpp b/src/sound/sdl_s.cpp index d111ac8ed0..7c89331f7a 100644 --- a/src/sound/sdl_s.cpp +++ b/src/sound/sdl_s.cpp @@ -30,6 +30,7 @@ const char *SoundDriver_SDL::Start(const char * const *parm) spec.channels = 2; spec.samples = 512; spec.callback = fill_sound_buffer; + MxInitialize(spec.freq); SDL_CALL SDL_OpenAudio(&spec, &spec); SDL_CALL SDL_PauseAudio(0); return NULL; diff --git a/src/sound/win32_s.cpp b/src/sound/win32_s.cpp index 3a5419495a..776158adf0 100644 --- a/src/sound/win32_s.cpp +++ b/src/sound/win32_s.cpp @@ -65,6 +65,8 @@ const char *SoundDriver_Win32::Start(const char * const *parm) if (waveOutOpen(&_waveout, WAVE_MAPPER, &wfex, (DWORD_PTR)&waveOutProc, 0, CALLBACK_FUNCTION) != MMSYSERR_NOERROR) return "waveOutOpen failed"; + MxInitialize(wfex.nSamplesPerSec); + PrepareHeader(&_wave_hdr[0]); PrepareHeader(&_wave_hdr[1]); FillHeaders();