diff options
author | Paul Gilbert | 2014-08-04 21:35:49 -0400 |
---|---|---|
committer | Paul Gilbert | 2014-08-04 21:35:49 -0400 |
commit | bb48a153a6479e08fe37c3547e14622226efeeb2 (patch) | |
tree | 426d41999bd0e272c14af45ea803431e8d841f6d | |
parent | 04d42638cde9022523910b9ec75130bd85ec1fa5 (diff) | |
download | scummvm-rg350-bb48a153a6479e08fe37c3547e14622226efeeb2.tar.gz scummvm-rg350-bb48a153a6479e08fe37c3547e14622226efeeb2.tar.bz2 scummvm-rg350-bb48a153a6479e08fe37c3547e14622226efeeb2.zip |
ACCESS: Remove graphics manager, and added more skeleton for Amazon intro
-rw-r--r-- | engines/access/access.cpp | 9 | ||||
-rw-r--r-- | engines/access/access.h | 6 | ||||
-rw-r--r-- | engines/access/amazon/amazon_game.cpp | 39 | ||||
-rw-r--r-- | engines/access/amazon/amazon_game.h | 22 | ||||
-rw-r--r-- | engines/access/asurface.cpp (renamed from engines/access/graphics.cpp) | 19 | ||||
-rw-r--r-- | engines/access/asurface.h (renamed from engines/access/graphics.h) | 22 | ||||
-rw-r--r-- | engines/access/module.mk | 2 | ||||
-rw-r--r-- | engines/access/screen.cpp | 9 | ||||
-rw-r--r-- | engines/access/screen.h | 13 |
9 files changed, 94 insertions, 47 deletions
diff --git a/engines/access/access.cpp b/engines/access/access.cpp index 1470842e1b..af64612e01 100644 --- a/engines/access/access.cpp +++ b/engines/access/access.cpp @@ -34,7 +34,6 @@ AccessEngine::AccessEngine(OSystem *syst, const AccessGameDescription *gameDesc) _debugger = nullptr; _events = nullptr; _files = nullptr; - _graphics = nullptr; _screen = nullptr; _sound = nullptr; @@ -46,7 +45,6 @@ AccessEngine::~AccessEngine() { delete _debugger; delete _events; delete _files; - delete _graphics; delete _screen; delete _sound; @@ -68,7 +66,6 @@ void AccessEngine::initialize() { _debugger = new Debugger(this); _events = new EventsManager(this); _files = new FileManager(this); - _graphics = new GraphicsManager(this); _screen = new Screen(this); _sound = new SoundManager(this, _mixer); @@ -80,11 +77,7 @@ Common::Error AccessEngine::run() { setVGA(); initialize(); - _screen->setInitialPalettte(); - _events->setCursor(CURSOR_0); - _events->showCursor(); - _graphics->setPanel(0); - doTitle(); + playGame(); dummyLoop(); return Common::kNoError; diff --git a/engines/access/access.h b/engines/access/access.h index 05ef545e38..f6d51cc744 100644 --- a/engines/access/access.h +++ b/engines/access/access.h @@ -33,7 +33,6 @@ #include "access/debugger.h" #include "access/events.h" #include "access/files.h" -#include "access/graphics.h" #include "access/screen.h" #include "access/sound.h" @@ -87,14 +86,13 @@ protected: virtual bool hasFeature(EngineFeature f) const; protected: /** - * Show game title + * Play the game */ - virtual void doTitle() = 0; + virtual void playGame() = 0; public: Debugger *_debugger; EventsManager *_events; FileManager *_files; - GraphicsManager *_graphics; Screen *_screen; SoundManager *_sound; diff --git a/engines/access/amazon/amazon_game.cpp b/engines/access/amazon/amazon_game.cpp index 30733087dd..681819f602 100644 --- a/engines/access/amazon/amazon_game.cpp +++ b/engines/access/amazon/amazon_game.cpp @@ -28,11 +28,41 @@ namespace Amazon { AmazonEngine::AmazonEngine(OSystem *syst, const AccessGameDescription *gameDesc) : AccessEngine(syst, gameDesc) { + _skipStart = false; } AmazonEngine::~AmazonEngine() { } +void AmazonEngine::playGame() { + _screen->setInitialPalettte(); + _events->setCursor(CURSOR_0); + _events->showCursor(); + _screen->setPanel(0); + + doTitle(); + if (shouldQuit()) + return; + + if (!_skipStart) { + _screen->setPanel(3); + doOpening(); + if (shouldQuit()) + return; + + if (!_skipStart) { + doTent(); + if (shouldQuit()) + return; + } + } + + doTitle(); + if (shouldQuit()) + return; + + _screen->clearScreen(); +} void AmazonEngine::doTitle() { _screen->setDisplayScan(); @@ -70,6 +100,15 @@ void AmazonEngine::doTitle() { int xp = READ_LE_UINT16(COUNTDOWN + _pCount * 4 + 2); _screen->plotImage(_objectsTable, id, Common::Point(xp, 71)); } + // TODO: More to do +} + +void AmazonEngine::doOpening() { + // TODO +} + +void AmazonEngine::doTent() { + // TODO } } // End of namespace Amazon diff --git a/engines/access/amazon/amazon_game.h b/engines/access/amazon/amazon_game.h index 33d7833670..79a74b329f 100644 --- a/engines/access/amazon/amazon_game.h +++ b/engines/access/amazon/amazon_game.h @@ -30,8 +30,28 @@ namespace Access { namespace Amazon { class AmazonEngine : public AccessEngine { +private: + bool _skipStart; + + /** + * Do title sequence + */ + void doTitle(); + + /** + * Do opening sequence + */ + void doOpening(); + + /** + * Do tent scene of introduction + */ + void doTent(); protected: - virtual void doTitle(); + /** + * Play the game + */ + virtual void playGame(); public: AmazonEngine(OSystem *syst, const AccessGameDescription *gameDesc); diff --git a/engines/access/graphics.cpp b/engines/access/asurface.cpp index c1187f2eb3..a0a790dbdc 100644 --- a/engines/access/graphics.cpp +++ b/engines/access/asurface.cpp @@ -20,23 +20,14 @@ * */ -#include "graphics/palette.h" -#include "access/access.h" -#include "access/graphics.h" -#include "access/resources.h" +#include "common/algorithm.h" +#include "access/asurface.h" namespace Access { -GraphicsManager::GraphicsManager(AccessEngine *vm) : _vm(vm) { - _vesaCurrentWin = 0; - _currentPanel = 0; - _hideFlag = true; -} - -void GraphicsManager::setPanel(int num) { - assert(num < 4); - _currentPanel = num; - _msVirtualOffset = _virtualOffsetsTable[num]; +void ASurface::clearBuffer() { + byte *pSrc = (byte *)getPixels(); + Common::fill(pSrc, pSrc + w * h, 0); } } // End of namespace Access diff --git a/engines/access/graphics.h b/engines/access/asurface.h index df626176fa..ecd04b9682 100644 --- a/engines/access/graphics.h +++ b/engines/access/asurface.h @@ -20,31 +20,19 @@ * */ -#ifndef ACCESS_GRAPHICS_H -#define ACCESS_GRAPHICS_H +#ifndef ACCESS_ASURFACE_H +#define ACCESS_ASURFACE_H #include "common/rect.h" #include "graphics/surface.h" namespace Access { -class AccessEngine; - -class GraphicsManager { -private: - AccessEngine *_vm; -public: - int _vesaCurrentWin; - int _currentPanel; - Common::Point _msVirtualOffset; - Common::Point _virtualOffsetsTable[4]; - bool _hideFlag; +class ASurface : public Graphics::Surface { public: - GraphicsManager(AccessEngine *vm); - - void setPanel(int num); + void clearBuffer(); }; } // End of namespace Access -#endif /* ACCESS_GRAPHICS_H */ +#endif /* ACCESS_ASURFACE_H */ diff --git a/engines/access/module.mk b/engines/access/module.mk index c9d593de22..ff4cedbdc6 100644 --- a/engines/access/module.mk +++ b/engines/access/module.mk @@ -1,13 +1,13 @@ MODULE := engines/access MODULE_OBJS := \ + asurface.o \ access.o \ debugger.o \ decompress.o \ detection.o \ events.o \ files.o \ - graphics.o \ resources.o \ screen.o \ sound.o \ diff --git a/engines/access/screen.cpp b/engines/access/screen.cpp index cb0154d56e..591bb67a7f 100644 --- a/engines/access/screen.cpp +++ b/engines/access/screen.cpp @@ -34,6 +34,9 @@ namespace Access { Screen::Screen(AccessEngine *vm) : _vm(vm) { create(320, 200, Graphics::PixelFormat::createFormatCLUT8()); Common::fill(&_tempPalette[0], &_tempPalette[PALETTE_SIZE], 0); + _vesaCurrentWin = 0; + _currentPanel = 0; + _hideFlag = true; _loadPalFlag = false; _leftSkip = _rightSkip = 0; _topSkip = _bottomSkip = 0; @@ -44,6 +47,12 @@ void Screen::setDisplayScan() { warning("TODO: setDisplayScan"); } +void Screen::setPanel(int num) { + assert(num < 4); + _currentPanel = num; + _msVirtualOffset = _virtualOffsetsTable[num]; +} + void Screen::updateScreen() { g_system->updateScreen(); } diff --git a/engines/access/screen.h b/engines/access/screen.h index 0d68c1bc7e..295372770a 100644 --- a/engines/access/screen.h +++ b/engines/access/screen.h @@ -26,7 +26,7 @@ #include "common/scummsys.h" #include "common/rect.h" #include "common/stream.h" -#include "graphics/surface.h" +#include "access/asurface.h" namespace Access { @@ -35,11 +35,16 @@ class AccessEngine; #define PALETTE_COUNT 256 #define PALETTE_SIZE (256 * 3) -class Screen: public Graphics::Surface { +class Screen: public ASurface { private: AccessEngine *_vm; byte _tempPalette[PALETTE_SIZE]; byte _rawPalette[PALETTE_SIZE]; + int _vesaCurrentWin; + int _currentPanel; + Common::Point _msVirtualOffset; + Common::Point _virtualOffsetsTable[4]; + bool _hideFlag; Common::Rect _lastBounds; int _leftSkip, _rightSkip; int _topSkip, _bottomSkip; @@ -57,6 +62,8 @@ public: void setDisplayScan(); + void setPanel(int num); + /** * Update the underlying screen */ @@ -72,6 +79,8 @@ public: */ void forceFadeIn(); + void clearScreen() { clearBuffer(); } + /** * Set the initial palette */ |