2009-07-01 16:20:47 +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.
|
|
|
|
|
|
|
|
* 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.
|
|
|
|
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* $URL$
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
*/
|
2009-09-30 16:04:21 +00:00
|
|
|
|
2009-07-01 16:20:47 +00:00
|
|
|
#ifndef DRACI_ANIMATION_H
|
|
|
|
#define DRACI_ANIMATION_H
|
|
|
|
|
2009-07-03 17:50:22 +00:00
|
|
|
#include "draci/sprite.h"
|
2009-10-11 23:01:59 +00:00
|
|
|
#include "draci/sound.h"
|
2009-07-03 17:50:22 +00:00
|
|
|
|
2009-07-01 16:20:47 +00:00
|
|
|
namespace Draci {
|
|
|
|
|
2009-07-24 05:00:53 +00:00
|
|
|
/**
|
|
|
|
* Animation IDs for those animations that don't have their IDs
|
|
|
|
* specified in the data files.
|
|
|
|
*/
|
2009-09-30 10:45:14 +00:00
|
|
|
enum {
|
2009-09-30 16:04:21 +00:00
|
|
|
kOverlayImage = -1,
|
|
|
|
kWalkingMapOverlay = -2,
|
2009-11-01 12:57:06 +00:00
|
|
|
kWalkingShortestPathOverlay = -3,
|
|
|
|
kWalkingObliquePathOverlay = -4,
|
|
|
|
kTitleText = -5,
|
|
|
|
kSpeechText = -6,
|
|
|
|
kInventorySprite = -7,
|
|
|
|
kDialogueLinesID = -8,
|
|
|
|
kUnused = -12,
|
|
|
|
kInventoryItemsID = -13
|
2009-09-30 10:45:14 +00:00
|
|
|
};
|
2009-07-03 17:50:22 +00:00
|
|
|
|
2009-09-30 16:04:21 +00:00
|
|
|
/**
|
|
|
|
* Used by overlays as a neutral index that won't get
|
2009-07-24 05:00:53 +00:00
|
|
|
* released with the GPL Release command.
|
|
|
|
*/
|
|
|
|
enum { kIgnoreIndex = -2 };
|
|
|
|
|
2009-07-03 17:50:22 +00:00
|
|
|
class DraciEngine;
|
|
|
|
|
2009-07-05 11:52:17 +00:00
|
|
|
class Animation {
|
2009-07-29 19:39:10 +00:00
|
|
|
|
|
|
|
typedef void (Animation::* AnimationCallback)();
|
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
public:
|
2009-07-24 05:00:53 +00:00
|
|
|
Animation(DraciEngine *v, int index);
|
2009-09-30 10:45:14 +00:00
|
|
|
~Animation();
|
2009-09-30 16:04:21 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
uint getZ() const { return _z; }
|
|
|
|
void setZ(uint z) { _z = z; }
|
2009-09-30 16:04:21 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
void setID(int id) { _id = id; }
|
|
|
|
int getID() const { return _id; }
|
2009-07-05 03:24:46 +00:00
|
|
|
|
2009-10-30 01:56:52 +00:00
|
|
|
void nextFrame(bool force);
|
2009-07-05 03:24:46 +00:00
|
|
|
void drawFrame(Surface *surface);
|
|
|
|
|
2009-10-11 23:01:59 +00:00
|
|
|
void addFrame(Drawable *frame, const SoundSample *sample);
|
2009-11-01 12:57:06 +00:00
|
|
|
void replaceFrame(int i, Drawable *frame, const SoundSample *sample);
|
2009-10-30 01:56:52 +00:00
|
|
|
Drawable *getCurrentFrame();
|
|
|
|
Drawable *getFrame(int frameNum);
|
2009-07-30 01:12:07 +00:00
|
|
|
void setCurrentFrame(uint frame);
|
2009-10-30 06:11:04 +00:00
|
|
|
uint currentFrameNum() const { return _currentFrame; }
|
|
|
|
uint getFrameCount() const { return _frames.size(); }
|
2009-07-05 03:24:46 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
bool isPlaying() const { return _playing; }
|
2009-07-05 03:24:46 +00:00
|
|
|
void setPlaying(bool playing);
|
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
bool isPaused() const { return _paused; }
|
|
|
|
void setPaused(bool paused) { _paused = paused; }
|
2009-08-17 18:47:17 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
bool isLooping() const { return _looping; }
|
2009-07-05 03:24:46 +00:00
|
|
|
void setLooping(bool looping);
|
|
|
|
|
2009-07-20 17:25:57 +00:00
|
|
|
void setRelative(int relx, int rely);
|
2009-10-30 06:11:04 +00:00
|
|
|
int getRelativeX() const { return _displacement.relX; }
|
|
|
|
int getRelativeY() const { return _displacement.relY; }
|
2009-09-27 20:49:59 +00:00
|
|
|
const Displacement &getDisplacement() const { return _displacement; }
|
2009-07-18 02:53:37 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
int getIndex() const { return _index; }
|
|
|
|
void setIndex(int index) { _index = index; }
|
2009-07-24 05:00:53 +00:00
|
|
|
|
2009-07-24 01:54:13 +00:00
|
|
|
void setScaleFactors(double scaleX, double scaleY);
|
2009-10-30 06:11:04 +00:00
|
|
|
double getScaleX() const { return _displacement.extraScaleX; }
|
|
|
|
double getScaleY() const { return _displacement.extraScaleY; }
|
2009-07-24 01:54:13 +00:00
|
|
|
|
2009-09-25 08:13:39 +00:00
|
|
|
void markDirtyRect(Surface *surface) const;
|
2009-07-22 07:18:00 +00:00
|
|
|
|
2009-11-01 23:04:56 +00:00
|
|
|
// Animation callbacks. They can only do simple things, such as
|
|
|
|
// setting the value of some variable or stopping an animation. In
|
|
|
|
// particular, they cannot run sub-loops or anything like that, because
|
|
|
|
// the callback is called at an arbitrary time without much control
|
|
|
|
// over what the state of the rest of the program is.
|
2009-07-29 19:39:10 +00:00
|
|
|
void registerCallback(AnimationCallback callback) { _callback = callback; }
|
|
|
|
|
|
|
|
void doNothing() {}
|
|
|
|
void stopAnimation();
|
|
|
|
void exitGameLoop();
|
2009-11-05 14:22:39 +00:00
|
|
|
void tellWalkingState();
|
2009-07-29 19:39:10 +00:00
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
private:
|
2009-09-25 08:13:39 +00:00
|
|
|
uint nextFrameNum() const;
|
2009-09-27 18:11:06 +00:00
|
|
|
void deleteFrames();
|
2009-07-05 03:24:46 +00:00
|
|
|
|
2009-09-30 16:04:21 +00:00
|
|
|
/** Internal animation ID
|
2009-09-30 10:45:14 +00:00
|
|
|
* (as specified in the data files and the bytecode)
|
2009-07-24 05:00:53 +00:00
|
|
|
*/
|
2009-09-30 16:04:21 +00:00
|
|
|
int _id;
|
|
|
|
|
2009-07-24 05:00:53 +00:00
|
|
|
/** The recency index of an animation, i.e. the most recently added animation has
|
|
|
|
* the highest index. Some script commands need this.
|
|
|
|
*/
|
|
|
|
int _index;
|
|
|
|
|
2009-07-03 17:50:22 +00:00
|
|
|
uint _currentFrame;
|
|
|
|
uint _z;
|
2009-10-12 22:27:23 +00:00
|
|
|
bool _hasChangedFrame;
|
2009-07-18 02:53:37 +00:00
|
|
|
|
2009-09-27 20:49:59 +00:00
|
|
|
Displacement _displacement;
|
2009-07-24 01:54:13 +00:00
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
uint _tick;
|
|
|
|
bool _playing;
|
|
|
|
bool _looping;
|
2009-08-17 18:47:17 +00:00
|
|
|
bool _paused;
|
2009-09-27 18:11:06 +00:00
|
|
|
|
|
|
|
/** Array of frames of the animation. The animation object owns these pointers.
|
|
|
|
*/
|
2009-09-30 10:45:14 +00:00
|
|
|
Common::Array<Drawable *> _frames;
|
2009-10-11 23:01:59 +00:00
|
|
|
/** Array of samples played during the animation. The animation
|
|
|
|
* object doesn't own these pointers, but they are stored in the
|
|
|
|
* cache.
|
|
|
|
*/
|
2009-10-12 22:27:23 +00:00
|
|
|
Common::Array<const SoundSample *> _samples;
|
2009-07-05 03:24:46 +00:00
|
|
|
|
2009-07-29 19:39:10 +00:00
|
|
|
AnimationCallback _callback;
|
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
DraciEngine *_vm;
|
2009-07-03 17:50:22 +00:00
|
|
|
};
|
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
|
2009-07-05 11:52:17 +00:00
|
|
|
class AnimationManager {
|
2009-07-03 17:50:22 +00:00
|
|
|
|
|
|
|
public:
|
2009-07-24 05:00:53 +00:00
|
|
|
AnimationManager(DraciEngine *vm) : _vm(vm), _lastIndex(-1) {}
|
2009-07-05 11:52:17 +00:00
|
|
|
~AnimationManager() { deleteAll(); }
|
2009-07-03 17:50:22 +00:00
|
|
|
|
2009-10-30 01:41:57 +00:00
|
|
|
Animation *addAnimation(int id, uint z, bool playing);
|
|
|
|
Animation *addText(int id, bool playing);
|
|
|
|
Animation *addItem(int id, bool playing);
|
2009-07-03 19:05:58 +00:00
|
|
|
void addOverlay(Drawable *overlay, uint z);
|
2009-09-30 16:04:21 +00:00
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
void play(int id);
|
|
|
|
void stop(int id);
|
2009-08-17 18:47:17 +00:00
|
|
|
void pauseAnimations();
|
|
|
|
void unpauseAnimations();
|
2009-07-03 19:05:58 +00:00
|
|
|
|
2009-07-05 03:24:46 +00:00
|
|
|
void deleteAnimation(int id);
|
2009-07-07 14:52:36 +00:00
|
|
|
void deleteOverlays();
|
2009-07-03 17:50:22 +00:00
|
|
|
void deleteAll();
|
2009-07-03 19:05:58 +00:00
|
|
|
|
2009-07-03 17:50:22 +00:00
|
|
|
void drawScene(Surface *surf);
|
2009-07-03 19:05:58 +00:00
|
|
|
|
2009-07-05 11:52:17 +00:00
|
|
|
Animation *getAnimation(int id);
|
2009-07-03 17:50:22 +00:00
|
|
|
|
2009-10-30 06:11:04 +00:00
|
|
|
int getLastIndex() const { return _lastIndex; }
|
2009-07-24 05:00:53 +00:00
|
|
|
void deleteAfterIndex(int index);
|
|
|
|
|
2009-09-27 20:49:59 +00:00
|
|
|
int getTopAnimationID(int x, int y) const;
|
2009-07-27 04:18:44 +00:00
|
|
|
|
2009-07-03 17:50:22 +00:00
|
|
|
private:
|
2009-09-30 10:45:14 +00:00
|
|
|
void sortAnimations();
|
2009-07-05 11:52:17 +00:00
|
|
|
void insertAnimation(Animation *anim);
|
2009-07-03 17:50:22 +00:00
|
|
|
|
|
|
|
DraciEngine *_vm;
|
2009-09-27 18:11:06 +00:00
|
|
|
|
|
|
|
/** List of animation objects, maintained sorted by decreasing Z-coordinates.
|
|
|
|
* The animation manager owns the pointers.
|
|
|
|
*/
|
2009-07-05 11:52:17 +00:00
|
|
|
Common::List<Animation *> _animations;
|
2009-07-24 05:00:53 +00:00
|
|
|
|
2009-09-30 16:04:21 +00:00
|
|
|
/** The index of the most recently added animation.
|
2009-09-30 10:45:14 +00:00
|
|
|
* See Animation::_index for details.
|
2009-07-24 05:00:53 +00:00
|
|
|
*/
|
|
|
|
int _lastIndex;
|
2009-07-03 17:50:22 +00:00
|
|
|
};
|
|
|
|
|
2009-07-01 16:20:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // DRACI_ANIMATION_H
|