aboutsummaryrefslogtreecommitdiff
path: root/engines/director
diff options
context:
space:
mode:
authorDmitry Iskrich2016-06-09 19:08:44 +0300
committerEugene Sandulenko2016-08-03 23:40:36 +0200
commitfd3c3368600337d837b5a9d3e886a4674e475174 (patch)
tree52877f44451ca7b5e5c4fbf83f990dd0a51563e5 /engines/director
parentd01fddfa6b39afa897cb1e1d694db127298da5cc (diff)
downloadscummvm-rg350-fd3c3368600337d837b5a9d3e886a4674e475174.tar.gz
scummvm-rg350-fd3c3368600337d837b5a9d3e886a4674e475174.tar.bz2
scummvm-rg350-fd3c3368600337d837b5a9d3e886a4674e475174.zip
DIRECTOR: Refactor in accordance with Director Loop, generate main lingo events
Diffstat (limited to 'engines/director')
-rw-r--r--engines/director/director.cpp4
-rw-r--r--engines/director/lingo/lingo.cpp1
-rw-r--r--engines/director/lingo/lingo.h1
-rw-r--r--engines/director/score.cpp72
-rw-r--r--engines/director/score.h16
5 files changed, 77 insertions, 17 deletions
diff --git a/engines/director/director.cpp b/engines/director/director.cpp
index 9108225565..50c4fbdb4c 100644
--- a/engines/director/director.cpp
+++ b/engines/director/director.cpp
@@ -73,8 +73,8 @@ Common::Error DirectorEngine::run() {
_mainArchive = new RIFFArchive();
_mainArchive->openFile("bookshelf_example.mmm");
- Score score(*_mainArchive);
- score.play();
+ Score score(*_mainArchive, *_lingo);
+ score.startLoop();
if (getPlatform() == Common::kPlatformWindows)
loadEXE();
diff --git a/engines/director/lingo/lingo.cpp b/engines/director/lingo/lingo.cpp
index bf06f45de7..fe192cce2f 100644
--- a/engines/director/lingo/lingo.cpp
+++ b/engines/director/lingo/lingo.cpp
@@ -38,6 +38,7 @@ struct EventHandlerType {
{ kEventEnterFrame, "enterFrame" },
{ kEventPrepareFrame, "prepareFrame" },
+ { kEventStepFrame, "stepFrame"},
{ kEventExitFrame, "exitFrame" },
{ kEventActivateWindow, "activateWindow" },
diff --git a/engines/director/lingo/lingo.h b/engines/director/lingo/lingo.h
index 7aa11fb863..65ead5fa55 100644
--- a/engines/director/lingo/lingo.h
+++ b/engines/director/lingo/lingo.h
@@ -40,6 +40,7 @@ enum LEvent {
kEventNone,
kEventEnterFrame,
kEventPrepareFrame,
+ kEventStepFrame,
kEventExitFrame,
kEventActivateWindow,
diff --git a/engines/director/score.cpp b/engines/director/score.cpp
index bc79ee9222..b95a50e352 100644
--- a/engines/director/score.cpp
+++ b/engines/director/score.cpp
@@ -29,6 +29,7 @@
#include "common/system.h"
#include "director/dib.h"
#include "director/resource.h"
+#include "lingo/lingo.h"
#include "graphics/palette.h"
#include "common/events.h"
@@ -37,10 +38,14 @@
namespace Director {
-Score::Score(Archive &movie) {
+Score::Score(Archive &movie, Lingo &lingo) {
_surface = new Graphics::ManagedSurface;
_movieArchive = &movie;
+ _lingo = &lingo;
+
+ _lingo->processEvent(kEventPrepareMovie, 0);
+
assert(_movieArchive->hasResource(MKTAG('V','W','S','C'), 1024));
assert(_movieArchive->hasResource(MKTAG('V','W','C','F'), 1024));
assert(_movieArchive->hasResource(MKTAG('V','W','C','R'), 1024));
@@ -124,7 +129,7 @@ void Score::loadConfig(Common::SeekableReadStream &stream) {
_castArrayEnd = stream.readUint16BE();
_currentFrameRate = stream.readByte();
stream.skip(9);
- /*uint16 stageColor = */ stream.readUint16BE();
+ _stageColor = stream.readUint16BE();
}
void Score::readVersion(uint32 rid) {
@@ -400,27 +405,48 @@ Common::Rect Score::readRect(Common::SeekableReadStream &stream) {
return *rect;
}
-void Score::play() {
+void Score::startLoop() {
initGraphics(_movieRect.width(), _movieRect.height(), true);
_surface->create(_movieRect.width(), _movieRect.height());
_currentFrame = 0;
_stopPlay = false;
_nextFrameTime = 0;
+
+ _lingo->processEvent(kEventStartMovie, 0);
+
while (!_stopPlay && _currentFrame < _frames.size() - 2) {
- display();
+ update();
processEvents();
g_system->updateScreen();
g_system->delayMillis(10);
}
}
-void Score::display() {
+void Score::update() {
if (g_system->getMillis() < _nextFrameTime)
return;
- _frames[_currentFrame]->display(*_movieArchive, *_surface, _movieRect);
+ _surface->clear(_stageColor);
+
+ //Exit from previous frame, and step to next
+ _lingo->processEvent(kEventExitFrame, _currentFrame - 1);
+ _lingo->processEvent(kEventStepFrame, _currentFrame);
+
+ //Director step: send beginSprite event to any sprites whose span begin in the upcoming frame
+ for (uint16 i = 0; i < CHANNEL_COUNT; i++) {
+ if (_frames[_currentFrame]->_sprites[i]->_enabled)
+ _lingo->processEvent(kEventBeginSprite, i);
+ }
+
+ //Director step: send prepareFrame event to all sprites and the script channel in upcoming frame
+ _lingo->processEvent(kEventPrepareFrame, _currentFrame);
+ _frames[_currentFrame]->prepareFrame(*_movieArchive, *_surface, _movieRect);
+ //Stage is drawn between the prepareFrame and enterFrame events (Lingo in a Nutshell)
+ _lingo->processEvent(kEventEnterFrame, _currentFrame);
+
_currentFrame++;
byte tempo = _frames[_currentFrame]->_tempo;
+
if (tempo) {
if (tempo > 161) {
//Delay
@@ -605,6 +631,8 @@ void Frame::readSprite(Common::SeekableReadStream &stream, uint16 offset, uint16
case kSpritePositionFlags:
sprite._flags = stream.readUint16BE();
sprite._ink = static_cast<inkType>(sprite._flags & 0x3f); //TODO more flags?
+ sprite._trails = sprite._flags & 0x40;
+ debug("%d", sprite._trails);
fieldPosition += 2;
break;
case kSpritePositionCastId:
@@ -636,15 +664,31 @@ void Frame::readSprite(Common::SeekableReadStream &stream, uint16 offset, uint16
}
}
-void Frame::display(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect moviRect) {
- surface.clear();
+void Frame::prepareFrame(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect) {
+ renderSprites(_movie, surface, movieRect);
+ renderTrailSprites(_movie, surface, movieRect);
+ if (_transType != 0)
+ playTranisition();
+ if (_sound1 != 0)
+ playSoundChannel(_sound1);
+ if (_sound2 != 0)
+ playSoundChannel(_sound2);
+}
+
+void Frame::playSoundChannel(uint16 id) {
+ warning("STUB: playSound(%d)", id);
+}
+
+void Frame::playTranisition() {
+ warning("STUB: playTranisition(%d, %d, %d)", _transType, _transFlags, _transChunkSize);
+}
+void Frame::renderSprites(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect) {
for (uint16 i = 0; i < CHANNEL_COUNT; i++) {
+ //TODO if trails == 0 -> render as trail sprite
if (_sprites[i]->_enabled) {
DIBDecoder img;
- //TODO check cast type
uint32 imgId = 1024 + _sprites[i]->_castId;
- //TODO looks like bad file?
if (!_movie.hasResource(MKTAG('D', 'I', 'B', ' '), imgId)) {
continue;
}
@@ -669,7 +713,6 @@ void Frame::display(Archive &_movie, Graphics::ManagedSurface &surface, Common::
height += y;
y = 0;
}
-
Common::Rect drawRect = Common::Rect(x, y, x + width, y + height);
switch (_sprites[i]->_ink) {
@@ -692,6 +735,13 @@ void Frame::display(Archive &_movie, Graphics::ManagedSurface &surface, Common::
g_system->copyRectToScreen(surface.getPixels(), surface.pitch, 0, 0, surface.getBounds().width(), surface.getBounds().height());
}
+void Frame::renderTrailSprites(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect) {
+ for (uint16 i = 0; i < CHANNEL_COUNT; i++) {
+ if (_sprites[i]->_enabled && _sprites[i]->_trails != 0)
+ warning("STUB: renderTrailSprites(%d)", i);
+ }
+}
+
void Frame::drawBackgndTransSprite(Graphics::ManagedSurface &target, const Graphics::Surface &sprite, Common::Rect &drawRect) {
uint8 skipColor = 15; //FIXME is it always white (last entry in pallette) ?
for (int ii = 0; ii < sprite.h; ii++) {
diff --git a/engines/director/score.h b/engines/director/score.h
index 09e3377e8a..9f0be8a442 100644
--- a/engines/director/score.h
+++ b/engines/director/score.h
@@ -29,6 +29,7 @@
#include "director/resource.h"
#include "graphics/managed_surface.h"
#include "common/str.h"
+#include "lingo/lingo.h"
namespace Director {
@@ -217,6 +218,7 @@ public:
bool _enabled;
byte _castId;
inkType _ink;
+ uint16 _trails;
Cast *_cast;
uint16 _flags;
Common::Point _startPoint;
@@ -230,9 +232,13 @@ public:
~Frame();
Frame(const Frame &frame);
void readChannel(Common::SeekableReadStream &stream, uint16 offset, uint16 size);
- void display(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect moviRect);
+ void prepareFrame(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect);
private:
+ void playTranisition();
+ void playSoundChannel(uint16 id);
+ void renderSprites(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect);
+ void renderTrailSprites(Archive &_movie, Graphics::ManagedSurface &surface, Common::Rect movieRect);
void readSprite(Common::SeekableReadStream &stream, uint16 offset, uint16 size);
void readMainChannels(Common::SeekableReadStream &stream, uint16 offset, uint16 size);
void drawBackgndTransSprite(Graphics::ManagedSurface &target, const Graphics::Surface &sprite, Common::Rect &drawRect);
@@ -256,13 +262,13 @@ public:
class Score {
public:
- Score(Archive &movie);
+ Score(Archive &movie, Lingo &lingo);
static Common::Rect readRect(Common::SeekableReadStream &stream);
- void play();
+ void startLoop();
private:
void processEvents();
- void display();
+ void update();
void readVersion(uint32 rid);
void loadConfig(Common::SeekableReadStream &stream);
void loadCastData(Common::SeekableReadStream &stream);
@@ -296,8 +302,10 @@ private:
bool _stopPlay;
uint16 _castArrayEnd;
Common::Rect _movieRect;
+ uint16 _stageColor;
Archive *_movieArchive;
Graphics::ManagedSurface *_surface;
+ Lingo *_lingo;
};
} //End of namespace Director