aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/Common/Tutorial/AreaTask.cpp
diff options
context:
space:
mode:
authordaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
committerdaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
commitb691c43c44ff180d10e7d4a9afc83b98551ff586 (patch)
tree3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.Client/Common/Tutorial/AreaTask.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.Client/Common/Tutorial/AreaTask.cpp')
-rw-r--r--Minecraft.Client/Common/Tutorial/AreaTask.cpp69
1 files changed, 69 insertions, 0 deletions
diff --git a/Minecraft.Client/Common/Tutorial/AreaTask.cpp b/Minecraft.Client/Common/Tutorial/AreaTask.cpp
new file mode 100644
index 00000000..de29ab1b
--- /dev/null
+++ b/Minecraft.Client/Common/Tutorial/AreaTask.cpp
@@ -0,0 +1,69 @@
+#include "stdafx.h"
+#include "Tutorial.h"
+#include "AreaTask.h"
+
+AreaTask::AreaTask(eTutorial_State state, Tutorial *tutorial, vector<TutorialConstraint *> *inConstraints, int descriptionId, EAreaTaskCompletionStates completionState)
+ : TutorialTask( tutorial, descriptionId, false, inConstraints, false, false, false )
+{
+ m_tutorialState = state;
+ if(m_tutorialState == e_Tutorial_State_Gameplay)
+ {
+ enableConstraints(true);
+ }
+ m_completionState = completionState;
+}
+
+bool AreaTask::isCompleted()
+{
+ if(bIsCompleted) return true;
+
+ bool complete = false;
+ switch(m_completionState)
+ {
+ case eAreaTaskCompletion_CompleteOnConstraintsSatisfied:
+ {
+ bool allSatisfied = true;
+ for(AUTO_VAR(it, constraints.begin()); it != constraints.end(); ++it)
+ {
+ TutorialConstraint *constraint = *it;
+ if(!constraint->isConstraintSatisfied(tutorial->getPad()))
+ {
+ allSatisfied = false;
+ break;
+ }
+ }
+ complete = allSatisfied;
+ }
+ break;
+ case eAreaTaskCompletion_CompleteOnActivation:
+ complete = bHasBeenActivated;
+ break;
+ };
+ bIsCompleted = complete;
+ return complete;
+}
+
+void AreaTask::setAsCurrentTask(bool active)
+{
+ TutorialTask::setAsCurrentTask(active);
+
+ if(m_completionState == eAreaTaskCompletion_CompleteOnConstraintsSatisfied)
+ {
+ enableConstraints(active);
+ }
+}
+
+void AreaTask::onStateChange(eTutorial_State newState)
+{
+ if(m_completionState == eAreaTaskCompletion_CompleteOnActivation)
+ {
+ if(m_tutorialState == newState)
+ {
+ enableConstraints(true);
+ }
+ else if(m_tutorialState != e_Tutorial_State_Gameplay)
+ {
+ //enableConstraints(false);
+ }
+ }
+} \ No newline at end of file