From 033c8ac0f3d21495536825a02f0cb60f3b0db633 Mon Sep 17 00:00:00 2001 From: escape209 Date: Tue, 17 Sep 2024 21:33:03 +0100 Subject: [PATCH] More stuff --- src/SB/Core/x/xFX.h | 1 + src/SB/Game/zNPCGoalRobo.cpp | 240 ++++++++++++++++++++++++++++++- src/SB/Game/zNPCGoalStd.h | 30 +++- src/SB/Game/zNPCGoalVillager.cpp | 16 ++- src/SB/Game/zNPCSupport.h | 11 ++ src/SB/Game/zNPCTypeCommon.h | 1 + src/SB/Game/zNPCTypeRobot.h | 1 + 7 files changed, 287 insertions(+), 13 deletions(-) diff --git a/src/SB/Core/x/xFX.h b/src/SB/Core/x/xFX.h index 855fc119..18bbc9ab 100644 --- a/src/SB/Core/x/xFX.h +++ b/src/SB/Core/x/xFX.h @@ -109,6 +109,7 @@ void xFXFireworksUpdate(F32 dt); void xFXStreakInit(); void xFXStreakUpdate(F32 dt); void xFXStreakRender(); +void xFXStreakStop(U32); void xFXShineInit(); void xFXShineUpdate(F32 dt); void xFXShineRender(); diff --git a/src/SB/Game/zNPCGoalRobo.cpp b/src/SB/Game/zNPCGoalRobo.cpp index 3ca1b74c..f627ec54 100644 --- a/src/SB/Game/zNPCGoalRobo.cpp +++ b/src/SB/Game/zNPCGoalRobo.cpp @@ -10,8 +10,8 @@ #include "zNPCGoalStd.h" #include "zNPCSupport.h" #include "zNPCGoals.h" - -F32 f_0 = 0.0f; // needed at file level to change scheduling for +#include "zGameExtras.h" +#include "zNPCSupport.h" xFactoryInst* GOALCreate_Robotic(S32 who, RyzMemGrow* grow, void*) { @@ -200,7 +200,7 @@ xFactoryInst* GOALCreate_Robotic(S32 who, RyzMemGrow* grow, void*) S32 zNPCGoalAlertFodder::Enter(F32 dt, void* updCtxt) { flg_attack = 0; - tmr_alertfod = f_0; // need non-const float to get scheduling right + tmr_alertfod = 0.0f; // need non-const float to get scheduling right alertfod = FODDER_ALERT_NOTICE; return zNPCGoalCommon::Enter(dt, updCtxt); } @@ -830,12 +830,10 @@ S32 zNPCGoalDogDash::Enter(F32 dt, void* updCtxt) S32 zNPCGoalAttackTarTar::Enter(F32 dt, void* updCtxt) { ((zNPCCommon*)(psyche->clt_owner))->VelStop(); - flg_pushanim |= 2; idx_launch = 1; flg_attack = 0; xVec3Copy(&pos_aimbase, &g_O3); - return zNPCGoalPushAnim::Enter(dt, updCtxt); } @@ -884,7 +882,7 @@ S32 zNPCGoalEvilPat::Exit(F32 dt, void* updCtxt) S32 zNPCGoalEvilPat::NPCMessage(NPCMsg* mail) { - zNPCRobot* npc = ((zNPCRobot*)(psyche->clt_owner)); // Var + zNPCRobot* npc = ((zNPCRobot*)(psyche->clt_owner)); switch (mail->msgid) { case NPC_MID_STUN: @@ -895,4 +893,234 @@ S32 zNPCGoalEvilPat::NPCMessage(NPCMsg* mail) return 1; } return 0; +} + +S32 zNPCGoalEvilPat::Process(en_trantype* trantype, F32 dt, void* updCtxt, xScene* scene) +{ + U32 nextgoal; + + zNPCRobot* npc = ((zNPCRobot*)(psyche->clt_owner)); + + if (npc->tmr_stunned < 0.0f) + { + *trantype = GOAL_TRAN_SET; + nextgoal = 'NGR4'; + } + else + { + *trantype = GOAL_TRAN_PUSH; + nextgoal = 'NGRa'; + } + + return (*trantype != GOAL_TRAN_NONE) ? nextgoal : xGoal::Process(trantype, dt, updCtxt, scene); +} + +S32 zNPCGoalTaunt::Enter(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + npc->SndPlayRandom(NPC_STYP_LAUGH); + zNPCGoalLoopAnim::Enter(dt, updCtxt); +} + +S32 zNPCGoalAttackArfMelee::Enter(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + FXStreakPrep(); + npc->SndPlayRandom(NPC_STYP_PUNCH); + zNPCGoalPushAnim::Enter(dt, updCtxt); +} + +void zNPCGoalAttackHammer::ModifyAnimSpeed() +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + F32 speed = 1.5f; + U32 cheats = zGameExtras_CheatFlags(); + if ((cheats & 0x800)) + { + speed = 2.5f; + } + xAnimSingle* anim = npc->AnimCurSingle(); + anim->CurrentSpeed = speed; +} + +S32 zNPCGoalEvade::Enter(F32 dt, void* updCtxt) +{ + flg_evade = 0; + + if (xrand() & 0x00800000) + { + flg_evade |= 1; + } + else + { + flg_evade |= 2; + } + + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalHokeyPokey::Enter(F32 dt, void* updCtxt) +{ + zNPCFodBzzt* bzzt = ((zNPCFodBzzt*)(psyche->clt_owner)); + flg_hokey = (xrand() >> 0x17) & 1; + flg_hokey |= 2; + ang_spinrate = 0.0f; + bzzt->DiscoReset(); + return zNPCGoalLoopAnim::Enter(dt, updCtxt); +} + +S32 zNPCGoalTubeBirth::Enter(F32 dt, void* updCtxt) +{ + zNPCTubeSlave* npc = ((zNPCTubeSlave*)(psyche->clt_owner)); + npc->hitpoints = npc->cfg_npc->pts_damage; + npc->VelStop(); + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAttackMonsoon::Enter(F32 dt, void* updCtxt) +{ + idx_launch = 0; + flg_pushanim |= 2; + return zNPCGoalPushAnim::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertArf::Enter(F32 dt, void* updCtxt) +{ + alertarf = ARF_ALERT_READY; + tmr_reload = -1.0f; + flg_user = 1; + + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertHammer::Enter(F32 dt, void* updCtxt) +{ + flg_attack = 0; + alertham = HAMMER_ALERT_NOTICE; + + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertChuck::Enter(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + alertchuk = CHUCK_ALERT_NOTICE; + npc->VelStop(); + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertChomper::Enter(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + alertchomp = CHOMPER_ALERT_NOTICE; + npc->VelStop(); + pos_evade = g_O3; + tmr_evade = -1.0f; + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalTubeLasso::Enter(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + npc->VelStop(); + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertSlick::Resume(F32 dt, void* updCtxt) +{ + zNPCCommon* npc = ((zNPCCommon*)(psyche->clt_owner)); + npc->VelStop(); + flg_info |= 2; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAlertTubelet::Enter(F32 dt, void* updCtxt) +{ + zNPCTubeSlave* npc = ((zNPCTubeSlave*)(psyche->clt_owner)); + npc->tubespot = ROBO_TUBE_MARY; + return zNPCGoalCommon::Enter(dt, updCtxt); +} + +S32 zNPCGoalAlertTubelet::Exit(F32 dt, void* updCtxt) +{ + zNPCTubelet* npc = ((zNPCTubelet*)(psyche->clt_owner)); + zNPC_SNDStop(eNPCSnd_TubeAttack); + npc->pete_attack_last = 0; + return xGoal::Exit(dt, updCtxt); +} + +S32 zNPCGoalAlertTubelet::Resume(F32 dt, void* updCtxt) +{ + zNPCTubelet* npc = ((zNPCTubelet*)(psyche->clt_owner)); + npc->tubestat = TUBE_STAT_ATTACK; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAlertPuppy::Resume(F32 dt, void* updCtxt) +{ + zNPCChomper* npc = ((zNPCChomper*)(psyche->clt_owner)); + flg_info |= 2; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAlertChuck::Resume(F32 dt, void* updCtxt) +{ + zNPCChuck* npc = ((zNPCChuck*)(psyche->clt_owner)); + flg_info |= 2; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAlertMonsoon::Resume(F32 dt, void* updCtxt) +{ + alertmony = MONSOON_ALERT_BEGIN; + flg_attack = 0; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAlertFodBomb::Resume(F32 dt, void* updCtxt) +{ + flg_info |= 2; + return zNPCGoalCommon::Resume(dt, updCtxt); +} + +S32 zNPCGoalAttackArfMelee::Exit(F32 dt, void* updCtxt) +{ + FXStreakDone(); + return zNPCGoalPushAnim::Exit(dt, updCtxt); +} + +void zNPCGoalAttackArfMelee::FXStreakDone() +{ + for (S32 i = 0; i < (S32)(sizeof(this->streakID) / sizeof(U32)); i++) + { + xFXStreakStop(streakID[i]); + streakID[i] = 0xDEAD; + } +} + +void zNPCGoalTubeAttack::AttackDataReset() +{ + zNPCTubelet* npc = ((zNPCTubelet*)(psyche->clt_owner)); + flg_attack = 0; + if (npc->tubestat == TUBE_STAT_ATTACK) + { + mary.marystat = TUBE_MARY_WAIT; + mary.ang_spinrate = 0.0; + } + else + { + paul.flg_paul = 1; + paul.cnt_nextlos = -1; + paul.len_laser = 10.0f; + } +} + +S32 zNPCGoalWound::NPCMessage(NPCMsg* msg) +{ + switch (msg->msgid) + { + case NPC_MID_DAMAGE: + return 1; + } + return 0; } \ No newline at end of file diff --git a/src/SB/Game/zNPCGoalStd.h b/src/SB/Game/zNPCGoalStd.h index bdcbba22..b34ec27c 100644 --- a/src/SB/Game/zNPCGoalStd.h +++ b/src/SB/Game/zNPCGoalStd.h @@ -312,6 +312,11 @@ class zNPCGoalAttackArfMelee : public zNPCGoalPushAnim // total size: 0x64 public: zNPCGoalAttackArfMelee(S32); + S32 Enter(F32 dt, void* updCtxt); + S32 Exit(F32 dt, void* updCtxt); + S32 FXStreakPrep(); + void FXStreakDone(); + U32 streakID[4]; // offset 0x54, size 0x10 }; @@ -390,6 +395,7 @@ class zNPCGoalEvilPat : public zNPCGoalCommon F32 GlyphStart(); F32 GlyphStop(); S32 NPCMessage(NPCMsg* mail); + S32 Process(en_trantype* trantype, F32 dt, void* updCtxt, xScene* scene); }; class zNPCGoalPatCarry : public zNPCGoalCommon @@ -404,12 +410,14 @@ class zNPCGoalStunned : public zNPCGoalCommon // total size: 0x4C public: zNPCGoalStunned(S32); + S32 Enter(F32 dt, void* updCtxt); }; class zNPCGoalEvade : public zNPCGoalCommon { public: zNPCGoalEvade(S32); + S32 Enter(F32 dt, void* updCtxt); S32 flg_evade; // offset 0x4C, size 0x4 }; @@ -442,6 +450,7 @@ class zNPCGoalAlertArf : public zNPCGoalCommon // total size: 0x54 public: zNPCGoalAlertArf(S32); + S32 Enter(F32 dt, void* updCtxt); en_alertarf alertarf; // offset 0x4C, size 0x4 F32 tmr_reload; // offset 0x50, size 0x4 }; @@ -461,6 +470,7 @@ class zNPCGoalAlertPuppy : public zNPCGoalCommon // total size: 0x50 public: zNPCGoalAlertPuppy(S32); + S32 Resume(F32 dt, void* updCtxt); enum en_alertpuppy alertpup; // offset 0x4C, size 0x4 }; @@ -541,6 +551,9 @@ class zNPCGoalAlertTubelet : public zNPCGoalCommon // total size: 0x5C public: zNPCGoalAlertTubelet(S32); + S32 Exit(F32 dt, void* updCtxt); + S32 Enter(F32 dt, void* updCtxt); + S32 Resume(F32 dt, void* updCtxt); S32 flg_attack; // offset 0x4C, size 0x4 S32 cnt_nextlos; // offset 0x50, size 0x4 F32 len_laser; // offset 0x54, size 0x4 @@ -570,6 +583,7 @@ class zNPCGoalAlertMonsoon : public zNPCGoalCommon // total size: 0x70 public: zNPCGoalAlertMonsoon(S32); + S32 Resume(F32 dt, void* updCtxt); xVec3 dir_attack; // offset 0x4C, size 0xC S32 flg_attack; // offset 0x58, size 0x4 en_alertmony alertmony; // offset 0x5C, size 0x4 @@ -629,6 +643,7 @@ class zNPCGoalAlertHammer : public zNPCGoalCommon // total size: 0x58 public: zNPCGoalAlertHammer(S32); + S32 Enter(F32 dt, void* updCtxt); S32 flg_attack; // offset 0x4C, size 0x4 en_alertham alertham; // offset 0x50, size 0x4 F32 tmr_alertham; // offset 0x54, size 0x4 @@ -666,6 +681,7 @@ class zNPCGoalAttackMonsoon : public zNPCGoalPushAnim // total size: 0x58 public: zNPCGoalAttackMonsoon(S32); + S32 Enter(F32 dt, void* updCtxt); S32 idx_launch; // offset 0x54, size 0x4 }; @@ -685,6 +701,7 @@ class zNPCGoalAttackHammer : public zNPCGoalPushAnim // total size: 0x78 public: zNPCGoalAttackHammer(S32); + void ModifyAnimSpeed(); S32 flg_attack; // offset 0x54, size 0x4 xVec3 pos_lastVert; // offset 0x58, size 0xC xVec3 pos_oldVert; // offset 0x64, size 0xC @@ -734,6 +751,7 @@ class zNPCGoalAlertFodBomb : public zNPCGoalCommon // total size: 0x5C public: zNPCGoalAlertFodBomb(S32); + S32 Resume(F32 dt, void* updCtxt); S32 flg_attack; // offset 0x4C, size 0x4 en_alertbomb alertbomb; // offset 0x50, size 0x4 F32 tmr_nextping; // offset 0x54, size 0x4 @@ -828,6 +846,7 @@ class zNPCGoalTubeLasso : public zNPCGoalCommon // total size: 0x4C public: zNPCGoalTubeLasso(S32); + S32 Enter(F32 dt, void* updCtxt); }; class zNPCGoalTubeDead : public zNPCGoalDead @@ -864,6 +883,7 @@ class zNPCGoalTubeBirth : public zNPCGoalCommon { public: zNPCGoalTubeBirth(S32); + S32 Enter(F32 dt, void* updCtxt); // total size: 0x4C }; @@ -872,6 +892,7 @@ class zNPCGoalTubeAttack : public zNPCGoalCommon // total size: 0x84 public: zNPCGoalTubeAttack(S32); + void AttackDataReset(); S32 flg_attack; // offset 0x4C, size 0x4 union { @@ -942,7 +963,12 @@ class zNPCGoalKnock : public zNPCGoalCommon { // total size: 0x64 public: - zNPCGoalKnock(S32); + zNPCGoalKnock(S32 id) : zNPCGoalCommon(id) + { + SetFlags(2); + flg_npcgable |= 1; + } + S32 flg_knock; // offset 0x4C, size 0x4 xVec3 pos_bumper; // offset 0x50, size 0xC S32 floorBounce; // offset 0x5C, size 0x4 @@ -954,6 +980,7 @@ class zNPCGoalWound : public zNPCGoalPushAnim // total size: 0x64 public: zNPCGoalWound(S32); + S32 NPCMessage(NPCMsg*); xVec3 dir_fling; // offset 0x54, size 0xC S32 flg_knock; // offset 0x60, size 0x4 }; @@ -963,6 +990,7 @@ class zNPCGoalHokeyPokey : public zNPCGoalLoopAnim // total size: 0x74 public: zNPCGoalHokeyPokey(S32); + S32 Enter(F32 dt, void* updCtxt); S32 flg_hokey; // offset 0x6C, size 0x4 F32 ang_spinrate; // offset 0x70, size 0x4 }; diff --git a/src/SB/Game/zNPCGoalVillager.cpp b/src/SB/Game/zNPCGoalVillager.cpp index 558834ea..49610627 100644 --- a/src/SB/Game/zNPCGoalVillager.cpp +++ b/src/SB/Game/zNPCGoalVillager.cpp @@ -531,15 +531,19 @@ S32 zNPCGoalBoyWeep::Enter(F32 dt, void* updCtxt) return zNPCGoalCommon::Enter(dt, updCtxt); } -// Equivalent: branching weirdness S32 zNPCGoalBoyWeep::NPCMessage(NPCMsg* mail) { - if (mail->msgid == NPC_MID_DAMAGE && mail->infotype == NPC_MDAT_DAMAGE && - mail->dmgdata.dmg_type == DMGTYP_SIDE) + switch (mail->msgid) { - ang_spinrate += 16.0f; - zNPCBalloonBoy* npc = (zNPCBalloonBoy*)psyche->clt_owner; - npc->SndPlayRandom(NPC_STYP_EXCLAIM); + case NPC_MID_DAMAGE: + if (mail->infotype == NPC_MDAT_DAMAGE && mail->dmgdata.dmg_type == DMGTYP_SIDE) + { + ang_spinrate += 16.0f; + zNPCBalloonBoy* npc = (zNPCBalloonBoy*)psyche->clt_owner; + npc->SndPlayRandom(NPC_STYP_EXCLAIM); + } + break; } + return 0; } diff --git a/src/SB/Game/zNPCSupport.h b/src/SB/Game/zNPCSupport.h index 8ccb5fe2..c103db45 100644 --- a/src/SB/Game/zNPCSupport.h +++ b/src/SB/Game/zNPCSupport.h @@ -15,6 +15,16 @@ enum en_npctgt NPC_TGT_FORCEINT = 0x7fffffff }; +enum _tageNPCSnd +{ + eNPCSnd_GloveAttack, + eNPCSnd_SleepyAttack, + eNPCSnd_TubeAttack, + eNPCSnd_FodBzztAttack, + eNPCSnd_JellyfishAttack, + eNPCSnd_Total +}; + struct NPCTarget { en_npctgt typ_target; @@ -48,5 +58,6 @@ xVec3* NPCC_faceDir(xEnt* ent); void NPCC_ang_toXZDir(F32 angle, xVec3* dir); F32 NPCC_aimVary(xVec3* dir_aim, xVec3* pos_src, xVec3* pos_tgt, F32 dst_vary, S32 flg_vary, xVec3* pos_aimPoint); F32 NPCC_ds2_toCam(const xVec3* pos_from, xVec3* delta); +void zNPC_SNDStop(_tageNPCSnd snd); #endif diff --git a/src/SB/Game/zNPCTypeCommon.h b/src/SB/Game/zNPCTypeCommon.h index 6060af24..d467db8e 100644 --- a/src/SB/Game/zNPCTypeCommon.h +++ b/src/SB/Game/zNPCTypeCommon.h @@ -410,6 +410,7 @@ struct zNPCCommon : xNPCBasic S32 AnimStart(U32 animID, S32 forceRestart); xAnimState* AnimFindState(U32 animID); xAnimState* AnimCurState(); + xAnimSingle* AnimCurSingle(); U32 AnimCurStateID(); void GiveReward(); S32 SndPlayFromSFX(xSFX* sfx, U32* sid_played); diff --git a/src/SB/Game/zNPCTypeRobot.h b/src/SB/Game/zNPCTypeRobot.h index 4e99ddd2..7ae2e05a 100644 --- a/src/SB/Game/zNPCTypeRobot.h +++ b/src/SB/Game/zNPCTypeRobot.h @@ -178,6 +178,7 @@ struct zNPCFodBzzt : zNPCRobot zNPCFodBzzt(S32 myType); zNPCLassoInfo* PRIV_GetLassoData(); + void DiscoReset(); }; struct zNPCChomper : zNPCRobot