diff options
author | Martin Kiewitz | 2010-01-06 21:56:31 +0000 |
---|---|---|
committer | Martin Kiewitz | 2010-01-06 21:56:31 +0000 |
commit | 1bea3e387313a5bda02c5d6e4e75af538f69a243 (patch) | |
tree | 4a119680d37f35425d418101a09962823a2cf999 /engines | |
parent | 1779a4488211903a0fe6efa145e3b8c265775bff (diff) | |
download | scummvm-rg350-1bea3e387313a5bda02c5d6e4e75af538f69a243.tar.gz scummvm-rg350-1bea3e387313a5bda02c5d6e4e75af538f69a243.tar.bz2 scummvm-rg350-1bea3e387313a5bda02c5d6e4e75af538f69a243.zip |
SCI: added a new class for robot resources
svn-id: r47099
Diffstat (limited to 'engines')
-rw-r--r-- | engines/sci/console.cpp | 19 | ||||
-rw-r--r-- | engines/sci/console.h | 3 | ||||
-rw-r--r-- | engines/sci/graphics/gui.cpp | 6 | ||||
-rw-r--r-- | engines/sci/graphics/gui.h | 2 | ||||
-rw-r--r-- | engines/sci/graphics/robot.cpp | 75 | ||||
-rw-r--r-- | engines/sci/graphics/robot.h | 56 |
6 files changed, 161 insertions, 0 deletions
diff --git a/engines/sci/console.cpp b/engines/sci/console.cpp index d2e885c0f7..9db6301816 100644 --- a/engines/sci/console.cpp +++ b/engines/sci/console.cpp @@ -111,6 +111,9 @@ Console::Console(SciEngine *vm) : GUI::Debugger() { DCmd_Register("set_palette", WRAP_METHOD(Console, cmdSetPalette)); DCmd_Register("draw_pic", WRAP_METHOD(Console, cmdDrawPic)); DCmd_Register("draw_cel", WRAP_METHOD(Console, cmdDrawCel)); +#ifdef ENABLE_SCI32 + DCmd_Register("draw_robot", WRAP_METHOD(Console, cmdDrawRobot)); +#endif DCmd_Register("undither", WRAP_METHOD(Console, cmdUndither)); DCmd_Register("play_video", WRAP_METHOD(Console, cmdPlayVideo)); // Segments @@ -1018,6 +1021,22 @@ bool Console::cmdDrawCel(int argc, const char **argv) { return true; } +#ifdef ENABLE_SCI32 +bool Console::cmdDrawRobot(int argc, const char **argv) { + if (argc < 2) { + DebugPrintf("Draws a frame from a robot resource\n"); + DebugPrintf("Usage: %s <resourceId>\n", argv[0]); + DebugPrintf("where <resourceId> is the id of the robot resource to draw\n"); + return true; + } + + uint16 resourceId = atoi(argv[1]); + + _vm->_gamestate->_gui->drawRobot(); + return true; +} +#endif + bool Console::cmdUndither(int argc, const char **argv) { if (argc != 2) { DebugPrintf("Enable/disable undithering.\n"); diff --git a/engines/sci/console.h b/engines/sci/console.h index de3d7e566f..e325db25f1 100644 --- a/engines/sci/console.h +++ b/engines/sci/console.h @@ -86,6 +86,9 @@ private: bool cmdSetPalette(int argc, const char **argv); bool cmdDrawPic(int argc, const char **argv); bool cmdDrawCel(int argc, const char **argv); +#ifdef ENABLE_SCI32 + bool cmdDrawRobot(int argc, const char **argv); +#endif bool cmdUndither(int argc, const char **argv); bool cmdPlayVideo(int argc, const char **argv); // Segments diff --git a/engines/sci/graphics/gui.cpp b/engines/sci/graphics/gui.cpp index 8eb83495fa..8d76ea064d 100644 --- a/engines/sci/graphics/gui.cpp +++ b/engines/sci/graphics/gui.cpp @@ -39,6 +39,7 @@ #include "sci/graphics/animate.h" #include "sci/graphics/controls.h" #include "sci/graphics/menu.h" +#include "sci/graphics/robot.h" #include "sci/graphics/text.h" #include "sci/graphics/transitions.h" #include "sci/graphics/view.h" @@ -919,6 +920,11 @@ void SciGui::frameOut() { } } } + +void SciGui::drawRobot() { + Robot *test = new Robot(_s->resMan, _screen, 91); + test->draw(); +} #endif bool SciGui::debugUndither(bool flag) { diff --git a/engines/sci/graphics/gui.h b/engines/sci/graphics/gui.h index 293c41da70..6ca800efc2 100644 --- a/engines/sci/graphics/gui.h +++ b/engines/sci/graphics/gui.h @@ -161,6 +161,8 @@ public: virtual void frameOut(); virtual void globalToLocal(int16 *x, int16 *y, reg_t planeObj); virtual void localToGlobal(int16 *x, int16 *y, reg_t planeObj); + + virtual void drawRobot(); #endif virtual bool debugUndither(bool flag); diff --git a/engines/sci/graphics/robot.cpp b/engines/sci/graphics/robot.cpp new file mode 100644 index 0000000000..e1ba592e64 --- /dev/null +++ b/engines/sci/graphics/robot.cpp @@ -0,0 +1,75 @@ +/* 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$ + * + */ + +#include "sci/sci.h" +#include "sci/engine/state.h" +#include "sci/graphics/gfx.h" +#include "sci/graphics/screen.h" +#include "sci/graphics/robot.h" + +namespace Sci { + +#ifdef ENABLE_SCI32 +Robot::Robot(ResourceManager *resMan, Screen *screen, GuiResourceId resourceId) + : _resMan(resMan), _screen(screen), _resourceId(resourceId) { + assert(resourceId != -1); + initData(resourceId); +} + +Robot::~Robot() { + _resMan->unlockResource(_resource); +} + +void Robot::initData(GuiResourceId resourceId) { + _resource = _resMan->findResource(ResourceId(kResourceTypeRobot, resourceId), true); + if (!_resource) { + error("robot resource %d not found", resourceId); + } + _resourceData = _resource->data; + + _width = READ_LE_UINT16(_resourceData + 10); + _height = READ_LE_UINT16(_resourceData + 12); +} + +// TODO: just trying around in here... + +void Robot::draw() { + byte *bitmapData = _resourceData + 0x48; + int x, y; + int frame; + + //for (frame = 0; frame < 30; frame++) { + for (y = 0; y < _height; y++) { + for (x = 0; x < _width; x++) { + _screen->putPixel(x, y, SCI_SCREEN_MASK_VISUAL, *bitmapData, 0, 0); + bitmapData++; + } + } + //} + _screen->copyToScreen(); +} +#endif + +} // End of namespace Sci diff --git a/engines/sci/graphics/robot.h b/engines/sci/graphics/robot.h new file mode 100644 index 0000000000..482ce75d40 --- /dev/null +++ b/engines/sci/graphics/robot.h @@ -0,0 +1,56 @@ +/* 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$ + * + */ + +#ifndef SCI_GRAPHICS_ROBOT_H +#define SCI_GRAPHICS_ROBOT_H + +namespace Sci { + +#ifdef ENABLE_SCI32 +class Robot { +public: + Robot(ResourceManager *resMan, Screen *screen, GuiResourceId resourceId); + ~Robot(); + + void draw(); + +private: + void initData(GuiResourceId resourceId); + + ResourceManager *_resMan; + Screen *_screen; + + GuiResourceId _resourceId; + Resource *_resource; + byte *_resourceData; + + uint16 _width; + uint16 _height; +}; +#endif + +} // End of namespace Sci + +#endif |