diff options
author | Sven Hesse | 2007-01-31 13:17:50 +0000 |
---|---|---|
committer | Sven Hesse | 2007-01-31 13:17:50 +0000 |
commit | 7101c0ef260fb1f095b8e04a5dc1ceb9e99cf759 (patch) | |
tree | e640d6e565b51bb7b251fb0b3bda68ddc05d468d /engines/gob/inter_v2.cpp | |
parent | 836a4ea99e36cdfda21d77f3bd8c41d9db824d49 (diff) | |
download | scummvm-rg350-7101c0ef260fb1f095b8e04a5dc1ceb9e99cf759.tar.gz scummvm-rg350-7101c0ef260fb1f095b8e04a5dc1ceb9e99cf759.tar.bz2 scummvm-rg350-7101c0ef260fb1f095b8e04a5dc1ceb9e99cf759.zip |
- Correctly setting of Snd::_playingSound
- Implemented sound fading in/out
- o2_stub0x81 -> o2_scroll
svn-id: r25307
Diffstat (limited to 'engines/gob/inter_v2.cpp')
-rw-r--r-- | engines/gob/inter_v2.cpp | 51 |
1 files changed, 33 insertions, 18 deletions
diff --git a/engines/gob/inter_v2.cpp b/engines/gob/inter_v2.cpp index 95e13ff43a..278c618e70 100644 --- a/engines/gob/inter_v2.cpp +++ b/engines/gob/inter_v2.cpp @@ -286,7 +286,7 @@ void Inter_v2::setupOpcodes(void) { {NULL, ""}, /* 80 */ OPCODE(o2_initScreen), - OPCODE(o2_stub0x81), + OPCODE(o2_scroll), OPCODE(o2_setScrollOffset), OPCODE(o2_playImd), /* 84 */ @@ -812,23 +812,6 @@ void Inter_v2::o2_stub0x55(void) { } } -void Inter_v2::o2_stub0x81(void) { - int16 var1; - int16 var2; - int16 var3; - int16 var4; - int16 var5; - int16 var6; - - var1 = _vm->_parse->parseValExpr(); - var2 = _vm->_parse->parseValExpr(); - var3 = _vm->_parse->parseValExpr(); - var4 = _vm->_parse->parseValExpr(); - var5 = _vm->_parse->parseValExpr(); - var6 = _vm->_parse->parseValExpr(); - warning("GOB2 Stub! o2_stub0x81(%d, %d, %d, %d, %d, %d)", var1, var2, var3, var4, var5, var6); -} - void Inter_v2::o2_stub0x85(void) { char dest[32]; @@ -1508,6 +1491,7 @@ bool Inter_v2::o2_goblinFunc(char &cmdCount, int16 &counter, int16 &retFlag) { cmd = load16(); _vm->_global->_inter_execPtr += 2; + warning("goblinFunc %d", cmd); if (cmd != 101) executeGoblinOpcode(cmd, extraData, NULL, NULL); return false; @@ -2231,6 +2215,37 @@ void Inter_v2::o2_setScrollOffset(void) { */ } +void Inter_v2::o2_scroll(void) { + int16 startX; + int16 startY; + int16 endX; + int16 endY; + int16 stepX; + int16 stepY; + int16 curX; + int16 curY; + + startX = _vm->_parse->parseValExpr(); + startY = _vm->_parse->parseValExpr(); + endX = _vm->_parse->parseValExpr(); + endY = _vm->_parse->parseValExpr(); + stepX = _vm->_parse->parseValExpr(); + stepY = _vm->_parse->parseValExpr(); + + if ((stepY != 0) || (startY > 0) || (endY > 0)) + warning("GOB2 Stub! Vertical scrolling / high surfaces"); + + curX = startX; + curY = startY; + while ((curX != endX) || (curY != endY)) { + curX = stepX > 0 ? MIN(curX + stepX, (int) endX) : MAX(curX + stepX, (int) endX); + curY = stepY > 0 ? MIN(curY + stepY, (int) endY) : MAX(curY + stepY, (int) endY); + _vm->_draw->_word_2FC9E = curX; + _vm->_video->_scrollOffset = _vm->_draw->_word_2FC9E; + _vm->_video->waitRetrace(_vm->_global->_videoMode); + } +} + void Inter_v2::o2_totSub(void) { char totFile[14]; byte length; |