mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-25 12:05:53 +00:00
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:
parent
a7619575ac
commit
46ed7dce87
@ -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) {
|
||||
|
@ -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
|
||||
|
@ -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");
|
||||
|
||||
|
@ -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;
|
||||
|
@ -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,
|
||||
|
Loading…
x
Reference in New Issue
Block a user