NANCY: Fix show_image and play_video debug commands

Added code to make the show_image and play_video debug commands play nice with the new graphics manager.
This commit is contained in:
fracturehill 2021-02-22 22:59:21 +02:00 committed by Eugene Sandulenko
parent a7619575ac
commit 46ed7dce87
5 changed files with 54 additions and 13 deletions

View File

@ -27,6 +27,8 @@
#include "engines/nancy/sound.h"
#include "engines/nancy/iff.h"
#include "engines/nancy/state/scene.h"
#include "engines/nancy/input.h"
#include "engines/nancy/graphics.h"
#include "common/system.h"
#include "common/events.h"
@ -67,9 +69,10 @@ void NancyConsole::postEnter() {
while (!_vm->shouldQuit() && !dec->endOfVideo()) {
Common::Event event;
if (ev->pollEvent(event)) {
if (event.type == Common::EVENT_KEYDOWN || event.type == Common::EVENT_LBUTTONDOWN)
if (event.type == Common::EVENT_CUSTOM_ENGINE_ACTION_END && event.customType == Nancy::InputManager::kNancyActionLeftClick) {
break;
}
}
if (dec->needsUpdate()) {
const Graphics::Surface *frame = dec->decodeNextFrame();
@ -78,14 +81,49 @@ void NancyConsole::postEnter() {
_vm->_system->updateScreen();
}
}
_vm->_system->delayMillis(10);
}
} else
_vm->graphicsManager->redrawAll();
} else {
debugPrintf("Failed to load '%s'\n", _videoFile.c_str());
}
_videoFile.clear();
delete dec;
}
if (!_imageFile.empty()) {
Graphics::Surface surf;
if (_vm->_res->loadImage(_imageCifTree, _imageFile, surf)) {
_vm->_system->fillScreen(0);
_vm->_system->copyRectToScreen(surf.getPixels(), surf.pitch, 0, 0, surf.w > 640 ? 640 : surf.w, surf.h > 480 ? 480 : surf.h);
_vm->_system->updateScreen();
surf.free();
Common::EventManager *ev = g_system->getEventManager();
while (!_vm->shouldQuit()) {
Common::Event event;
if (ev->pollEvent(event)) {
if (event.type == Common::EVENT_CUSTOM_ENGINE_ACTION_END && event.customType == Nancy::InputManager::kNancyActionLeftClick) {
break;
}
_vm->_system->updateScreen();
}
_vm->_system->delayMillis(10);
}
_vm->graphicsManager->redrawAll();
} else {
debugPrintf("Failed to load image '%s'\n", _imageFile.c_str());
}
_imageFile.clear();
_imageCifTree.clear();
}
}
bool NancyConsole::Cmd_cifHexDump(int argc, const char **argv) {
@ -220,17 +258,9 @@ bool NancyConsole::Cmd_showImage(int argc, const char **argv) {
return true;
}
Graphics::Surface surf;
if (_vm->_res->loadImage((argc == 2 ? "ciftree" : argv[2]), argv[1], surf)) {
_vm->_system->fillScreen(0);
_vm->_system->copyRectToScreen(surf.getPixels(), surf.pitch, 0, 0, surf.w > 640 ? 640 : surf.w, surf.h > 480 ? 480 : surf.h);
surf.free();
_vm->_gameFlow.minGameState = NancyEngine::kIdle;
_imageFile = argv[1];
_imageCifTree = argc == 2 ? "ciftree" : argv[2];
return cmdExit(0, 0);
} else {
debugPrintf("Failed to load image\n");
return true;
}
}
bool NancyConsole::Cmd_loadCal(int argc, const char **argv) {

View File

@ -54,6 +54,8 @@ private:
bool Cmd_sceneID(int argc, const char **argv);
Common::String _videoFile;
Common::String _imageFile;
Common::String _imageCifTree;
};
} // End of namespace Nancy

View File

@ -117,6 +117,12 @@ void GraphicsManager::clearObjects() {
_objects.clear();
}
void GraphicsManager::redrawAll() {
for (auto &obj : _objects) {
obj->_needsRedraw = true;
}
}
void GraphicsManager::loadFonts() {
Common::SeekableReadStream *chunk = _engine->getBootChunkStream("FONT");

View File

@ -48,6 +48,8 @@ public:
void removeObject(RenderObject *object);
void clearObjects();
void redrawAll();
Font *getFont(uint id) { return id < _fonts.size() ? &_fonts[id] : nullptr; }
Graphics::ManagedSurface object0;

View File

@ -65,6 +65,7 @@ struct NancyInput {
// This class handles collecting events and translating them to a NancyInput object,
// which can then be pulled by interested classes through getInput()
class InputManager {
friend class NancyConsole;
enum NancyAction {
kNancyActionMoveUp,
kNancyActionMoveDown,