aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
Diffstat (limited to 'engines')
-rw-r--r--engines/neverhood/module.h3
-rw-r--r--engines/neverhood/module.mk1
-rw-r--r--engines/neverhood/module1500.cpp2
-rw-r--r--engines/neverhood/module1500.h2
-rw-r--r--engines/neverhood/neverhood.cpp14
-rw-r--r--engines/neverhood/neverhood.h8
-rw-r--r--engines/neverhood/scene.cpp6
-rw-r--r--engines/neverhood/screen.cpp88
-rw-r--r--engines/neverhood/screen.h54
9 files changed, 157 insertions, 21 deletions
diff --git a/engines/neverhood/module.h b/engines/neverhood/module.h
index 432a04c043..b59b532fad 100644
--- a/engines/neverhood/module.h
+++ b/engines/neverhood/module.h
@@ -27,6 +27,9 @@
#include "neverhood/neverhood.h"
#include "neverhood/entity.h"
+#include "neverhood/graphics.h"
+#include "neverhood/palette.h"
+#include "neverhood/screen.h"
namespace Neverhood {
diff --git a/engines/neverhood/module.mk b/engines/neverhood/module.mk
index 709538e565..e51565f76b 100644
--- a/engines/neverhood/module.mk
+++ b/engines/neverhood/module.mk
@@ -13,6 +13,7 @@ MODULE_OBJS = \
resource.o \
resourceman.o \
scene.o \
+ screen.o \
sprite.o
# This module can be built as a plugin
diff --git a/engines/neverhood/module1500.cpp b/engines/neverhood/module1500.cpp
index f4c77948b4..97d125a45f 100644
--- a/engines/neverhood/module1500.cpp
+++ b/engines/neverhood/module1500.cpp
@@ -147,7 +147,7 @@ void Scene1501::update() {
if (_countdown1 != 0) {
_countdown1--;
if (_countdown1 == 0) {
- // TODO g_screen->clear(0);
+ _vm->_screen->clear();
_parentModule->sendMessage(0x1009, 0, this);
}
} else if ((_countdown2 != 0 && (--_countdown2 == 0)) || !_soundResource.isPlaying()) {
diff --git a/engines/neverhood/module1500.h b/engines/neverhood/module1500.h
index 66eef59073..e3633a0e85 100644
--- a/engines/neverhood/module1500.h
+++ b/engines/neverhood/module1500.h
@@ -28,8 +28,6 @@
#include "neverhood/neverhood.h"
#include "neverhood/module.h"
#include "neverhood/scene.h"
-#include "neverhood/graphics.h"
-#include "neverhood/palette.h"
namespace Neverhood {
diff --git a/engines/neverhood/neverhood.cpp b/engines/neverhood/neverhood.cpp
index ac89a3e658..4baff5eafa 100644
--- a/engines/neverhood/neverhood.cpp
+++ b/engines/neverhood/neverhood.cpp
@@ -20,28 +20,19 @@
*
*/
-#include "common/events.h"
-#include "common/keyboard.h"
#include "common/file.h"
-#include "common/random.h"
-#include "common/savefile.h"
#include "common/config-manager.h"
-
#include "base/plugins.h"
#include "base/version.h"
-
#include "graphics/cursorman.h"
-
#include "engines/util.h"
-
-#include "audio/mixer.h"
-
#include "neverhood/neverhood.h"
#include "neverhood/blbarchive.h"
#include "neverhood/gamemodule.h"
#include "neverhood/graphics.h"
#include "neverhood/resourceman.h"
#include "neverhood/resource.h"
+#include "neverhood/screen.h"
namespace Neverhood {
@@ -71,6 +62,8 @@ Common::Error NeverhoodEngine::run() {
_isSaveAllowed = false;
+ _screen = new Screen(this);
+
_res = new ResourceMan();
_res->addArchive("a.blb");
_res->addArchive("c.blb");
@@ -179,6 +172,7 @@ Common::Error NeverhoodEngine::run() {
delete _gameModule;
delete _res;
+ delete _screen;
debug("Ok.");
diff --git a/engines/neverhood/neverhood.h b/engines/neverhood/neverhood.h
index b261a087f0..c13ac517fb 100644
--- a/engines/neverhood/neverhood.h
+++ b/engines/neverhood/neverhood.h
@@ -29,11 +29,7 @@
#include "common/random.h"
#include "common/savefile.h"
#include "common/system.h"
-
#include "audio/mixer.h"
-
-#include "graphics/surface.h"
-
#include "engines/engine.h"
namespace Neverhood {
@@ -43,8 +39,9 @@ enum NeverhoodGameFeatures {
struct NeverhoodGameDescription;
-class ResourceMan;
class GameModule;
+class ResourceMan;
+class Screen;
struct GameState {
int sceneNum;
@@ -74,6 +71,7 @@ public:
uint16 _buttonState;
GameState _gameState;
+ Screen *_screen;
ResourceMan *_res;
GameModule *_gameModule;
diff --git a/engines/neverhood/scene.cpp b/engines/neverhood/scene.cpp
index ccdae3a287..f1209318ec 100644
--- a/engines/neverhood/scene.cpp
+++ b/engines/neverhood/scene.cpp
@@ -39,13 +39,13 @@ Scene::Scene(NeverhoodEngine *vm, Module *parentModule, bool clearHitRects)
// TODO _playerSprite = NULL;
// TODO _mouseSprite = NULL;
_palette = NULL;
- // TODO _class300 = NULL;
+ // TODO _background = NULL;
// TODO _field_8E = -1;
if (clearHitRects) {
// TODO g_Class700->setHitRects(NULL, 0);
// TODO g_Class700->clear();
}
- // TODO g_screen->setFps(24);
+ _vm->_screen->setFps(24);
// TODO g_screen->hSmack = NULL;
// TODO g_screen->field_24 = 0;
// TODO g_screen->field_26 = 0;
@@ -292,7 +292,7 @@ void Scene::smackerUpdate() {
_messageHandlerCb = _savedMessageHandlerCb;
if (_palette)
_palette->usePalette();
- // TODO class300->restore();
+ // TODO _background->restore();
// TODO g_screen->smackerPlayer = NULL;
}
#endif
diff --git a/engines/neverhood/screen.cpp b/engines/neverhood/screen.cpp
new file mode 100644
index 0000000000..4b531ca139
--- /dev/null
+++ b/engines/neverhood/screen.cpp
@@ -0,0 +1,88 @@
+/* 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.
+ *
+ */
+
+#include "graphics/palette.h"
+#include "neverhood/screen.h"
+
+namespace Neverhood {
+
+Screen::Screen(NeverhoodEngine *vm)
+ : _vm(vm), _paletteData(NULL), _paletteChanged(false) {
+
+ _ticks = _vm->_system->getMillis();
+
+ _backScreen = new Graphics::Surface();
+ _backScreen->create(640, 480, Graphics::PixelFormat::createFormatCLUT8());
+
+}
+
+Screen::~Screen() {
+ delete _backScreen;
+}
+
+void Screen::wait() {
+}
+
+void Screen::setFps(int fps) {
+ _frameDelay = 1000 / fps;
+}
+
+int Screen::getFps() {
+ return 1000 / _frameDelay;
+}
+
+void Screen::setPaletteData(byte *paletteData) {
+ _paletteChanged = true;
+ _paletteData = paletteData;
+}
+
+void Screen::unsetPaletteData(byte *paletteData) {
+ if (_paletteData == paletteData) {
+ _paletteChanged = false;
+ _paletteData = NULL;
+ }
+}
+
+void Screen::testPalette(byte *paletteData) {
+ if (_paletteData == paletteData)
+ _paletteChanged = true;
+}
+
+void Screen::updatePalette() {
+ if (_paletteChanged && _paletteData) {
+ byte *tempPalette = new byte[768];
+ for (int i = 0; i < 256; i++) {
+ tempPalette[i * 3 + 0] = _paletteData[i * 4 + 0];
+ tempPalette[i * 3 + 1] = _paletteData[i * 4 + 1];
+ tempPalette[i * 3 + 2] = _paletteData[i * 4 + 2];
+ }
+ _vm->_system->getPaletteManager()->setPalette(tempPalette, 0, 256);
+ delete[] tempPalette;
+ _paletteChanged = false;
+ }
+}
+
+void Screen::clear() {
+ memset(_backScreen->pixels, 0, _backScreen->pitch * _backScreen->h);
+}
+
+} // End of namespace Neverhood
diff --git a/engines/neverhood/screen.h b/engines/neverhood/screen.h
new file mode 100644
index 0000000000..0e7ce3d7d6
--- /dev/null
+++ b/engines/neverhood/screen.h
@@ -0,0 +1,54 @@
+/* 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.
+ *
+ */
+
+#ifndef NEVERHOOD_SCREEN_H
+#define NEVERHOOD_SCREEN_H
+
+#include "graphics/surface.h"
+#include "neverhood/neverhood.h"
+
+namespace Neverhood {
+
+class Screen {
+public:
+ Screen(NeverhoodEngine *vm);
+ ~Screen();
+ void wait();
+ void setFps(int fps);
+ int getFps();
+ void setPaletteData(byte *paletteData);
+ void unsetPaletteData(byte *paletteData);
+ void testPalette(byte *paletteData);
+ void updatePalette();
+ void clear();
+protected:
+ NeverhoodEngine *_vm;
+ Graphics::Surface *_backScreen;
+ uint32 _ticks;
+ uint32 _frameDelay;
+ byte *_paletteData;
+ bool _paletteChanged;
+};
+
+} // End of namespace Neverhood
+
+#endif /* NEVERHOOD_SCREEN_H */