aboutsummaryrefslogtreecommitdiff
path: root/engines/sci
diff options
context:
space:
mode:
Diffstat (limited to 'engines/sci')
-rw-r--r--engines/sci/sfx/music.cpp10
-rw-r--r--engines/sci/sfx/music.h2
2 files changed, 5 insertions, 7 deletions
diff --git a/engines/sci/sfx/music.cpp b/engines/sci/sfx/music.cpp
index 057b4677bf..9da4b2acbf 100644
--- a/engines/sci/sfx/music.cpp
+++ b/engines/sci/sfx/music.cpp
@@ -370,20 +370,18 @@ void SciMusic::doFade(MusicEntry *pSnd) {
pSnd->fadeTicker--;
else {
pSnd->fadeTicker = pSnd->fadeTickerStep;
- if (pSnd->volume + pSnd->fadeStep > pSnd->fadeTo) {
+ pSnd->volume += pSnd->fadeStep;
+ if (((pSnd->fadeStep > 0) && (pSnd->volume >= pSnd->fadeTo)) || ((pSnd->fadeStep < 0) && (pSnd->volume <= pSnd->fadeTo))) {
pSnd->volume = pSnd->fadeTo;
pSnd->fadeStep = 0;
- } else {
- pSnd->volume += pSnd->fadeStep;
}
pSnd->pMidiParser->setVolume(pSnd->volume);
if (pSnd->fadeStep == 0) {
// Signal the engine scripts that the sound is done fading
- // FIXME: is this correct?
- //SegManager *segMan = ((SciEngine *)g_engine)->getEngineState()->_segMan; // HACK
- //PUT_SEL32V(segMan, pSnd->soundObj, signal, SIGNAL_OFFSET);
+ SegManager *segMan = ((SciEngine *)g_engine)->getEngineState()->_segMan; // HACK
+ PUT_SEL32V(segMan, pSnd->soundObj, signal, SIGNAL_OFFSET);
}
}
}
diff --git a/engines/sci/sfx/music.h b/engines/sci/sfx/music.h
index 861ddf69e3..0c7bc2e976 100644
--- a/engines/sci/sfx/music.h
+++ b/engines/sci/sfx/music.h
@@ -71,7 +71,7 @@ struct MusicEntry {
uint16 ticker;
byte prio;
byte loop;
- byte volume;
+ int16 volume;
byte fadeTo;
short fadeStep;