2014-02-24 00:33:26 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
2015-05-09 13:56:27 +00:00
|
|
|
*
|
2014-02-24 00:33:26 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2015-05-09 13:56:27 +00:00
|
|
|
*
|
2014-02-24 00:33:26 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MADS_SCENE_H
|
|
|
|
#define MADS_SCENE_H
|
|
|
|
|
|
|
|
#include "common/scummsys.h"
|
2014-02-24 02:34:20 +00:00
|
|
|
#include "common/array.h"
|
|
|
|
#include "common/rect.h"
|
2014-02-24 05:20:53 +00:00
|
|
|
#include "mads/assets.h"
|
2014-03-14 02:25:16 +00:00
|
|
|
#include "mads/screen.h"
|
2014-03-06 02:50:12 +00:00
|
|
|
#include "mads/hotspots.h"
|
2014-03-04 04:40:23 +00:00
|
|
|
#include "mads/messages.h"
|
2014-02-26 04:10:51 +00:00
|
|
|
#include "mads/msurface.h"
|
2014-02-25 14:21:19 +00:00
|
|
|
#include "mads/scene_data.h"
|
2014-03-02 16:38:56 +00:00
|
|
|
#include "mads/animation.h"
|
2014-03-29 21:12:12 +00:00
|
|
|
#include "mads/rails.h"
|
2014-03-04 01:53:27 +00:00
|
|
|
#include "mads/sequence.h"
|
2014-03-05 03:33:27 +00:00
|
|
|
#include "mads/sprites.h"
|
2014-03-15 22:43:39 +00:00
|
|
|
#include "mads/user_interface.h"
|
2014-02-24 00:33:26 +00:00
|
|
|
|
|
|
|
namespace MADS {
|
|
|
|
|
2015-03-14 01:54:20 +00:00
|
|
|
enum { RETURNING_FROM_DIALOG = -2, RETURNING_FROM_LOADING = -1 };
|
|
|
|
|
2014-02-24 00:33:26 +00:00
|
|
|
class Scene {
|
2014-02-24 05:20:53 +00:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Return the index of a given Vocab in the active vocab list
|
|
|
|
*/
|
|
|
|
int activeVocabIndexOf(int vocabId);
|
|
|
|
|
2014-02-25 14:21:19 +00:00
|
|
|
/**
|
|
|
|
* Secondary loading vocab list
|
|
|
|
*/
|
|
|
|
void loadVocabStrings();
|
2014-03-02 15:49:20 +00:00
|
|
|
|
2014-03-03 04:09:17 +00:00
|
|
|
/**
|
|
|
|
* Handles a single frame within the game scene
|
|
|
|
*/
|
|
|
|
void doFrame();
|
2014-03-03 05:42:41 +00:00
|
|
|
|
|
|
|
void doPreactions();
|
|
|
|
|
|
|
|
void doAction();
|
|
|
|
|
2014-03-29 15:18:07 +00:00
|
|
|
/**
|
|
|
|
* Calls all the necessary step handlers for the current frame
|
|
|
|
*/
|
2014-03-03 05:42:41 +00:00
|
|
|
void doSceneStep();
|
|
|
|
|
2014-04-09 02:04:43 +00:00
|
|
|
/**
|
|
|
|
* Checks whether there's a pending keypress, and if so handles it.
|
|
|
|
*/
|
2014-03-03 05:42:41 +00:00
|
|
|
void checkKeyboard();
|
2014-03-24 02:11:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks for a highlighted hotspot, and updates the cursor accordingly
|
|
|
|
*/
|
|
|
|
void updateCursor();
|
2014-02-24 05:20:53 +00:00
|
|
|
protected:
|
|
|
|
MADSEngine *_vm;
|
2014-02-24 00:33:26 +00:00
|
|
|
public:
|
2014-02-24 05:20:53 +00:00
|
|
|
SceneLogic *_sceneLogic;
|
2014-05-24 22:19:54 +00:00
|
|
|
MSurface _sceneSurface;
|
2014-02-24 00:33:26 +00:00
|
|
|
int _priorSceneId;
|
|
|
|
int _nextSceneId;
|
|
|
|
int _currentSceneId;
|
2014-02-25 01:05:35 +00:00
|
|
|
Common::Array<VerbInit> _verbList;
|
2014-03-04 04:40:23 +00:00
|
|
|
TextDisplayList _textDisplay;
|
2014-02-26 00:52:35 +00:00
|
|
|
SpriteSlots _spriteSlots;
|
2014-03-02 22:49:52 +00:00
|
|
|
SpriteSets _sprites;
|
2014-03-03 04:09:17 +00:00
|
|
|
DynamicHotspots _dynamicHotspots;
|
2014-02-24 05:20:53 +00:00
|
|
|
Common::Array<int> _activeVocabs;
|
2014-03-04 01:53:27 +00:00
|
|
|
SequenceList _sequences;
|
2014-03-04 14:33:57 +00:00
|
|
|
KernelMessages _kernelMessages;
|
2014-03-29 21:12:12 +00:00
|
|
|
Rails _rails;
|
2014-02-25 01:05:35 +00:00
|
|
|
Common::String _talkFont;
|
|
|
|
int _textSpacing;
|
2014-03-15 21:38:44 +00:00
|
|
|
Hotspots _hotspots;
|
2014-03-04 04:40:23 +00:00
|
|
|
DirtyAreas _dirtyAreas;
|
2014-04-06 02:41:25 +00:00
|
|
|
int _variant;
|
2014-02-26 04:10:51 +00:00
|
|
|
SceneInfo *_sceneInfo;
|
|
|
|
MSurface _backgroundSurface;
|
2014-03-07 03:31:41 +00:00
|
|
|
DepthSurface _depthSurface;
|
2014-03-15 22:43:39 +00:00
|
|
|
UserInterface _userInterface;
|
2014-04-13 02:08:21 +00:00
|
|
|
bool _cyclingActive;
|
2014-04-20 02:49:14 +00:00
|
|
|
int _cyclingThreshold;
|
|
|
|
int _cyclingDelay;
|
|
|
|
int _totalCycleColors;
|
|
|
|
Common::Array<uint32> _cycleTicks;
|
|
|
|
Common::Array<PaletteCycle> _paletteCycles;
|
2014-03-02 15:49:20 +00:00
|
|
|
Common::StringArray _vocabStrings;
|
2014-03-08 04:07:36 +00:00
|
|
|
Animation *_animationData;
|
2015-09-21 19:18:19 +00:00
|
|
|
Animation *_animation[10];
|
2014-03-03 05:42:41 +00:00
|
|
|
bool _freeAnimationFlag;
|
2014-03-02 21:42:39 +00:00
|
|
|
int _depthStyle;
|
2014-03-02 23:37:09 +00:00
|
|
|
int _bandsRange;
|
|
|
|
int _scaleRange;
|
|
|
|
int _interfaceY;
|
|
|
|
int _spritesCount;
|
2014-03-03 01:06:21 +00:00
|
|
|
MADSAction _action;
|
2014-03-03 01:50:35 +00:00
|
|
|
bool _roomChanged;
|
|
|
|
bool _reloadSceneFlag;
|
2014-03-04 04:40:23 +00:00
|
|
|
Common::Point _posAdjust;
|
2014-03-08 19:05:17 +00:00
|
|
|
uint32 _frameStartTime;
|
2015-01-18 01:51:52 +00:00
|
|
|
ScreenMode _mode;
|
2014-03-20 03:33:18 +00:00
|
|
|
bool _lookFlag;
|
|
|
|
Common::Point _customDest;
|
2014-04-12 15:00:29 +00:00
|
|
|
Common::Array<PaletteUsage::UsageEntry> _paletteUsageF;
|
|
|
|
Common::Array<PaletteUsage::UsageEntry> _scenePaletteUsage;
|
2014-02-24 02:34:20 +00:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2014-02-24 05:20:53 +00:00
|
|
|
Scene(MADSEngine *vm);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor
|
|
|
|
*/
|
|
|
|
~Scene();
|
2014-02-24 02:34:20 +00:00
|
|
|
|
2014-09-04 02:09:50 +00:00
|
|
|
void restrictScene();
|
|
|
|
|
2014-02-24 05:20:53 +00:00
|
|
|
/**
|
|
|
|
* Clear the vocabulary list
|
|
|
|
*/
|
|
|
|
void clearVocab();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a given vocab entry to the active list
|
|
|
|
*/
|
|
|
|
void addActiveVocab(int vocabId);
|
|
|
|
|
2014-05-20 02:43:49 +00:00
|
|
|
/**
|
|
|
|
* Get the number of entries in the game's vocabulary
|
|
|
|
*/
|
|
|
|
uint32 getVocabStringsCount() const;
|
|
|
|
|
2014-02-25 01:05:35 +00:00
|
|
|
/**
|
|
|
|
* Clear the sequence list
|
|
|
|
*/
|
|
|
|
void clearSequenceList();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear the message list
|
|
|
|
*/
|
|
|
|
void clearMessageList();
|
|
|
|
|
2014-02-24 05:20:53 +00:00
|
|
|
/**
|
|
|
|
* Loads the scene logic for a given scene
|
|
|
|
*/
|
2014-02-25 01:05:35 +00:00
|
|
|
void loadSceneLogic();
|
|
|
|
|
2014-02-26 00:52:35 +00:00
|
|
|
/**
|
|
|
|
* Loads the resources associated with the given scene
|
|
|
|
* @param sceneId Scene to load
|
|
|
|
* @param prefix Prefix to use for retrieving animation data
|
|
|
|
* @param palFlag Flag for whether to reset the high/lo palette areas
|
|
|
|
*/
|
|
|
|
void loadScene(int sceneId, const Common::String &prefix, bool palFlag);
|
|
|
|
|
2014-02-25 01:05:35 +00:00
|
|
|
/**
|
|
|
|
* Loads the hotstpots for the scene
|
|
|
|
*/
|
|
|
|
void loadHotspots();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the vocab list
|
|
|
|
*/
|
|
|
|
void loadVocab();
|
2014-02-26 00:52:35 +00:00
|
|
|
|
2014-03-03 01:50:35 +00:00
|
|
|
bool getDepthHighBits(const Common::Point &pt);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Main scene loop
|
|
|
|
*/
|
|
|
|
void loop();
|
2014-03-03 00:29:54 +00:00
|
|
|
|
2014-03-04 14:33:57 +00:00
|
|
|
/**
|
|
|
|
* Draw all the elements onto the scene
|
|
|
|
*/
|
2014-03-10 04:00:39 +00:00
|
|
|
void drawElements(ScreenTransition transitionType, bool surfaceFlag);
|
2014-03-04 14:33:57 +00:00
|
|
|
|
2014-10-11 22:21:49 +00:00
|
|
|
/*
|
|
|
|
* Initializes the data for palette animation within the scene
|
|
|
|
*/
|
|
|
|
void initPaletteAnimation(Common::Array<PaletteCycle> &palCycles, bool animFlag);
|
|
|
|
|
2014-04-20 02:49:14 +00:00
|
|
|
/**
|
|
|
|
* Handles cycling palette colors for the scene
|
|
|
|
*/
|
|
|
|
void animatePalette();
|
|
|
|
|
2014-03-08 04:07:36 +00:00
|
|
|
/**
|
|
|
|
* Load an animation
|
|
|
|
*/
|
2015-10-15 09:21:31 +00:00
|
|
|
int loadAnimation(const Common::String &resName, int trigger = 0);
|
2014-03-08 04:07:36 +00:00
|
|
|
|
2014-03-17 03:40:21 +00:00
|
|
|
/**
|
|
|
|
* Returns a vocab entry
|
|
|
|
*/
|
2014-03-17 04:20:50 +00:00
|
|
|
Common::String getVocab(int vocabId) { return _vocabStrings[vocabId - 1]; }
|
2014-03-17 03:40:21 +00:00
|
|
|
|
2014-02-24 05:20:53 +00:00
|
|
|
/**
|
2014-04-16 12:44:12 +00:00
|
|
|
* Clear the data for the currently loaded scene
|
2014-02-24 05:20:53 +00:00
|
|
|
*/
|
2014-04-16 12:44:12 +00:00
|
|
|
void freeCurrentScene();
|
2014-03-22 18:25:26 +00:00
|
|
|
|
2014-04-06 02:41:25 +00:00
|
|
|
/**
|
|
|
|
* Set the walk surface for a scene to a different variant
|
|
|
|
*/
|
|
|
|
void changeVariant(int variant);
|
2014-03-22 18:25:26 +00:00
|
|
|
|
2014-03-24 00:14:16 +00:00
|
|
|
void resetScene();
|
2014-04-03 00:28:57 +00:00
|
|
|
|
2014-04-07 01:24:35 +00:00
|
|
|
/**
|
2014-05-08 08:43:23 +00:00
|
|
|
* Removes all the scene specific sprites fromt the sprites list,
|
2014-04-07 01:24:35 +00:00
|
|
|
* leaving any player sprites list in place at the start of the list.
|
|
|
|
*/
|
|
|
|
void removeSprites();
|
2014-04-19 18:46:28 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Frees any currently active animation for the scene
|
|
|
|
*/
|
|
|
|
void freeAnimation();
|
2014-04-23 03:00:41 +00:00
|
|
|
|
2015-10-12 08:53:46 +00:00
|
|
|
/**
|
|
|
|
* Frees any given active animation for the scene
|
|
|
|
*/
|
|
|
|
void freeAnimation(int idx);
|
|
|
|
|
2014-04-23 03:00:41 +00:00
|
|
|
/**
|
2014-05-26 22:58:25 +00:00
|
|
|
* Synchronize the game
|
2014-04-23 03:00:41 +00:00
|
|
|
*/
|
|
|
|
void synchronize(Common::Serializer &s);
|
2015-10-10 15:32:51 +00:00
|
|
|
|
2015-10-15 09:21:31 +00:00
|
|
|
void setAnimFrame(int id, int val);
|
|
|
|
int getAnimFrame(int id);
|
|
|
|
|
2015-10-10 15:32:51 +00:00
|
|
|
void setDynamicAnim(int id, int anim_id, int segment);
|
|
|
|
void setCamera(Common::Point pos);
|
2015-11-09 10:09:30 +00:00
|
|
|
void drawToBackground(int spriteId, int frameId, Common::Point pos, int depth, int scale);
|
2015-10-13 07:09:50 +00:00
|
|
|
void deleteSequence(int idx);
|
2015-10-17 23:07:06 +00:00
|
|
|
void loadSpeech(int idx);
|
|
|
|
void playSpeech(int idx);
|
2015-11-11 00:50:37 +00:00
|
|
|
void sceneScale(int yFront, int maxScale, int yBack, int minScale);
|
2015-10-20 12:07:26 +00:00
|
|
|
void animations_tick();
|
2015-11-10 08:04:25 +00:00
|
|
|
|
2015-10-25 18:02:11 +00:00
|
|
|
int _speechReady;
|
2014-02-24 00:33:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // End of namespace MADS
|
|
|
|
|
|
|
|
#endif /* MADS_SCENE_H */
|