aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/zvision/actions.cpp34
-rw-r--r--engines/zvision/actions.h6
-rw-r--r--engines/zvision/scr_file_handling.cpp6
3 files changed, 39 insertions, 7 deletions
diff --git a/engines/zvision/actions.cpp b/engines/zvision/actions.cpp
index 504c250597..affa8f5a9c 100644
--- a/engines/zvision/actions.cpp
+++ b/engines/zvision/actions.cpp
@@ -111,6 +111,40 @@ bool ActionCrossfade::execute(ZVision *engine) {
//////////////////////////////////////////////////////////////////////////////
+// ActionDisableControl
+//////////////////////////////////////////////////////////////////////////////
+
+ActionDisableControl::ActionDisableControl(const Common::String &line) {
+ sscanf(line.c_str(), "%*[^(](%u)", &_key);
+}
+
+bool ActionDisableControl::execute(ZVision *engine) {
+ debug("Disabling control %u", _key);
+
+ engine->getScriptManager()->disableControl(_key);
+
+ return true;
+}
+
+
+//////////////////////////////////////////////////////////////////////////////
+// ActionEnableControl
+//////////////////////////////////////////////////////////////////////////////
+
+ActionEnableControl::ActionEnableControl(const Common::String &line) {
+ sscanf(line.c_str(), "%*[^(](%u)", &_key);
+}
+
+bool ActionEnableControl::execute(ZVision *engine) {
+ debug("Enabling control %u", _key);
+
+ engine->getScriptManager()->enableControl(_key);
+
+ return true;
+}
+
+
+//////////////////////////////////////////////////////////////////////////////
// ActionMusic
//////////////////////////////////////////////////////////////////////////////
diff --git a/engines/zvision/actions.h b/engines/zvision/actions.h
index aa67be20c7..1d87b8025c 100644
--- a/engines/zvision/actions.h
+++ b/engines/zvision/actions.h
@@ -168,6 +168,7 @@ public:
bool execute(ZVision *engine);
private:
+ uint32 _key;
};
class ActionDisableVenus : public ResultAction {
@@ -188,10 +189,8 @@ private:
class ActionDissolve : public ResultAction {
public:
- ActionDissolve(const Common::String &line);
+ ActionDissolve();
bool execute(ZVision *engine);
-
-private:
};
class ActionDistort : public ResultAction {
@@ -208,6 +207,7 @@ public:
bool execute(ZVision *engine);
private:
+ uint32 _key;
};
class ActionMusic : public ResultAction {
diff --git a/engines/zvision/scr_file_handling.cpp b/engines/zvision/scr_file_handling.cpp
index 10e5c8f0eb..3fee767135 100644
--- a/engines/zvision/scr_file_handling.cpp
+++ b/engines/zvision/scr_file_handling.cpp
@@ -177,8 +177,7 @@ void ScriptManager::parseResults(Common::SeekableReadStream &stream, Common::Lis
} else if (line.matchString("*:disable_control*", true)) {
-
-
+ actionList.push_back(Common::SharedPtr<ResultAction>(new ActionDisableControl(line)));
} else if (line.matchString("*:disable_venus*", true)) {
@@ -192,8 +191,7 @@ void ScriptManager::parseResults(Common::SeekableReadStream &stream, Common::Lis
} else if (line.matchString("*:enable_control*", true)) {
-
-
+ actionList.push_back(Common::SharedPtr<ResultAction>(new ActionEnableControl(line)));
} else if (line.matchString("*:flush_mouse_events*", true)) {