diff options
| author | Max Horn | 2003-08-04 22:15:16 +0000 |
|---|---|---|
| committer | Max Horn | 2003-08-04 22:15:16 +0000 |
| commit | d280258e09fccc1ac3c72569a28e4cb69afef488 (patch) | |
| tree | c46512447bceda823298e905bd20ed79ef9e4e45 /sound/mixer.cpp | |
| parent | 679e818b0b401163b8e257be4b9b30a809e204e9 (diff) | |
| download | scummvm-rg350-d280258e09fccc1ac3c72569a28e4cb69afef488.tar.gz scummvm-rg350-d280258e09fccc1ac3c72569a28e4cb69afef488.tar.bz2 scummvm-rg350-d280258e09fccc1ac3c72569a28e4cb69afef488.zip | |
renamed eof -> eos (end of stream); hid MP3/Vorbis stream classes completly (by providing factory methods); new readBuffer method for AudioInputStream for improved speed of the mixer; new MusicStream class (subclassed for MP3/Vorbis sound) which offers a getRate method; some other tweaks
svn-id: r9467
Diffstat (limited to 'sound/mixer.cpp')
| -rw-r--r-- | sound/mixer.cpp | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/sound/mixer.cpp b/sound/mixer.cpp index dbc87f01f7..8ca9d360d8 100644 --- a/sound/mixer.cpp +++ b/sound/mixer.cpp @@ -709,7 +709,7 @@ void ChannelRaw::mix(int16 *data, uint len) { assert(_input); assert(_converter); - if (_input->eof()) { + if (_input->eos()) { // TODO: call drain method destroy(); return; @@ -820,7 +820,7 @@ void ChannelStream::mix(int16 *data, uint len) { assert(_input); assert(_converter); - if (_input->eof()) { + if (_input->eos()) { // TODO: call drain method // Normally, the stream stays around even if all its data is used up. @@ -929,7 +929,7 @@ static inline int scale_sample(mad_fixed_t sample) { ChannelMP3::ChannelMP3(SoundMixer *mixer, PlayingSoundHandle *handle, File *file, uint size) : Channel(mixer, handle) { // Create the input stream - _input = new MP3InputStream(file, mad_timer_zero, size); + _input = makeMP3Stream(file, mad_timer_zero, size); // Get a rate converter instance //printf("ChannelMP3: inrate %d, outrate %d, stereo %d\n", _input->getRate(), mixer->getOutputRate(), _input->isStereo()); @@ -951,7 +951,7 @@ void ChannelMP3::mix(int16 *data, uint len) { assert(_input); assert(_converter); - if (_input->eof()) { + if (_input->eos()) { // TODO: call drain method destroy(); return; @@ -1013,7 +1013,7 @@ void ChannelMP3::mix(int16 *data, uint len) { ChannelMP3CDMusic::ChannelMP3CDMusic(SoundMixer *mixer, PlayingSoundHandle *handle, File *file, mad_timer_t duration) : Channel(mixer, handle) { // Create the input stream - _input = new MP3InputStream(file, duration, 0); + _input = makeMP3Stream(file, duration, 0); // Get a rate converter instance //printf("ChannelMP3CDMusic: inrate %d, outrate %d, stereo %d\n", _input->getRate(), mixer->getOutputRate(), _input->isStereo()); @@ -1034,7 +1034,7 @@ void ChannelMP3CDMusic::mix(int16 *data, uint len) { assert(_input); assert(_converter); - if (_input->eof()) { + if (_input->eos()) { // TODO: call drain method destroy(); return; @@ -1158,15 +1158,11 @@ void ChannelMP3CDMusic::mix(int16 *data, uint len) { ChannelVorbis::ChannelVorbis(SoundMixer *mixer, PlayingSoundHandle *handle, OggVorbis_File *ov_file, int duration, bool is_cd_track) : Channel(mixer, handle) { #ifdef SOX_HACK - vorbis_info *vi; - // Create the input stream - _input = new VorbisInputStream(ov_file, duration); + _input = makeVorbisStream(ov_file, duration); // Get a rate converter instance - vi = ov_info(ov_file, -1); - assert(vi->channels == 1 || vi->channels == 2); - _converter = makeRateConverter(vi->rate, mixer->getOutputRate(), _input->isStereo()); + _converter = makeRateConverter(_input->getRate(), mixer->getOutputRate(), _input->isStereo()); #else _ov_file = ov_file; @@ -1187,7 +1183,7 @@ void ChannelVorbis::mix(int16 *data, uint len) { assert(_input); assert(_converter); - if (_input->eof()) { + if (_input->eos()) { // TODO: call drain method destroy(); return; |
