diff options
author | Paul Gilbert | 2014-03-20 21:59:43 -0400 |
---|---|---|
committer | Paul Gilbert | 2014-03-20 21:59:43 -0400 |
commit | 79f51c4ebd377ae91ec639ecf935c5fc4b2d2a32 (patch) | |
tree | a2fee7e218b589dbb6b9879e3072eb5402714cb1 | |
parent | 8df3da1556b05e5aab203125e0c61802e75b971f (diff) | |
download | scummvm-rg350-79f51c4ebd377ae91ec639ecf935c5fc4b2d2a32.tar.gz scummvm-rg350-79f51c4ebd377ae91ec639ecf935c5fc4b2d2a32.tar.bz2 scummvm-rg350-79f51c4ebd377ae91ec639ecf935c5fc4b2d2a32.zip |
MADS: Minor initial sprite slots loading fixes, missing code from SequenceList::loadSprites
-rw-r--r-- | engines/mads/events.cpp | 2 | ||||
-rw-r--r-- | engines/mads/game.cpp | 2 | ||||
-rw-r--r-- | engines/mads/scene.cpp | 2 | ||||
-rw-r--r-- | engines/mads/sequence.cpp | 97 | ||||
-rw-r--r-- | engines/mads/sequence.h | 8 |
5 files changed, 72 insertions, 39 deletions
diff --git a/engines/mads/events.cpp b/engines/mads/events.cpp index 32d3a09c18..90393d665f 100644 --- a/engines/mads/events.cpp +++ b/engines/mads/events.cpp @@ -35,7 +35,7 @@ namespace MADS { EventsManager::EventsManager(MADSEngine *vm) { _vm = vm; _cursorSprites = nullptr; - _frameCounter = 0; + _frameCounter = 10; _priorFrameTime = 0; _keyPressed = false; _mouseClicked = false; diff --git a/engines/mads/game.cpp b/engines/mads/game.cpp index 06ea2a5437..60481c69e4 100644 --- a/engines/mads/game.cpp +++ b/engines/mads/game.cpp @@ -232,7 +232,7 @@ void Game::sectionLoop() { _player.updateFrame(); _player._visible3 = _player._visible; _player._special = _scene.getDepthHighBits(_player._playerPos); - _player._priorTimer = _scene._frameStartTime + _player._ticksAmount; + _player._priorTimer = _scene._frameStartTime - _player._ticksAmount; _player.idle(); if (_scene._userInterface._selectedInvIndex >= 0) { diff --git a/engines/mads/scene.cpp b/engines/mads/scene.cpp index 154e4c38bd..e65460611e 100644 --- a/engines/mads/scene.cpp +++ b/engines/mads/scene.cpp @@ -288,9 +288,11 @@ void Scene::doFrame() { } if (!_vm->_game->_abortTimers && !player._unk3) { + // Refresh the dynamic hotspots if they've changed if (_dynamicHotspots._changed) _dynamicHotspots.refresh(); + // Check all on-screen visual objects _vm->_game->_screenObjects.check(player._stepEnabled && !_action._startWalkFlag && !_vm->_game->_abortTimers2); } diff --git a/engines/mads/sequence.cpp b/engines/mads/sequence.cpp index 684e4996bc..6288f0ad61 100644 --- a/engines/mads/sequence.cpp +++ b/engines/mads/sequence.cpp @@ -28,31 +28,37 @@ namespace MADS { - SequenceEntry::SequenceEntry() { - _spritesIndex = 0; - _flipped = 0; - _frameIndex = 0; - _frameStart = 0; - _numSprites = 0; - _animType = ANIMTYPE_NONE; - _frameInc = 0; - _depth = 0; - _scale = 0; - _dynamicHotspotIndex = -1; - _triggerCountdown = 0; - _doneFlag = 0; - _abortMode = ABORTMODE_0; - _numTicks = 0; - _extraTicks = 0; - _timeout = 0; - - _entries._count = 0; - Common::fill(&_entries._mode[0], &_entries._mode[TIMER_ENTRY_SUBSET_MAX], SM_0); - Common::fill(&_entries._frameIndex[0], &_entries._frameIndex[TIMER_ENTRY_SUBSET_MAX], 0); - Common::fill(&_entries._abortVal[0], &_entries._abortVal[TIMER_ENTRY_SUBSET_MAX], 0); - } +SequenceEntry::SequenceEntry() { + _spritesIndex = 0; + _flipped = 0; + _frameIndex = 0; + _frameStart = 0; + _numSprites = 0; + _animType = ANIMTYPE_NONE; + _frameInc = 0; + _depth = 0; + _scale = 0; + _dynamicHotspotIndex = -1; + _field18 = 0; + _field1A = 0; + _field1C = 0; + _field1E = 0; + _field20 = 0; + _field22 = 0; + _triggerCountdown = 0; + _doneFlag = 0; + _abortMode = ABORTMODE_0; + _numTicks = 0; + _extraTicks = 0; + _timeout = 0; + + _entries._count = 0; + Common::fill(&_entries._mode[0], &_entries._mode[TIMER_ENTRY_SUBSET_MAX], SM_0); + Common::fill(&_entries._frameIndex[0], &_entries._frameIndex[TIMER_ENTRY_SUBSET_MAX], 0); + Common::fill(&_entries._abortVal[0], &_entries._abortVal[TIMER_ENTRY_SUBSET_MAX], 0); +} - /*------------------------------------------------------------------------*/ +/*------------------------------------------------------------------------*/ #define SEQUENCE_LIST_SIZE 30 @@ -126,7 +132,7 @@ int SequenceList::add(int spriteListIndex, bool flipped, int frameIndex, int tri _entries[seqIndex]._triggerCountdown = triggerCountdown; _entries[seqIndex]._doneFlag = false; - _entries[seqIndex]._field13 = 0; + _entries[seqIndex]._flags = 0; _entries[seqIndex]._dynamicHotspotIndex = -1; _entries[seqIndex]._entries._count = 0; _entries[seqIndex]._abortMode = _vm->_game->_abortTimersMode2; @@ -210,30 +216,49 @@ bool SequenceList::loadSprites(int seqIndex) { if (seqEntry._spritesIndex == -1) { // Doesn't have an associated sprite anymore, so mark as done seqEntry._doneFlag = true; - } - else if ((slotIndex = scene._spriteSlots.add()) >= 0) { + } else if ((slotIndex = scene._spriteSlots.add()) >= 0) { SpriteSlot &spriteSlot = scene._spriteSlots[slotIndex]; setSpriteSlot(seqIndex, spriteSlot); - int x2 = 0, y2 = 0; - - if ((seqEntry._field13 != 0) || (seqEntry._dynamicHotspotIndex >= 0)) { + if ((seqEntry._flags != 0) || (seqEntry._dynamicHotspotIndex >= 0)) { SpriteAsset &spriteSet = *scene._sprites[seqEntry._spritesIndex]; MSprite *frame = spriteSet.getFrame(seqEntry._frameIndex - 1); int width = frame->getWidth() * seqEntry._scale / 200; int height = frame->getHeight() * seqEntry._scale / 100; + Common::Point pt = spriteSlot._position; + + // ToDO: Find out the proper meanings of the following fields + if (seqEntry._flags & 1) { + seqEntry._field20 += seqEntry._field18; + if (seqEntry._field20 >= 100) { + int v = seqEntry._field20 / 100; + seqEntry._msgPos.x += v * seqEntry._field1C; + seqEntry._field20 -= v * 100; + } - warning("frame size %d x %d", width, height); + seqEntry._field22 += seqEntry._field1A; + if (seqEntry._field22 >= 100) { + int v = seqEntry._field22 / 100; + seqEntry._msgPos.y += v * seqEntry._field1E; + seqEntry._field22 -= v * 100; + } + } - // TODO: Missing stuff here, and I'm not certain about the dynamic hotspot stuff below + if (seqEntry._flags & 2) { + if ((pt.x + width) < 0 || (pt.x + width) >= MADS_SCREEN_WIDTH || + pt.y < 0 || (pt.y + height) >= MADS_SCENE_HEIGHT) { + result = true; + seqEntry._doneFlag = true; + } + } if (seqEntry._dynamicHotspotIndex >= 0) { DynamicHotspot &dynHotspot = scene._dynamicHotspots[seqEntry._dynamicHotspotIndex]; - dynHotspot._bounds.left = MAX(x2 - width, 0); - dynHotspot._bounds.right = MAX(x2 - width, 319) - dynHotspot._bounds.left + 1; - dynHotspot._bounds.top = MAX(y2 - height, 0); - dynHotspot._bounds.bottom = MIN(y2, 155) - dynHotspot._bounds.top; + dynHotspot._bounds.left = MAX(pt.x - width, 0); + dynHotspot._bounds.top = MAX(pt.y - height, 0); + dynHotspot._bounds.right = dynHotspot._bounds.left + width; + dynHotspot._bounds.bottom = dynHotspot._bounds.top + height; scene._dynamicHotspots._changed = true; } diff --git a/engines/mads/sequence.h b/engines/mads/sequence.h index a62ad7ee7a..2645e62acc 100644 --- a/engines/mads/sequence.h +++ b/engines/mads/sequence.h @@ -62,9 +62,15 @@ struct SequenceEntry { int _dynamicHotspotIndex; bool _nonFixed; - int _field13; + uint32 _flags; Common::Point _msgPos; + int _field18; + int _field1A; + int _field1C; + int _field1E; + int _field20; + int _field22; int _triggerCountdown; bool _doneFlag; SequenceSubEntries _entries; |