From 06a08d9c775f305d78cd64c8db194a0c421ee415 Mon Sep 17 00:00:00 2001 From: antoniou79 Date: Tue, 20 Aug 2019 19:31:23 +0300 Subject: BLADERUNNER: Restore Hasan being at Animoid past Act 2 This restores the trigger for the last dialogue about the fish scale --- engines/bladerunner/game_constants.h | 11 ++- engines/bladerunner/script/ai/hasan.cpp | 111 +++++++++++++++++++++++++++-- engines/bladerunner/script/init_script.cpp | 1 + engines/bladerunner/script/scene/rc04.cpp | 1 + 4 files changed, 116 insertions(+), 8 deletions(-) diff --git a/engines/bladerunner/game_constants.h b/engines/bladerunner/game_constants.h index b1f40a7f64..a425efd7ee 100644 --- a/engines/bladerunner/game_constants.h +++ b/engines/bladerunner/game_constants.h @@ -578,7 +578,7 @@ enum Flags { kFlagPS05toPS06 = 136, kFlagCT04HomelessTalk = 137, kFlagPS07KleinInsulted = 138, - // 139 is never used + kFlagMcCoyTalkedToBulletBobAboutHasan = 139, // Re-purposed. Original: 139 is never used // 140 is never used kFlagRC51Available = 141, kFlagNotUsed142 = 142, // is never checked @@ -2518,6 +2518,15 @@ enum GoalZuben { kGoalZubenGone = 599 }; +enum GoalHasan { + kGoalHasanDefault = 0, + kGoalHasanIsAway = 300, // original final goal for Hasan + kGoalHasanIsWalkingAroundIsAtCT02 = 301, // new goal for restored content + kGoalHasanIsWalkingAroundStayAwayFromCT02 = 302, // new goal for restored content + kGoalHasanIsWalkingAroundStaysAtCT02 = 303, // new goal for restored content + kGoalHasanIsWalkingAroundIsAway = 304 // new goal for restored content +}; + enum GoalOfficerLeary { kGoalOfficerLearyDefault = 0, kGoalOfficerLearyRC01WalkToCrowd = 1, diff --git a/engines/bladerunner/script/ai/hasan.cpp b/engines/bladerunner/script/ai/hasan.cpp index 3f48cc113b..696d44036c 100644 --- a/engines/bladerunner/script/ai/hasan.cpp +++ b/engines/bladerunner/script/ai/hasan.cpp @@ -48,15 +48,36 @@ void AIScriptHasan::Initialize() { Actor_Put_In_Set(kActorHasan, kSetAR01_AR02); Actor_Set_At_XYZ(kActorHasan, -214.0f, 0.0f, -1379.0f, 371); - Actor_Set_Goal_Number(kActorHasan, 0); + Actor_Set_Goal_Number(kActorHasan, kGoalHasanDefault); } bool AIScriptHasan::Update() { - if (Global_Variable_Query(kVariableChapter) != 3 || Actor_Query_Goal_Number(kActorHasan) >= 300) + if (_vm->_cutContent) { + if (Global_Variable_Query(kVariableChapter) == 1 + && Actor_Query_Goal_Number(kActorHasan) != kGoalHasanIsAway) + { + // use this goal to put Hasan in a FreeSlot set for Act 1 + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsAway); + return true; + } else if (Global_Variable_Query(kVariableChapter) == 2 + && Actor_Query_Goal_Number(kActorHasan) != kGoalHasanDefault + ) { + Actor_Set_Goal_Number(kActorHasan, kGoalHasanDefault); + return true; + } else if (Global_Variable_Query(kVariableChapter) > 2 + && Actor_Query_Goal_Number(kActorHasan) < kGoalHasanIsWalkingAroundIsAtCT02) { + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundIsAtCT02); + return true; + } return false; + } else { + // original behavior results in Hasan going away when chapter 3 begins + if (Global_Variable_Query(kVariableChapter) != 3 || Actor_Query_Goal_Number(kActorHasan) >= kGoalHasanIsAway) + return false; - Actor_Set_Goal_Number(kActorHasan, 300); - return true; + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsAway); + return true; + } } void AIScriptHasan::TimerExpired(int timer) { @@ -64,6 +85,51 @@ void AIScriptHasan::TimerExpired(int timer) { } void AIScriptHasan::CompletedMovementTrack() { + if (_vm->_cutContent) { + // + // *after Act 2* Hasan will be leaving Animoid Row for sometime + if (Global_Variable_Query(kVariableChapter) > 2) { + int maxHasanLeaveProb = 4; + // if Bullet Bob is dead or McCoy reprimanded Bob about Hasan, + // then Hasan is less likely to leave at Animoid Row, *after Act 2* + if (Game_Flag_Query(kFlagMcCoyTalkedToBulletBobAboutHasan) + || Actor_Query_Goal_Number(kGoalBulletBobDead) + || Actor_Query_Goal_Number(kGoalBulletBobGone) + ) { + maxHasanLeaveProb = 10; + } + + if (Actor_Query_Goal_Number(kActorHasan) == kGoalHasanIsWalkingAroundIsAtCT02) { + if (Random_Query(1, maxHasanLeaveProb) == 1 + && Player_Query_Current_Scene() != kSceneAR01 + && Player_Query_Current_Scene() != kSceneAR02 + ) { + // Hasan leaves Animoid Row + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundIsAway); + return; // true; + } else { + // stay (change goal to a temp one to trigger GoalChanged() (so that we can reset the "track") + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundStaysAtCT02); + return; // true; + } + } + + if (Actor_Query_Goal_Number(kActorHasan) == kGoalHasanIsWalkingAroundIsAway) { + if (Random_Query(1, 2) == 1 + && Player_Query_Current_Scene() != kSceneAR01 + && Player_Query_Current_Scene() != kSceneAR02 + ) { + // Hasan returns tp Animoid Row + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundIsAtCT02); + return; // true; + } else { + // stay away (change goal to a temp one to trigger GoalChanged() (so that we can reset the "track") + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundStayAwayFromCT02); + return; // true; + } + } + } + } //return false; } @@ -108,9 +174,40 @@ int AIScriptHasan::GetFriendlinessModifierIfGetsClue(int otherActorId, int clueI } bool AIScriptHasan::GoalChanged(int currentGoalNumber, int newGoalNumber) { - if (newGoalNumber == 300) { - Actor_Put_In_Set(kActorHasan, kSetFreeSlotH); - Actor_Set_At_Waypoint(kActorHasan, 40, 0); + if (_vm->_cutContent) { + switch (newGoalNumber) { + case kGoalHasanDefault: + Actor_Put_In_Set(kActorHasan, kSetAR01_AR02); + Actor_Set_At_XYZ(kActorHasan, -214.0f, 0.0f, -1379.0f, 371); + break; + case kGoalHasanIsAway: + Actor_Put_In_Set(kActorHasan, kSetFreeSlotH); + Actor_Set_At_Waypoint(kActorHasan, 40, 0); // kSetFreeSlotH + break; + case kGoalHasanIsWalkingAroundIsAtCT02: + AI_Movement_Track_Flush(kActorHasan); + AI_Movement_Track_Append(kActorHasan, 554, Random_Query(60, 180)); // kSetAR01_AR02 + Actor_Face_Heading(kActorHasan, 371, false); + AI_Movement_Track_Repeat(kActorHasan); + break; + case kGoalHasanIsWalkingAroundIsAway: + AI_Movement_Track_Flush(kActorHasan); + AI_Movement_Track_Append(kActorHasan, 40, Random_Query(10, 40)); // kSetFreeSlotH + AI_Movement_Track_Repeat(kActorHasan); + break; + case kGoalHasanIsWalkingAroundStayAwayFromCT02: + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundIsAway); + break; + case kGoalHasanIsWalkingAroundStaysAtCT02: + Actor_Set_Goal_Number(kActorHasan, kGoalHasanIsWalkingAroundIsAtCT02); + break; + } + } else { + // original behavior - Hasan leaves on Act 3 + if (newGoalNumber == kGoalHasanIsAway) { + Actor_Put_In_Set(kActorHasan, kSetFreeSlotH); + Actor_Set_At_Waypoint(kActorHasan, 40, 0); // kSetFreeSlotH + } } return false; } diff --git a/engines/bladerunner/script/init_script.cpp b/engines/bladerunner/script/init_script.cpp index 63323613c1..0b8afe1147 100644 --- a/engines/bladerunner/script/init_script.cpp +++ b/engines/bladerunner/script/init_script.cpp @@ -2242,6 +2242,7 @@ void InitScript::Init_World_Waypoints() { World_Waypoint_Set(551, kSetKP05_KP06, -737.31f, 0.0f, -145.05f); // 552 - UNUSED // 553 - kSetRC03 - Izo AI script + // 554 - kSetAR01_AR02 - Hasan AI script (new) } void InitScript::Init_SDB() { diff --git a/engines/bladerunner/script/scene/rc04.cpp b/engines/bladerunner/script/scene/rc04.cpp index 774eca6b76..8efdaf4a24 100644 --- a/engines/bladerunner/script/scene/rc04.cpp +++ b/engines/bladerunner/script/scene/rc04.cpp @@ -209,6 +209,7 @@ void SceneScriptRC04::dialogueWithBulletBob() { Actor_Says(kActorMcCoy, 5040, 16); Actor_Says(kActorBulletBob, 550, 11); Actor_Modify_Friendliness_To_Other(kActorBulletBob, kActorMcCoy, -6); + Game_Flag_Set(kFlagMcCoyTalkedToBulletBobAboutHasan); break; case 610: // GOGGLES -- cgit v1.2.3