diff options
author | Filippos Karapetis | 2009-01-14 13:55:36 +0000 |
---|---|---|
committer | Filippos Karapetis | 2009-01-14 13:55:36 +0000 |
commit | f79007d6cf52820f900a9d3fb0e2a48e92ab1e4a (patch) | |
tree | 3ded7c1e37d5e62c98b4617bad8c531c22fc0078 /engines | |
parent | 405680af6de7dfb09ca703eb08cecf1debe82893 (diff) | |
download | scummvm-rg350-f79007d6cf52820f900a9d3fb0e2a48e92ab1e4a.tar.gz scummvm-rg350-f79007d6cf52820f900a9d3fb0e2a48e92ab1e4a.tar.bz2 scummvm-rg350-f79007d6cf52820f900a9d3fb0e2a48e92ab1e4a.zip |
Fix for non-looped tracks of the music enhancement project. Also, got rid of the dwMidiIndex variable
svn-id: r35862
Diffstat (limited to 'engines')
-rw-r--r-- | engines/tinsel/music.cpp | 27 |
1 files changed, 8 insertions, 19 deletions
diff --git a/engines/tinsel/music.cpp b/engines/tinsel/music.cpp index e3daf8fb55..54a7656d44 100644 --- a/engines/tinsel/music.cpp +++ b/engines/tinsel/music.cpp @@ -61,9 +61,6 @@ struct SOUND_BUFFER { //static MDI_DRIVER *mDriver; //static HSEQUENCE mSeqHandle; -// if non-zero this is the index position of the next MIDI sequence to play -static uint32 dwMidiIndex = 0; - // MIDI buffer static SOUND_BUFFER midiBuffer = { 0, 0 }; @@ -183,18 +180,12 @@ bool PlayMidiSequence(uint32 dwFileOffset, bool bLoop) { SetMidiVolume(volMusic); } - // set file offset for this sequence - dwMidiIndex = dwFileOffset; - // the index and length of the last tune loaded static uint32 dwLastMidiIndex; //static uint32 dwLastSeqLen; uint32 dwSeqLen = 0; // length of the sequence - if (dwMidiIndex == 0) - return true; - // Support for external music from the music enhancement project if (_vm->getFeatures() & GF_ENHANCED_AUDIO_SUPPORT) { int trackNumber = GetTrackNumber(dwFileOffset); @@ -208,13 +199,11 @@ bool PlayMidiSequence(uint32 dwFileOffset, bool bLoop) { if (track > 0) { StopMidi(); - AudioCD.play(track, bLoop ? -1 : 0, 0, 0); + AudioCD.play(track, bLoop ? -1 : 1, 0, 0); // Check if an enhanced audio track is being played. // If it is, stop here and don't load a MIDI track if (AudioCD.isPlaying()) { - // allow another sequence to play - dwMidiIndex = 0; return true; } } @@ -223,7 +212,10 @@ bool PlayMidiSequence(uint32 dwFileOffset, bool bLoop) { } } - if (dwMidiIndex != dwLastMidiIndex) { + if (dwFileOffset == 0) + return true; + + if (dwFileOffset != dwLastMidiIndex) { Common::File midiStream; // open MIDI sequence file in binary mode @@ -231,10 +223,10 @@ bool PlayMidiSequence(uint32 dwFileOffset, bool bLoop) { error(CANNOT_FIND_FILE, MIDI_FILE); // update index of last tune loaded - dwLastMidiIndex = dwMidiIndex; + dwLastMidiIndex = dwFileOffset; // move to correct position in the file - midiStream.seek(dwMidiIndex, SEEK_SET); + midiStream.seek(dwFileOffset, SEEK_SET); // read the length of the sequence dwSeqLen = midiStream.readUint32LE(); @@ -256,14 +248,11 @@ bool PlayMidiSequence(uint32 dwFileOffset, bool bLoop) { // Store the length //dwLastSeqLen = dwSeqLen; } else { - // dwMidiIndex == dwLastMidiIndex + // dwFileOffset == dwLastMidiIndex _vm->_midiMusic->stop(); _vm->_midiMusic->playXMIDI(midiBuffer.pDat, dwSeqLen, bLoop); } - // allow another sequence to play - dwMidiIndex = 0; - return true; } |