mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 14:50:24 +00:00 
			
		
		
		
	Additional CPlayerGun implementations; downcast macro for tweak pointers
This commit is contained in:
		
							parent
							
								
									86ada63867
								
							
						
					
					
						commit
						1f7e8e1033
					
				| @ -87,80 +87,80 @@ struct ITweakPlayerRes : ITweak | ||||
| 
 | ||||
|     void ResolveResources(const urde::IFactory& factory) | ||||
|     { | ||||
|         x4_saveStationIcon = factory.GetResourceIdByName(GetSaveStationIcon().c_str())->id; | ||||
|         x8_missileStationIcon = factory.GetResourceIdByName(GetMissileStationIcon().c_str())->id; | ||||
|         xc_elevatorIcon = factory.GetResourceIdByName(GetElevatorIcon().c_str())->id; | ||||
|         x4_saveStationIcon = factory.GetResourceIdByName(_GetSaveStationIcon().c_str())->id; | ||||
|         x8_missileStationIcon = factory.GetResourceIdByName(_GetMissileStationIcon().c_str())->id; | ||||
|         xc_elevatorIcon = factory.GetResourceIdByName(_GetElevatorIcon().c_str())->id; | ||||
| 
 | ||||
|         x10_minesBreakFirstTopIcon = factory.GetResourceIdByName(GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x14_minesBreakFirstBottomIcon = factory.GetResourceIdByName(GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x18_minesBreakSecondTopIcon = factory.GetResourceIdByName(GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x1c_minesBreakSecondBottomIcon = factory.GetResourceIdByName(GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x10_minesBreakFirstTopIcon = factory.GetResourceIdByName(_GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x14_minesBreakFirstBottomIcon = factory.GetResourceIdByName(_GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x18_minesBreakSecondTopIcon = factory.GetResourceIdByName(_GetMinesBreakFirstTopIcon().c_str())->id; | ||||
|         x1c_minesBreakSecondBottomIcon = factory.GetResourceIdByName(_GetMinesBreakFirstTopIcon().c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<9 ; ++i) | ||||
|             x24_lStick[i] = factory.GetResourceIdByName(GetLStick(i).c_str())->id; | ||||
|             x24_lStick[i] = factory.GetResourceIdByName(_GetLStick(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<9 ; ++i) | ||||
|             x4c_cStick[i] = factory.GetResourceIdByName(GetCStick(i).c_str())->id; | ||||
|             x4c_cStick[i] = factory.GetResourceIdByName(_GetCStick(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             x74_lTrigger[i] = factory.GetResourceIdByName(GetLTrigger(i).c_str())->id; | ||||
|             x74_lTrigger[i] = factory.GetResourceIdByName(_GetLTrigger(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             x80_rTrigger[i] = factory.GetResourceIdByName(GetRTrigger(i).c_str())->id; | ||||
|             x80_rTrigger[i] = factory.GetResourceIdByName(_GetRTrigger(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             x8c_startButton[i] = factory.GetResourceIdByName(GetStartButton(i).c_str())->id; | ||||
|             x8c_startButton[i] = factory.GetResourceIdByName(_GetStartButton(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             x98_aButton[i] = factory.GetResourceIdByName(GetAButton(i).c_str())->id; | ||||
|             x98_aButton[i] = factory.GetResourceIdByName(_GetAButton(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             xa4_bButton[i] = factory.GetResourceIdByName(GetBButton(i).c_str())->id; | ||||
|             xa4_bButton[i] = factory.GetResourceIdByName(_GetBButton(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             xb0_xButton[i] = factory.GetResourceIdByName(GetXButton(i).c_str())->id; | ||||
|             xb0_xButton[i] = factory.GetResourceIdByName(_GetXButton(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<2 ; ++i) | ||||
|             xbc_yButton[i] = factory.GetResourceIdByName(GetYButton(i).c_str())->id; | ||||
|             xbc_yButton[i] = factory.GetResourceIdByName(_GetYButton(i).c_str())->id; | ||||
| 
 | ||||
|         xc4_ballTransitionsANCS = factory.GetResourceIdByName(GetBallTransitionsANCS().c_str())->id; | ||||
|         xc4_ballTransitionsANCS = factory.GetResourceIdByName(_GetBallTransitionsANCS().c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<5 ; ++i) | ||||
|             xc8_ballTransitions[i] = factory.GetResourceIdByName(GetBallTransitionBeamRes(i).c_str())->id; | ||||
|             xc8_ballTransitions[i] = factory.GetResourceIdByName(_GetBallTransitionBeamRes(i).c_str())->id; | ||||
| 
 | ||||
|         for (int i=0 ; i<5 ; ++i) | ||||
|             xc8_cineGun[i] = factory.GetResourceIdByName(GetBeamCineModel(i).c_str())->id; | ||||
|             xc8_cineGun[i] = factory.GetResourceIdByName(_GetBeamCineModel(i).c_str())->id; | ||||
| 
 | ||||
|         xf0_unkFloat = GetUnkFloat(); | ||||
|         xf0_unkFloat = _GetUnkFloat(); | ||||
|     } | ||||
| 
 | ||||
| protected: | ||||
|     virtual const std::string& GetSaveStationIcon() const=0; | ||||
|     virtual const std::string& GetMissileStationIcon() const=0; | ||||
|     virtual const std::string& GetElevatorIcon() const=0; | ||||
|     virtual const std::string& _GetSaveStationIcon() const=0; | ||||
|     virtual const std::string& _GetMissileStationIcon() const=0; | ||||
|     virtual const std::string& _GetElevatorIcon() const=0; | ||||
| 
 | ||||
|     virtual const std::string& GetMinesBreakFirstTopIcon() const=0; | ||||
|     virtual const std::string& GetMinesBreakFirstBottomIcon() const=0; | ||||
|     virtual const std::string& GetMinesBreakSecondTopIcon() const=0; | ||||
|     virtual const std::string& GetMinesBreakSecondBottomIcon() const=0; | ||||
|     virtual const std::string& _GetMinesBreakFirstTopIcon() const=0; | ||||
|     virtual const std::string& _GetMinesBreakFirstBottomIcon() const=0; | ||||
|     virtual const std::string& _GetMinesBreakSecondTopIcon() const=0; | ||||
|     virtual const std::string& _GetMinesBreakSecondBottomIcon() const=0; | ||||
| 
 | ||||
|     virtual const std::string& GetLStick(size_t idx) const=0; | ||||
|     virtual const std::string& GetCStick(size_t idx) const=0; | ||||
|     virtual const std::string& _GetLStick(size_t idx) const=0; | ||||
|     virtual const std::string& _GetCStick(size_t idx) const=0; | ||||
| 
 | ||||
|     virtual const std::string& GetLTrigger(size_t idx) const=0; | ||||
|     virtual const std::string& GetRTrigger(size_t idx) const=0; | ||||
|     virtual const std::string& GetStartButton(size_t idx) const=0; | ||||
|     virtual const std::string& GetAButton(size_t idx) const=0; | ||||
|     virtual const std::string& GetBButton(size_t idx) const=0; | ||||
|     virtual const std::string& GetXButton(size_t idx) const=0; | ||||
|     virtual const std::string& GetYButton(size_t idx) const=0; | ||||
|     virtual const std::string& _GetLTrigger(size_t idx) const=0; | ||||
|     virtual const std::string& _GetRTrigger(size_t idx) const=0; | ||||
|     virtual const std::string& _GetStartButton(size_t idx) const=0; | ||||
|     virtual const std::string& _GetAButton(size_t idx) const=0; | ||||
|     virtual const std::string& _GetBButton(size_t idx) const=0; | ||||
|     virtual const std::string& _GetXButton(size_t idx) const=0; | ||||
|     virtual const std::string& _GetYButton(size_t idx) const=0; | ||||
| 
 | ||||
|     virtual const std::string& GetBallTransitionsANCS() const=0; | ||||
|     virtual const std::string& _GetBallTransitionsANCS() const=0; | ||||
| 
 | ||||
|     virtual const std::string& GetBallTransitionBeamRes(size_t idx) const=0; | ||||
|     virtual const std::string& GetBeamCineModel(size_t idx) const=0; | ||||
|     virtual const std::string& _GetBallTransitionBeamRes(size_t idx) const=0; | ||||
|     virtual const std::string& _GetBeamCineModel(size_t idx) const=0; | ||||
| 
 | ||||
|     virtual float GetUnkFloat() const=0; | ||||
|     virtual float _GetUnkFloat() const=0; | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| { | ||||
| namespace DNAMP1 | ||||
| { | ||||
| struct CTweakAutoMapper : public ITweakAutoMapper | ||||
| struct CTweakAutoMapper final : public ITweakAutoMapper | ||||
| { | ||||
|     DECL_YAML | ||||
|     Value<bool> x4_24_showOneMiniMapArea : 1; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| { | ||||
| namespace DNAMP1 | ||||
| { | ||||
| struct CTweakBall : public ITweakBall | ||||
| struct CTweakBall final : public ITweakBall | ||||
| { | ||||
|     DECL_YAML | ||||
|     Delete __d; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakGame : ITweakGame | ||||
| struct CTweakGame final : ITweakGame | ||||
| { | ||||
|     DECL_YAML | ||||
|     String<-1> x4_worldPrefix; | ||||
|  | ||||
| @ -7,7 +7,7 @@ namespace DataSpec | ||||
| { | ||||
| namespace DNAMP1 | ||||
| { | ||||
| struct CTweakGui : ITweakGui | ||||
| struct CTweakGui final : ITweakGui | ||||
| { | ||||
|     DECL_YAML | ||||
|     Value<bool> x4_; | ||||
|  | ||||
| @ -7,7 +7,7 @@ namespace DataSpec | ||||
| { | ||||
| namespace DNAMP1 | ||||
| { | ||||
| struct CTweakGuiColors : public ITweakGuiColors | ||||
| struct CTweakGuiColors final : public ITweakGuiColors | ||||
| { | ||||
|     DECL_YAML | ||||
|     DNAColor x4_pauseBlurFilterColor; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakGunRes : ITweakGunRes | ||||
| struct CTweakGunRes final : ITweakGunRes | ||||
| { | ||||
|     DECL_YAML | ||||
| 
 | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakParticle : ITweakParticle | ||||
| struct CTweakParticle final : ITweakParticle | ||||
| { | ||||
|     DECL_YAML | ||||
|     String<-1> m_particle; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakPlayer : ITweakPlayer | ||||
| struct CTweakPlayer final : ITweakPlayer | ||||
| { | ||||
|     Delete _d; | ||||
|     Value<float> x4_maxTranslationalAcceleration[8]; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakPlayerControl : ITweakPlayerControl | ||||
| struct CTweakPlayerControl final : ITweakPlayerControl | ||||
| { | ||||
|     DECL_YAML | ||||
|     Vector<atUint32, DNA_COUNT(67)> m_mappings; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakPlayerGun : ITweakPlayerGun | ||||
| struct CTweakPlayerGun final : ITweakPlayerGun | ||||
| { | ||||
|     DECL_YAML | ||||
|     Value<float> x4_upLookAngle; | ||||
|  | ||||
| @ -8,7 +8,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakPlayerRes : ITweakPlayerRes | ||||
| struct CTweakPlayerRes final : ITweakPlayerRes | ||||
| { | ||||
|     DECL_YAML | ||||
| 
 | ||||
| @ -72,32 +72,32 @@ struct CTweakPlayerRes : ITweakPlayerRes | ||||
| 
 | ||||
|     Value<float> m_unkFloat; | ||||
| 
 | ||||
|     const std::string& GetSaveStationIcon() const { return m_saveStationIcon; } | ||||
|     const std::string& GetMissileStationIcon() const { return m_missileStationIcon; } | ||||
|     const std::string& GetElevatorIcon() const { return m_elevatorIcon; } | ||||
|     const std::string& _GetSaveStationIcon() const { return m_saveStationIcon; } | ||||
|     const std::string& _GetMissileStationIcon() const { return m_missileStationIcon; } | ||||
|     const std::string& _GetElevatorIcon() const { return m_elevatorIcon; } | ||||
| 
 | ||||
|     const std::string& GetMinesBreakFirstTopIcon() const { return m_minesBreakFirstTopIcon; } | ||||
|     const std::string& GetMinesBreakFirstBottomIcon() const { return m_minesBreakFirstBottomIcon; } | ||||
|     const std::string& GetMinesBreakSecondTopIcon() const { return m_minesBreakSecondTopIcon; } | ||||
|     const std::string& GetMinesBreakSecondBottomIcon() const { return m_minesBreakSecondBottomIcon; } | ||||
|     const std::string& _GetMinesBreakFirstTopIcon() const { return m_minesBreakFirstTopIcon; } | ||||
|     const std::string& _GetMinesBreakFirstBottomIcon() const { return m_minesBreakFirstBottomIcon; } | ||||
|     const std::string& _GetMinesBreakSecondTopIcon() const { return m_minesBreakSecondTopIcon; } | ||||
|     const std::string& _GetMinesBreakSecondBottomIcon() const { return m_minesBreakSecondBottomIcon; } | ||||
| 
 | ||||
|     const std::string& GetLStick(size_t idx) const { return (&m_lStickN)[idx]; } | ||||
|     const std::string& GetCStick(size_t idx) const { return (&m_cStickN)[idx]; } | ||||
|     const std::string& _GetLStick(size_t idx) const { return (&m_lStickN)[idx]; } | ||||
|     const std::string& _GetCStick(size_t idx) const { return (&m_cStickN)[idx]; } | ||||
| 
 | ||||
|     const std::string& GetLTrigger(size_t idx) const { return (&m_lTriggerOut)[idx]; } | ||||
|     const std::string& GetRTrigger(size_t idx) const { return (&m_rTriggerOut)[idx]; } | ||||
|     const std::string& GetStartButton(size_t idx) const { return (&m_startButtonOut)[idx]; } | ||||
|     const std::string& GetAButton(size_t idx) const { return (&m_aButtonOut)[idx]; } | ||||
|     const std::string& GetBButton(size_t idx) const { return (&m_bButtonOut)[idx]; } | ||||
|     const std::string& GetXButton(size_t idx) const { return (&m_xButtonOut)[idx]; } | ||||
|     const std::string& GetYButton(size_t idx) const { return (&m_yButtonOut)[idx]; } | ||||
|     const std::string& _GetLTrigger(size_t idx) const { return (&m_lTriggerOut)[idx]; } | ||||
|     const std::string& _GetRTrigger(size_t idx) const { return (&m_rTriggerOut)[idx]; } | ||||
|     const std::string& _GetStartButton(size_t idx) const { return (&m_startButtonOut)[idx]; } | ||||
|     const std::string& _GetAButton(size_t idx) const { return (&m_aButtonOut)[idx]; } | ||||
|     const std::string& _GetBButton(size_t idx) const { return (&m_bButtonOut)[idx]; } | ||||
|     const std::string& _GetXButton(size_t idx) const { return (&m_xButtonOut)[idx]; } | ||||
|     const std::string& _GetYButton(size_t idx) const { return (&m_yButtonOut)[idx]; } | ||||
| 
 | ||||
|     const std::string& GetBallTransitionsANCS() const { return m_ballTransitionsANCS; } | ||||
|     const std::string& _GetBallTransitionsANCS() const { return m_ballTransitionsANCS; } | ||||
| 
 | ||||
|     const std::string& GetBallTransitionBeamRes(size_t idx) const { return (&m_ballTransitionsPower)[idx]; } | ||||
|     const std::string& GetBeamCineModel(size_t idx) const { return (&m_cinePower)[idx]; } | ||||
|     const std::string& _GetBallTransitionBeamRes(size_t idx) const { return (&m_ballTransitionsPower)[idx]; } | ||||
|     const std::string& _GetBeamCineModel(size_t idx) const { return (&m_cinePower)[idx]; } | ||||
| 
 | ||||
|     float GetUnkFloat() const { return m_unkFloat; } | ||||
|     float _GetUnkFloat() const { return m_unkFloat; } | ||||
| 
 | ||||
|     CTweakPlayerRes() = default; | ||||
|     CTweakPlayerRes(athena::io::IStreamReader& in) { read(in); } | ||||
|  | ||||
| @ -9,7 +9,7 @@ namespace DataSpec | ||||
| namespace DNAMP1 | ||||
| { | ||||
| 
 | ||||
| struct CTweakSlideShow : ITweakSlideShow | ||||
| struct CTweakSlideShow final : ITweakSlideShow | ||||
| { | ||||
|     DECL_YAML | ||||
| 
 | ||||
|  | ||||
| @ -7,7 +7,7 @@ namespace DataSpec | ||||
| { | ||||
| namespace DNAMP1 | ||||
| { | ||||
| struct CTweakTargeting : public ITweakTargeting | ||||
| struct CTweakTargeting final : public ITweakTargeting | ||||
| { | ||||
|     DECL_YAML | ||||
|     Value<atUint32> x4_; | ||||
|  | ||||
| @ -95,10 +95,6 @@ public: | ||||
|         Phazon = 27 | ||||
|     }; | ||||
| 
 | ||||
|     enum class EChargeState : u32 | ||||
|     { | ||||
|     }; | ||||
| 
 | ||||
| private: | ||||
| 
 | ||||
|     static const u32 PowerUpMaxValues[41]; | ||||
|  | ||||
| @ -1,5 +1,24 @@ | ||||
| #ifndef __URDE_GAMEGLOBALOBJECTS_HPP__ | ||||
| #define __URDE_GAMEGLOBALOBJECTS_HPP__ | ||||
| 
 | ||||
| #define USE_DOWNCAST_TWEAKS 1 | ||||
| 
 | ||||
| #if USE_DOWNCAST_TWEAKS | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakGame.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakPlayer.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakPlayerControl.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakPlayerGun.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakGunRes.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakPlayerRes.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakGui.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakSlideShow.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakGui.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakTargeting.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakAutoMapper.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakParticle.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakBall.hpp" | ||||
| #include "../DataSpec/DNAMP1/Tweaks/CTweakGuiColors.hpp" | ||||
| #else | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakGame.hpp" | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakPlayer.hpp" | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakPlayerControl.hpp" | ||||
| @ -14,6 +33,7 @@ | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakParticle.hpp" | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakBall.hpp" | ||||
| #include "../DataSpec/DNACommon/Tweaks/ITweakGuiColors.hpp" | ||||
| #endif | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| @ -33,6 +53,21 @@ extern class CBooRenderer* g_Renderer; | ||||
| extern class CStringTable* g_MainStringTable; | ||||
| extern class CInputGenerator* g_InputGenerator; | ||||
| 
 | ||||
| #if USE_DOWNCAST_TWEAKS | ||||
| using ITweakGame = DataSpec::DNAMP1::CTweakGame; | ||||
| using ITweakPlayer = DataSpec::DNAMP1::CTweakPlayer; | ||||
| using ITweakPlayerRes = DataSpec::DNAMP1::CTweakPlayerRes; | ||||
| using ITweakPlayerControl = DataSpec::DNAMP1::CTweakPlayerControl; | ||||
| using ITweakPlayerGun = DataSpec::DNAMP1::CTweakPlayerGun; | ||||
| using ITweakGunRes = DataSpec::DNAMP1::CTweakGunRes; | ||||
| using ITweakTargeting = DataSpec::DNAMP1::CTweakTargeting; | ||||
| using ITweakAutoMapper = DataSpec::DNAMP1::CTweakAutoMapper; | ||||
| using ITweakGui = DataSpec::DNAMP1::CTweakGui; | ||||
| using ITweakSlideShow = DataSpec::DNAMP1::CTweakSlideShow; | ||||
| using ITweakParticle = DataSpec::DNAMP1::CTweakParticle; | ||||
| using ITweakBall = DataSpec::DNAMP1::CTweakBall; | ||||
| using ITweakGuiColors = DataSpec::DNAMP1::CTweakGuiColors; | ||||
| #else | ||||
| using ITweakGame = DataSpec::ITweakGame; | ||||
| using ITweakPlayer = DataSpec::ITweakPlayer; | ||||
| using ITweakPlayerRes = DataSpec::ITweakPlayerRes; | ||||
| @ -46,6 +81,7 @@ using ITweakSlideShow = DataSpec::ITweakSlideShow; | ||||
| using ITweakParticle = DataSpec::ITweakParticle; | ||||
| using ITweakBall = DataSpec::ITweakBall; | ||||
| using ITweakGuiColors = DataSpec::ITweakGuiColors; | ||||
| #endif | ||||
| 
 | ||||
| extern ITweakGame*   g_tweakGame; | ||||
| extern ITweakPlayer* g_tweakPlayer; | ||||
|  | ||||
| @ -431,7 +431,7 @@ void CSamusHud::UpdateFreeLook(float dt, const CStateManager& mgr) | ||||
|     TCastToConstPtr<CFirstPersonCamera> fpCam = mgr.GetCameraManager()->GetCurrentCamera(mgr); | ||||
|     CPlayer& player = mgr.GetPlayer(); | ||||
|     bool inFreeLook = player.IsInFreeLook() && fpCam; | ||||
|     bool lookControlHeld = player.IsLookControlHeld(); | ||||
|     bool lookControlHeld = player.GetFreeLookStickState(); | ||||
|     if (x2e0_24_inFreeLook != inFreeLook) | ||||
|     { | ||||
|         if (inFreeLook) | ||||
| @ -1527,7 +1527,7 @@ void CSamusHud::DrawAttachedEnemyEffect(const CStateManager& mgr) const | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         float halfModPeriod = 0.5 * modPeriod; | ||||
|         float halfModPeriod = 0.5f * modPeriod; | ||||
|         float tmp = std::fabs(std::fmod(drainTime, modPeriod)); | ||||
|         if (tmp < halfModPeriod) | ||||
|             alpha = tmp / halfModPeriod; | ||||
|  | ||||
| @ -0,0 +1,19 @@ | ||||
| #include "CBomb.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| CBomb::CBomb(const TToken<CGenDescription>& particle1, const TToken<CGenDescription>& particle2, | ||||
|              TUniqueId uid, TAreaId aid, TUniqueId playerId, float f1, | ||||
|              const zeus::CTransform& xf, const CDamageInfo& dInfo) | ||||
| : CWeapon(uid, aid, true, playerId, EWeaponType::Bomb, "Bomb", xf, | ||||
|           CMaterialFilter::MakeIncludeExclude({EMaterialTypes::Solid, EMaterialTypes::Trigger, | ||||
|                                                EMaterialTypes::NonSolidDamageable}, | ||||
|                                               {EMaterialTypes::Projectile, EMaterialTypes::Bomb}), | ||||
|           {EMaterialTypes::Projectile, EMaterialTypes::Bomb}, dInfo, EProjectileAttrib::Bombs, | ||||
|           CModelData::CModelDataNull()) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,20 @@ | ||||
| #ifndef __URDE_CBOMB_HPP__ | ||||
| #define __URDE_CBOMB_HPP__ | ||||
| 
 | ||||
| #include "CWeapon.hpp" | ||||
| #include "CToken.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| class CBomb : public CWeapon | ||||
| { | ||||
| public: | ||||
|     CBomb(const TToken<CGenDescription>& particle1, const TToken<CGenDescription>& particle2, | ||||
|           TUniqueId uid, TAreaId aid, TUniqueId playerId, float f1, | ||||
|           const zeus::CTransform& xf, const CDamageInfo& dInfo); | ||||
| }; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #endif // __URDE_CBOMB_HPP__
 | ||||
| @ -3,10 +3,20 @@ | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| CFidget::EState CFidget::Update(int fire, bool bobbing, bool b1, float dt, CStateManager& mgr) | ||||
| { | ||||
|     return EState::Zero; | ||||
| } | ||||
| 
 | ||||
| void CFidget::ResetMinor() | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CFidget::ResetAll() | ||||
| { | ||||
|     x0_state = EState::Zero; | ||||
|     x4_ = -1; | ||||
|     x4_type = SamusGun::EFidgetType::Invalid; | ||||
|     x18_ = 0.f; | ||||
|     x1c_ = 0.f; | ||||
|     x14_ = 0.f; | ||||
| @ -14,9 +24,9 @@ void CFidget::ResetAll() | ||||
|     x28_ = 0.f; | ||||
|     x2c_ = 0.f; | ||||
|     x8_ = 0; | ||||
|     xc_ = -1; | ||||
|     xc_parm2 = -1; | ||||
|     x10_ = 3; | ||||
|     x34_24_ = false; | ||||
|     x34_24_loading = false; | ||||
| } | ||||
| 
 | ||||
| } | ||||
| @ -2,9 +2,11 @@ | ||||
| #define __URDE_CFIDGET_HPP__ | ||||
| 
 | ||||
| #include "RetroTypes.hpp" | ||||
| #include "CGunMotion.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| class CStateManager; | ||||
| 
 | ||||
| class CFidget | ||||
| { | ||||
| @ -22,9 +24,9 @@ public: | ||||
|     }; | ||||
| private: | ||||
|     EState x0_state = EState::Zero; | ||||
|     s32 x4_ = -1; | ||||
|     SamusGun::EFidgetType x4_type = SamusGun::EFidgetType::Invalid; | ||||
|     u32 x8_ = 0; | ||||
|     s32 xc_ = -1; | ||||
|     s32 xc_parm2 = -1; | ||||
|     u32 x10_ = 3; | ||||
|     float x14_ = 0.f; | ||||
|     float x18_ = 0.f; | ||||
| @ -34,10 +36,15 @@ private: | ||||
|     float x28_ = 0.f; | ||||
|     float x2c_ = 0.f; | ||||
|     float x30_ = 105.f; | ||||
|     bool x34_24_ = false; | ||||
|     bool x34_24_loading = false; | ||||
| public: | ||||
|     EState GetState() const { return x0_state; } | ||||
|     SamusGun::EFidgetType GetType() const { return x4_type; } | ||||
|     s32 GetParm2() const { return xc_parm2; } | ||||
|     EState Update(int fire, bool bobbing, bool b1, float dt, CStateManager& mgr); | ||||
|     void ResetMinor(); | ||||
|     void ResetAll(); | ||||
|     void DoneLoading() { x34_24_loading = false; } | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -11,14 +11,14 @@ bool CGSFidget::Update(CAnimData& data, float dt, CStateManager& mgr) | ||||
|     return !data.IsAnimTimeRemaining(0.001f, "Whole Body"); | ||||
| } | ||||
| 
 | ||||
| s32 CGSFidget::SetAnim(CAnimData& data, s32 type, s32 parm1, s32 parm2, CStateManager& mgr) | ||||
| s32 CGSFidget::SetAnim(CAnimData& data, s32 type, s32 gunId, s32 parm2, CStateManager& mgr) | ||||
| { | ||||
|     const CPASDatabase& pas = data.GetCharacterInfo().GetPASDatabase(); | ||||
|     CPASAnimParmData parms(1, CPASAnimParm::FromEnum(type), CPASAnimParm::FromInt32(parm1), | ||||
|                            CPASAnimParm::FromEnum(parm2)); | ||||
|     CPASAnimParmData parms(1, CPASAnimParm::FromEnum(type), CPASAnimParm::FromInt32(gunId), | ||||
|                            CPASAnimParm::FromInt32(parm2)); | ||||
|     auto anim = pas.FindBestAnimation(parms, *mgr.GetActiveRandom(), -1); | ||||
|     bool loop = pas.GetAnimState(1)->GetAnimParmData(anim.second, 3).GetBoolValue(); | ||||
|     x14_parm1 = parm1; | ||||
|     x14_gunId = gunId; | ||||
|     x18_parm2 = parm2; | ||||
|     if (anim.second != -1) | ||||
|     { | ||||
| @ -30,10 +30,10 @@ s32 CGSFidget::SetAnim(CAnimData& data, s32 type, s32 parm1, s32 parm2, CStateMa | ||||
|     return anim.second; | ||||
| } | ||||
| 
 | ||||
| void CGSFidget::LoadAnimAsync(CAnimData& data, s32 type, s32 parm1, s32 parm2, CStateManager& mgr) | ||||
| void CGSFidget::LoadAnimAsync(CAnimData& data, s32 type, s32 gunId, s32 parm2, CStateManager& mgr) | ||||
| { | ||||
|     CPASAnimParmData parms(1, CPASAnimParm::FromEnum(type), CPASAnimParm::FromInt32(parm1), | ||||
|                            CPASAnimParm::FromEnum(parm2)); | ||||
|     CPASAnimParmData parms(1, CPASAnimParm::FromEnum(type), CPASAnimParm::FromInt32(gunId), | ||||
|                            CPASAnimParm::FromInt32(parm2)); | ||||
|     auto anim = data.GetCharacterInfo().GetPASDatabase().FindBestAnimation(parms, *mgr.GetActiveRandom(), -1); | ||||
|     if (anim.second != -1) | ||||
|         NWeaponTypes::get_token_vector(data, anim.second, x0_anims, true); | ||||
|  | ||||
| @ -12,12 +12,12 @@ class CGSFidget | ||||
| { | ||||
|     std::vector<CToken> x0_anims; | ||||
|     s32 x10_ = -1; | ||||
|     s32 x14_parm1 = -1; | ||||
|     s32 x14_gunId = -1; | ||||
|     s32 x18_parm2 = -1; | ||||
| public: | ||||
|     bool Update(CAnimData& data, float dt, CStateManager& mgr); | ||||
|     s32 SetAnim(CAnimData& data, s32 type, s32 parm1, s32 parm2, CStateManager& mgr); | ||||
|     void LoadAnimAsync(CAnimData& data, s32 type, s32 parm1, s32 parm2, CStateManager& mgr); | ||||
|     s32 SetAnim(CAnimData& data, s32 type, s32 gunId, s32 parm2, CStateManager& mgr); | ||||
|     void LoadAnimAsync(CAnimData& data, s32 type, s32 gunId, s32 parm2, CStateManager& mgr); | ||||
|     void UnLoadAnim(); | ||||
|     bool IsAnimLoaded() const; | ||||
| }; | ||||
|  | ||||
| @ -61,6 +61,16 @@ void CGrappleArm::EnterIdle(CStateManager& mgr) | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CGrappleArm::EnterFidget(CStateManager& mgr, SamusGun::EFidgetType type, s32 gunId, s32 parm2) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CGrappleArm::EnterFreeLook(s32 gunId, s32 setId, CStateManager& mgr) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CGrappleArm::ReturnToDefault(CStateManager& mgr, float f1, bool b1) | ||||
| { | ||||
| 
 | ||||
|  | ||||
| @ -6,6 +6,7 @@ | ||||
| #include "Character/CModelData.hpp" | ||||
| #include "CStateManager.hpp" | ||||
| #include "CGunController.hpp" | ||||
| #include "CGunMotion.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| @ -66,6 +67,8 @@ public: | ||||
|     void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&); | ||||
|     void EnterStruck(CStateManager& mgr, float angle, bool attack, bool b2); | ||||
|     void EnterIdle(CStateManager& mgr); | ||||
|     void EnterFidget(CStateManager& mgr, SamusGun::EFidgetType type, s32 gunId, s32 parm2); | ||||
|     void EnterFreeLook(s32 gunId, s32 setId, CStateManager& mgr); | ||||
|     void ReturnToDefault(CStateManager& mgr, float f1, bool b1); | ||||
|     CGunController* GunController() { return x328_gunController.get(); } | ||||
| }; | ||||
|  | ||||
| @ -6,14 +6,14 @@ | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| void CGunController::LoadFidgetAnimAsync(CStateManager& mgr, s32 type, s32 parm1, s32 parm2) | ||||
| void CGunController::LoadFidgetAnimAsync(CStateManager& mgr, s32 type, s32 gunId, s32 parm2) | ||||
| { | ||||
|     x30_fidget.LoadAnimAsync(*x0_modelData.AnimationData(), type, parm1, parm2, mgr); | ||||
|     x30_fidget.LoadAnimAsync(*x0_modelData.AnimationData(), type, gunId, parm2, mgr); | ||||
| } | ||||
| 
 | ||||
| void CGunController::EnterFidget(CStateManager& mgr, s32 type, s32 parm1, s32 parm2) | ||||
| void CGunController::EnterFidget(CStateManager& mgr, s32 type, s32 gunId, s32 parm2) | ||||
| { | ||||
|     x54_curAnimId = x30_fidget.SetAnim(*x0_modelData.AnimationData(), type, parm1, parm2, mgr); | ||||
|     x54_curAnimId = x30_fidget.SetAnim(*x0_modelData.AnimationData(), type, gunId, parm2, mgr); | ||||
|     x50_gunState = EGunState::Fidget; | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -40,8 +40,8 @@ public: | ||||
|     } | ||||
| 
 | ||||
|     void UnLoadFidget() { x30_fidget.UnLoadAnim(); } | ||||
|     void LoadFidgetAnimAsync(CStateManager& mgr, s32 type, s32 parm1, s32 parm2); | ||||
|     void EnterFidget(CStateManager& mgr, s32 type, s32 parm1, s32 parm2); | ||||
|     void LoadFidgetAnimAsync(CStateManager& mgr, s32 type, s32 gunId, s32 parm2); | ||||
|     void EnterFidget(CStateManager& mgr, s32 type, s32 gunId, s32 parm2); | ||||
|     bool IsFidgetLoaded() const { return x30_fidget.IsAnimLoaded(); } | ||||
|     s32 GetFreeLookSetId() const { return x4_freeLook.GetSetId(); } | ||||
|     bool IsComboOver() const { return x1c_comboFire.IsComboOver(); } | ||||
|  | ||||
| @ -10,7 +10,7 @@ CGunMotion::CGunMotion(CAssetId ancsId, const zeus::CVector3f& scale) | ||||
| : x0_modelData(CAnimRes(ancsId, 0, scale, 0, false), 1), | ||||
|   x4c_gunController(x0_modelData) | ||||
| { | ||||
|     xb8_24_inFidget = false; | ||||
|     xb8_24_animPlaying = false; | ||||
|     LoadAnimations(); | ||||
| } | ||||
| 
 | ||||
| @ -84,7 +84,7 @@ void CGunMotion::BasePosition(bool bigStrikeReset) | ||||
| 
 | ||||
| void CGunMotion::EnterFidget(CStateManager& mgr, SamusGun::EFidgetType type, s32 parm2) | ||||
| { | ||||
|     xb8_24_inFidget = true; | ||||
|     xb8_24_animPlaying = true; | ||||
|     x4c_gunController.EnterFidget(mgr, s32(type), 0, parm2); | ||||
| } | ||||
| 
 | ||||
| @ -92,7 +92,7 @@ void CGunMotion::Update(float dt, CStateManager& mgr) | ||||
| { | ||||
|     x0_modelData.AdvanceAnimation(dt, mgr, kInvalidAreaId, true); | ||||
|     if (x4c_gunController.Update(dt, mgr)) | ||||
|         xb8_24_inFidget = false; | ||||
|         xb8_24_animPlaying = false; | ||||
| } | ||||
| 
 | ||||
| void CGunMotion::Draw(const CStateManager& mgr, const zeus::CTransform& xf) const | ||||
|  | ||||
| @ -23,7 +23,9 @@ enum class EAnimationState | ||||
| }; | ||||
| enum class EFidgetType | ||||
| { | ||||
|     Zero | ||||
|     Invalid = -1, | ||||
|     Zero, | ||||
|     One | ||||
| }; | ||||
| } | ||||
| 
 | ||||
| @ -32,7 +34,7 @@ class CGunMotion | ||||
|     CModelData x0_modelData; | ||||
|     CGunController x4c_gunController; | ||||
|     std::vector<CToken> xa8_anims; | ||||
|     bool xb8_24_inFidget : 1; | ||||
|     bool xb8_24_animPlaying : 1; | ||||
| 
 | ||||
|     void LoadAnimations(); | ||||
| 
 | ||||
| @ -47,6 +49,7 @@ public: | ||||
|     void Draw(const CStateManager& mgr, const zeus::CTransform& xf) const; | ||||
|     s32 GetFreeLookSetId() const { return x4c_gunController.GetFreeLookSetId(); } | ||||
|     CGunController& GunController() { return x4c_gunController; } | ||||
|     bool IsAnimPlaying() const { return xb8_24_animPlaying; } | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -12,6 +12,7 @@ | ||||
| #include "CStateManager.hpp" | ||||
| #include "CGunController.hpp" | ||||
| #include "WeaponCommon.hpp" | ||||
| #include "CGunMotion.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| @ -20,16 +21,23 @@ class CActorLights; | ||||
| struct CModelFlags; | ||||
| class CWeaponDescription; | ||||
| 
 | ||||
| enum class EChargeState | ||||
| { | ||||
|     Normal, | ||||
|     Charged | ||||
| }; | ||||
| 
 | ||||
| using SWeaponInfo = DataSpec::SWeaponInfo; | ||||
| 
 | ||||
| class CVelocityInfo | ||||
| { | ||||
|     friend class CGunWeapon; | ||||
|     rstl::reserved_vector<zeus::CVector3f, 2> x0_vel; | ||||
|     rstl::reserved_vector<bool, 2> x1c_; | ||||
|     rstl::reserved_vector<bool, 2> x1c_targetHoming; | ||||
|     rstl::reserved_vector<float, 2> x24_; | ||||
| public: | ||||
|     const zeus::CVector3f& GetVelocity(int i) const { return x0_vel[i]; } | ||||
|     bool GetTargetHoming(int i) const { return x1c_targetHoming[i]; } | ||||
| }; | ||||
| 
 | ||||
| class CGunWeapon | ||||
| @ -95,7 +103,8 @@ public: | ||||
|     virtual void PreRenderGunFx(const CStateManager&, const zeus::CTransform&) {} | ||||
|     virtual void PostRenderGunFx(const CStateManager&, const zeus::CTransform&) {} | ||||
|     virtual void UpdateGunFx(bool, float, const CStateManager&, const zeus::CTransform&) {} | ||||
|     virtual void Fire(bool, float, CPlayerState::EChargeState, const zeus::CTransform&, CStateManager&, TUniqueId) {} | ||||
|     virtual void Fire(bool underwater, float dt, EChargeState chargeState, const zeus::CTransform& xf, | ||||
|                       CStateManager& mgr, TUniqueId homingTarget) {} | ||||
|     virtual void EnableFx(bool) {} | ||||
|     virtual void EnableSecondaryFx(ESecondaryFxType) {} | ||||
|     void BuildSecondaryEffect(ESecondaryFxType type); | ||||
| @ -115,6 +124,11 @@ public: | ||||
|     CElementGen* GetChargeMuzzleFx() const { return x1a4_muzzleGenerators[1].get(); } | ||||
|     void ReturnToDefault(CStateManager& mgr) {} | ||||
|     void UnLoadFidget() {} | ||||
|     bool IsFidgetLoaded() const { return x100_gunController->IsFidgetLoaded(); } | ||||
|     void AsyncLoadFidget(CStateManager& mgr, SamusGun::EFidgetType type, s32 parm2) | ||||
|     { x100_gunController->LoadFidgetAnimAsync(mgr, s32(type), s32(x200_beamId), parm2); } | ||||
|     void EnterFidget(CStateManager& mgr, SamusGun::EFidgetType type, s32 parm2) | ||||
|     { x100_gunController->EnterFidget(mgr, s32(type), s32(x200_beamId), parm2); } | ||||
|     CModelData& GetSolidModelData() { return *x10_solidModelData; } | ||||
|     const SWeaponInfo& GetWeaponInfo() const; | ||||
|     zeus::CAABox GetBounds() const; | ||||
|  | ||||
| @ -9,6 +9,8 @@ | ||||
| #include "World/CScriptWater.hpp" | ||||
| #include "World/CGameLight.hpp" | ||||
| #include "Input/ControlMapper.hpp" | ||||
| #include "CBomb.hpp" | ||||
| #include "CPowerBomb.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| @ -319,8 +321,8 @@ void CPlayerGun::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId sender, CSt | ||||
|     case EScriptObjectMessage::OnFloor: | ||||
|         if (player.GetControlsFrozen() && !x834_30_inBigStrike) | ||||
|         { | ||||
|             x2f4_ = 0; | ||||
|             x2ec_firing = 0; | ||||
|             x2f4_fireButtonStates = 0; | ||||
|             x2ec_lastFireButtonStates = 0; | ||||
|             CancelFiring(mgr); | ||||
|             TakeDamage(true, false, mgr); | ||||
|             x394_damageTimer = 0.75f; | ||||
| @ -409,7 +411,7 @@ void CPlayerGun::ResetCharge(CStateManager& mgr, bool b1) | ||||
|             PlayAnim(NWeaponTypes::EGunAnimType::Zero, false); | ||||
|         if (r30) | ||||
|             x72c_currentBeam->EnableSecondaryFx(CGunWeapon::ESecondaryFxType::Zero); | ||||
|         if ((x2f8_ & 0x2) != 0x2 || x330_chargeWeaponIdx != 0) | ||||
|         if ((x2f8_ & 0x2) != 0x2 || x330_chargeState != EChargeState::Normal) | ||||
|         { | ||||
|             if ((x2f8_ & 0x8) != 0x8) | ||||
|             { | ||||
| @ -422,7 +424,7 @@ void CPlayerGun::ResetCharge(CStateManager& mgr, bool b1) | ||||
|     } | ||||
| 
 | ||||
|     x32c_ = 0; | ||||
|     x330_chargeWeaponIdx = 0; | ||||
|     x330_chargeState = EChargeState::Normal; | ||||
|     x320_ = x310_selectedBeam; | ||||
|     x833_30_ = true; | ||||
|     x832_27_ = false; | ||||
| @ -449,6 +451,14 @@ static const CPlayerState::EItemType skBeamArr[] = | ||||
|     CPlayerState::EItemType::PlasmaBeam | ||||
| }; | ||||
| 
 | ||||
| static const CPlayerState::EItemType skBeamComboArr[] = | ||||
| { | ||||
|     CPlayerState::EItemType::SuperMissile, | ||||
|     CPlayerState::EItemType::IceSpreader, | ||||
|     CPlayerState::EItemType::Wavebuster, | ||||
|     CPlayerState::EItemType::Flamethrower | ||||
| }; | ||||
| 
 | ||||
| static const ControlMapper::ECommands mBeamCtrlCmd[] = | ||||
| { | ||||
|     ControlMapper::ECommands::PowerBeam, | ||||
| @ -555,7 +565,7 @@ void CPlayerGun::ResetBeamParams(CStateManager& mgr, const CPlayerState& playerS | ||||
|     Reset(mgr, false); | ||||
|     if (playSelectionSfx) | ||||
|         CSfxManager::SfxStart(1774, 1.f, 0.f, true, 0x7f, false, kInvalidAreaId); | ||||
|     x2ec_firing &= ~0x1; | ||||
|     x2ec_lastFireButtonStates &= ~0x1; | ||||
|     x320_ = x310_selectedBeam; | ||||
|     x833_30_ = true; | ||||
| } | ||||
| @ -696,28 +706,28 @@ void CPlayerGun::ProcessInput(const CFinalInput& input, CStateManager& mgr) | ||||
|     switch (mgr.GetPlayer().GetMorphballTransitionState()) | ||||
|     { | ||||
|     default: | ||||
|         x2f4_ = 0; | ||||
|         x2f4_fireButtonStates = 0; | ||||
|         break; | ||||
|     case CPlayer::EPlayerMorphBallState::Unmorphed: | ||||
|         if ((x2f8_ & 0x10) != 0x10) | ||||
|             HandleWeaponChange(input, mgr); | ||||
|     case CPlayer::EPlayerMorphBallState::Morphed: | ||||
|         x2f4_ = ControlMapper::GetDigitalInput(ControlMapper::ECommands::FireOrBomb, input) ? 1 : 0; | ||||
|         x2f4_ |= ControlMapper::GetDigitalInput(ControlMapper::ECommands::MissileOrPowerBomb, input) ? 2 : 0; | ||||
|         x2f4_fireButtonStates = ControlMapper::GetDigitalInput(ControlMapper::ECommands::FireOrBomb, input) ? 1 : 0; | ||||
|         x2f4_fireButtonStates |= ControlMapper::GetDigitalInput(ControlMapper::ECommands::MissileOrPowerBomb, input) ? 2 : 0; | ||||
|         break; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UnLoadFidget() | ||||
| { | ||||
|     if ((x2fc_ & 0x1) == 0x1) | ||||
|     if ((x2fc_fidgetAnimBits & 0x1) == 0x1) | ||||
|         x73c_gunMotion->GunController().UnLoadFidget(); | ||||
|     if ((x2fc_ & 0x2) == 0x2) | ||||
|     if ((x2fc_fidgetAnimBits & 0x2) == 0x2) | ||||
|         x72c_currentBeam->UnLoadFidget(); | ||||
|     if ((x2fc_ & 0x4) == 0x4) | ||||
|     if ((x2fc_fidgetAnimBits & 0x4) == 0x4) | ||||
|         if (CGunController* gc = x740_grappleArm->GunController()) | ||||
|             gc->UnLoadFidget(); | ||||
|     x2fc_ = 0; | ||||
|     x2fc_fidgetAnimBits = 0; | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::ReturnArmAndGunToDefault(CStateManager& mgr, bool b1) | ||||
| @ -787,7 +797,7 @@ void CPlayerGun::CancelFiring(CStateManager& mgr) | ||||
| float CPlayerGun::GetBeamVelocity() const | ||||
| { | ||||
|     if (x72c_currentBeam->IsLoaded()) | ||||
|         return x72c_currentBeam->GetVelocityInfo().GetVelocity(x330_chargeWeaponIdx).y; | ||||
|         return x72c_currentBeam->GetVelocityInfo().GetVelocity(int(x330_chargeState)).y; | ||||
|     return 10.f; | ||||
| } | ||||
| 
 | ||||
| @ -881,16 +891,464 @@ void CPlayerGun::CancelLockOn() | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UpdateWeaponFire(float dt, const CPlayerState& playerState, CStateManager& mgr) | ||||
| void CPlayerGun::FireSecondary(float dt, CStateManager& mgr) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UpdateGunIdle(bool b1, float camBobT, float dt, CStateManager& mgr) | ||||
| void CPlayerGun::ResetCharged(float dt, CStateManager& mgr) | ||||
| { | ||||
|     if (x832_26_) | ||||
|         return; | ||||
|     if (x32c_ >= 3) | ||||
|     { | ||||
|         x833_30_ = false; | ||||
|         UpdateNormalShotCycle(dt, mgr); | ||||
|         x832_24_ = true; | ||||
|         CancelCharge(mgr, true); | ||||
|     } | ||||
|     else if (x32c_ != 0) | ||||
|     { | ||||
|         x320_ = x310_selectedBeam; | ||||
|         x833_30_ = true; | ||||
|         x32c_ = 10; | ||||
|     } | ||||
|     StopChargeSound(mgr); | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::ActivateCombo(CStateManager& mgr) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::ProcessChargeState(u32 releasedStates, u32 pressedStates, CStateManager& mgr, float dt) | ||||
| { | ||||
|     if ((releasedStates & 0x1) != 0) | ||||
|         ResetCharged(dt, mgr); | ||||
|     if ((pressedStates & 0x1) != 0) | ||||
|     { | ||||
|         if (x32c_ == 0 && (pressedStates & 0x1) != 0 && x348_ == 0.f && x832_28_) | ||||
|         { | ||||
|             UpdateNormalShotCycle(dt, mgr); | ||||
|             x32c_ = 1; | ||||
|         } | ||||
|     } | ||||
|     else if (mgr.GetPlayerState()->HasPowerUp(CPlayerState::EItemType::Missiles) && (pressedStates & 0x2) != 0) | ||||
|     { | ||||
|         if (x32c_ >= 4) | ||||
|         { | ||||
|             if (mgr.GetPlayerState()->HasPowerUp(skBeamComboArr[x310_selectedBeam])) | ||||
|                 ActivateCombo(mgr); | ||||
|         } | ||||
|         else if (x32c_ == 0) | ||||
|         { | ||||
|             FireSecondary(dt, mgr); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::ResetNormal(CStateManager& mgr) | ||||
| { | ||||
|     Reset(mgr, false); | ||||
|     x832_28_ = false; | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UpdateNormalShotCycle(float dt, CStateManager& mgr) | ||||
| { | ||||
|     if (!ExitMissile()) | ||||
|         return; | ||||
|     if (mgr.GetCameraManager()->IsInCinematicCamera()) | ||||
|         return; | ||||
|     x832_25_ = x833_28_phazonBeamActive || x310_selectedBeam != 3 || x32c_ != 0; | ||||
|     x30c_ += 1; | ||||
|     zeus::CTransform xf = x833_29_pointBlankWorldSurface ? x448_elbowWorldXf : x4a8_gunWorldXf * x418_beamLocalXf; | ||||
|     if (!x833_29_pointBlankWorldSurface && x364_ <= 0.f) | ||||
|     { | ||||
|         zeus::CVector3f oldOrigin = xf.origin; | ||||
|         xf = x478_assistAimXf; | ||||
|         xf.origin = oldOrigin; | ||||
|     } | ||||
|     xf.origin += mgr.GetCameraManager()->GetGlobalCameraTranslation(mgr); | ||||
|     x38c_ = 0.0625f; | ||||
|     TUniqueId homingTarget; | ||||
|     if (x72c_currentBeam->GetVelocityInfo().GetTargetHoming(int(x330_chargeState))) | ||||
|         homingTarget = GetTargetId(mgr); | ||||
|     else | ||||
|         homingTarget = kInvalidUniqueId; | ||||
|     x72c_currentBeam->Fire(x834_27_underwater, dt, x330_chargeState, xf, mgr, homingTarget); | ||||
|     mgr.InformListeners(x4a8_gunWorldXf.origin, EListenNoiseType::Zero); | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::ProcessNormalState(u32 releasedStates, u32 pressedStates, CStateManager& mgr, float dt) | ||||
| { | ||||
|     if ((releasedStates & 0x1) != 0) | ||||
|         ResetNormal(mgr); | ||||
|     if ((pressedStates & 0x1) != 0 && x348_ == 0.f && x832_28_) | ||||
|         UpdateNormalShotCycle(dt, mgr); | ||||
|     else if ((pressedStates & 0x2) != 0) | ||||
|         FireSecondary(dt, mgr); | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UpdateWeaponFire(float dt, const CPlayerState& playerState, CStateManager& mgr) | ||||
| { | ||||
|     u32 oldFiring = x2ec_lastFireButtonStates; | ||||
|     x2ec_lastFireButtonStates = x2f4_fireButtonStates; | ||||
|     u32 pressedStates = x2f4_fireButtonStates & (oldFiring ^ x2f4_fireButtonStates); | ||||
|     x2f0_pressedFireButtonStates = pressedStates; | ||||
|     u32 releasedStates = oldFiring & (oldFiring ^ x2f4_fireButtonStates); | ||||
|     x832_28_ = false; | ||||
| 
 | ||||
|     CPlayer& player = mgr.GetPlayer(); | ||||
|     if (!x832_24_ && !x834_30_inBigStrike) | ||||
|     { | ||||
|         float coolDown = x72c_currentBeam->GetWeaponInfo().x0_coolDown; | ||||
|         if ((pressedStates & 0x1) == 0) | ||||
|         { | ||||
|             if (x390_cooldown >= coolDown) | ||||
|             { | ||||
|                 x390_cooldown = coolDown; | ||||
|                 if (player.GetMorphballTransitionState() == CPlayer::EPlayerMorphBallState::Unmorphed && | ||||
|                     mgr.GetPlayerState()->ItemEnabled(CPlayerState::EItemType::ChargeBeam) && | ||||
|                     player.GetGunHolsterState() == CPlayer::EGunHolsterState::Drawn && | ||||
|                     player.GetGrappleState() == CPlayer::EGrappleState::None && | ||||
|                     mgr.GetPlayerState()->GetTransitioningVisor() != CPlayerState::EPlayerVisor::Scan && | ||||
|                     mgr.GetPlayerState()->GetCurrentVisor() != CPlayerState::EPlayerVisor::Scan && | ||||
|                     (x2ec_lastFireButtonStates & 0x1) != 0 && x32c_ == 0) | ||||
|                 { | ||||
|                     x832_28_ = true; | ||||
|                     pressedStates |= 0x1; | ||||
|                     x390_cooldown = 0.f; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else if (x390_cooldown >= coolDown) | ||||
|         { | ||||
|             x832_28_ = true; | ||||
|             x390_cooldown = 0.f; | ||||
|         } | ||||
|         x390_cooldown += dt; | ||||
|     } | ||||
| 
 | ||||
|     if (x834_28_) | ||||
|         x834_28_ = (x2ec_lastFireButtonStates & 0x1) != 0; | ||||
| 
 | ||||
|     if (player.GetMorphballTransitionState() == CPlayer::EPlayerMorphBallState::Morphed) | ||||
|     { | ||||
|         x835_28_bombReady = false; | ||||
|         x835_29_powerBombReady = false; | ||||
|         if (!x835_31_actorAttached) | ||||
|         { | ||||
|             x835_28_bombReady = false; | ||||
|             if (x53a_powerBomb != kInvalidUniqueId && | ||||
|                 !mgr.CanCreateProjectile(x538_playerId, EWeaponType::PowerBomb, 1)) | ||||
|             { | ||||
|                 auto* pb = static_cast<const CPowerBomb*>(mgr.GetObjectById(x53a_powerBomb)); | ||||
|                 if (pb && pb->GetCurTime() <= 4.25f) | ||||
|                     x835_28_bombReady = false; | ||||
|                 else | ||||
|                     x53a_powerBomb = kInvalidUniqueId; | ||||
|             } | ||||
|             if (((pressedStates & 0x1) != 0 || x32c_ != 0) && | ||||
|                 mgr.GetPlayerState()->HasPowerUp(CPlayerState::EItemType::MorphBallBombs)) | ||||
|             { | ||||
|                 if (x835_28_bombReady) | ||||
|                     DropBomb(EBWeapon::Zero, mgr); | ||||
|             } | ||||
|             else if (mgr.GetPlayerState()->HasPowerUp(CPlayerState::EItemType::PowerBombs) && | ||||
|                      mgr.GetPlayerState()->GetItemAmount(CPlayerState::EItemType::PowerBombs) > 0) | ||||
|             { | ||||
|                 x835_29_powerBombReady = mgr.CanCreateProjectile(x538_playerId, EWeaponType::PowerBomb, 1) && | ||||
|                                          mgr.CanCreateProjectile(x538_playerId, EWeaponType::Bomb, 1); | ||||
|                 if ((pressedStates & 0x2) != 0 && x835_29_powerBombReady) | ||||
|                     DropBomb(EBWeapon::One, mgr); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     else if ((x2f8_ & 0x8) != 0x8 && | ||||
|              player.GetMorphballTransitionState() == CPlayer::EPlayerMorphBallState::Unmorphed) | ||||
|     { | ||||
|         if ((pressedStates & 0x2) != 0 && !x318_ && (x2f8_ & 0x2) != 0x2 && !x32c_) | ||||
|         { | ||||
|             u32 missileCount = mgr.GetPlayerState()->GetItemAmount(CPlayerState::EItemType::Missiles); | ||||
|             if (x338_ != 1 && x338_ != 2) | ||||
|             { | ||||
|                 if (mgr.GetPlayerState()->HasPowerUp(CPlayerState::EItemType::Missiles) && missileCount > 0) | ||||
|                 { | ||||
|                     x300_ = missileCount; | ||||
|                     if (x300_ > 5) | ||||
|                         x300_ = 5; | ||||
|                     if (!x835_25_inPhazonBeam) | ||||
|                     { | ||||
|                         x2f8_ &= ~0x1; | ||||
|                         x2f8_ |= 0x6; | ||||
|                         x318_ = 1; | ||||
|                         x31c_missileMode = EMissleMode::Active; | ||||
|                     } | ||||
|                     FireSecondary(dt, mgr); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     if (!CSfxManager::IsPlaying(x2e4_invalidSfx)) | ||||
|                         x2e4_invalidSfx = PlaySfx(1781, x834_27_underwater, false, 0.165f); | ||||
|                     else | ||||
|                         x2e4_invalidSfx.reset(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             if (x3a4_fidget.GetState() == CFidget::EState::Zero) | ||||
|             { | ||||
|                 if ((x2f8_ & 0x10) == 0x10 && x744_auxWeapon->IsComboFxActive(mgr)) | ||||
|                 { | ||||
|                     if (x2ec_lastFireButtonStates == 0 || (x310_selectedBeam == 2 && x833_29_pointBlankWorldSurface)) | ||||
|                     { | ||||
|                         StopContinuousBeam(mgr, (x2f8_ & 0x8) == 0x8); | ||||
|                     } | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     if (mgr.GetPlayerState()->ItemEnabled(CPlayerState::EItemType::ChargeBeam) && | ||||
|                         x33c_gunOverrideMode == EGunOverrideMode::Normal) | ||||
|                         ProcessChargeState(releasedStates, pressedStates, mgr, dt); | ||||
|                     else | ||||
|                         ProcessNormalState(releasedStates, pressedStates, mgr, dt); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::EnterFreeLook(CStateManager& mgr) | ||||
| { | ||||
|     if (!x832_30_) | ||||
|         x73c_gunMotion->PlayPasAnim(SamusGun::EAnimationState::FreeLook, mgr, 0.f, false); | ||||
|     x740_grappleArm->EnterFreeLook(x835_25_inPhazonBeam ? 1 : x310_selectedBeam, | ||||
|                                    x73c_gunMotion->GetFreeLookSetId(), mgr); | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::SetFidgetAnimBits(int parm2, bool beamOnly) | ||||
| { | ||||
|     x2fc_fidgetAnimBits = 0; | ||||
|     if (beamOnly) | ||||
|     { | ||||
|         x2fc_fidgetAnimBits = 2; | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     switch (x3a4_fidget.GetType()) | ||||
|     { | ||||
|     case SamusGun::EFidgetType::Zero: | ||||
|         x2fc_fidgetAnimBits = 1; | ||||
|         if (parm2 != 1) | ||||
|             return; | ||||
|         x2fc_fidgetAnimBits |= 4; | ||||
|         break; | ||||
|     case SamusGun::EFidgetType::One: | ||||
|         if (parm2 >= 6 || parm2 < 4) | ||||
|             x2fc_fidgetAnimBits = 2; | ||||
|         else | ||||
|             x2fc_fidgetAnimBits = 1; | ||||
|         x2fc_fidgetAnimBits |= 4; | ||||
|         break; | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::AsyncLoadFidget(CStateManager& mgr) | ||||
| { | ||||
|     SetFidgetAnimBits(x3a4_fidget.GetParm2(), x3a4_fidget.GetState() == CFidget::EState::Three); | ||||
|     if ((x2fc_fidgetAnimBits & 0x1) == 0x1) | ||||
|         x73c_gunMotion->GunController().LoadFidgetAnimAsync(mgr, s32(x3a4_fidget.GetType()), | ||||
|                                                             x310_selectedBeam, x3a4_fidget.GetParm2()); | ||||
|     if ((x2fc_fidgetAnimBits & 0x2) == 0x2) | ||||
|     { | ||||
|         x72c_currentBeam->AsyncLoadFidget(mgr, (x3a4_fidget.GetState() == CFidget::EState::Three ? | ||||
|             SamusGun::EFidgetType::Zero : x3a4_fidget.GetType()), x3a4_fidget.GetParm2()); | ||||
|         x832_31_ = false; | ||||
|     } | ||||
|     if ((x2fc_fidgetAnimBits & 0x4) == 0x4) | ||||
|         if (CGunController* gc = x740_grappleArm->GunController()) | ||||
|             gc->LoadFidgetAnimAsync(mgr, s32(x3a4_fidget.GetType()), | ||||
|                                     x3a4_fidget.GetType() != SamusGun::EFidgetType::Zero ? x310_selectedBeam : 0, | ||||
|                                     x3a4_fidget.GetParm2()); | ||||
| } | ||||
| 
 | ||||
| bool CPlayerGun::IsFidgetLoaded() const | ||||
| { | ||||
|     int loadFlags = 0; | ||||
|     if ((x2fc_fidgetAnimBits & 0x1) == 0x1 && x73c_gunMotion->GunController().IsFidgetLoaded()) | ||||
|         loadFlags |= 0x1; | ||||
|     if ((x2fc_fidgetAnimBits & 0x2) == 0x2 && x72c_currentBeam->IsFidgetLoaded()) | ||||
|         loadFlags |= 0x2; | ||||
|     if ((x2fc_fidgetAnimBits & 0x4) == 0x4) | ||||
|         if (CGunController* gc = x740_grappleArm->GunController()) | ||||
|             if (gc->IsFidgetLoaded()) | ||||
|                 loadFlags |= 0x4; | ||||
|     return x2fc_fidgetAnimBits == loadFlags; | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::EnterFidget(CStateManager& mgr) | ||||
| { | ||||
|     if ((x2fc_fidgetAnimBits & 0x1) == 0x1) | ||||
|     { | ||||
|         x73c_gunMotion->EnterFidget(mgr, x3a4_fidget.GetType(), x3a4_fidget.GetParm2()); | ||||
|         x834_25_ = true; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         x834_25_ = false; | ||||
|     } | ||||
| 
 | ||||
|     if ((x2fc_fidgetAnimBits & 0x2) == 0x2) | ||||
|         x72c_currentBeam->EnterFidget(mgr, x3a4_fidget.GetType(), x3a4_fidget.GetParm2()); | ||||
| 
 | ||||
|     if ((x2fc_fidgetAnimBits & 0x4) == 0x4) | ||||
|         x740_grappleArm->EnterFidget(mgr, x3a4_fidget.GetType(), | ||||
|                                      x3a4_fidget.GetType() != SamusGun::EFidgetType::Zero ? x310_selectedBeam : 0, | ||||
|                                      x3a4_fidget.GetParm2()); | ||||
| 
 | ||||
|     UnLoadFidget(); | ||||
|     x3a4_fidget.DoneLoading(); | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::UpdateGunIdle(bool b1, float camBobT, float dt, CStateManager& mgr) | ||||
| { | ||||
|     CPlayer& player = mgr.GetPlayer(); | ||||
|     if (player.IsInFreeLook() && !x832_29_ && !x740_grappleArm->IsGrappling() && | ||||
|         x3a4_fidget.GetState() != CFidget::EState::Three && | ||||
|         player.GetGunHolsterState() == CPlayer::EGunHolsterState::Drawn && !x834_30_inBigStrike) | ||||
|     { | ||||
|         if ((x2f8_ & 0x8) != 0x8) | ||||
|         { | ||||
|             if (!x833_31_ && !x834_26_) | ||||
|             { | ||||
|                 if (x388_ < 0.25f) | ||||
|                     x388_ += dt; | ||||
|                 if (x388_ >= 0.25f && !x740_grappleArm->IsSuitLoading()) | ||||
|                 { | ||||
|                     EnterFreeLook(mgr); | ||||
|                     x833_31_ = true; | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 x388_ = 0.f; | ||||
|                 if (x834_26_) | ||||
|                     ResetIdle(mgr); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         if (x833_31_) | ||||
|         { | ||||
|             if ((x2f8_ & 0x10) != 0x10) | ||||
|             { | ||||
|                 x73c_gunMotion->ReturnToDefault(mgr, x834_30_inBigStrike); | ||||
|                 x740_grappleArm->ReturnToDefault(mgr, 0.f, false); | ||||
|             } | ||||
|             x833_31_ = false; | ||||
|         } | ||||
|         x388_ = 0.f; | ||||
|         if (player.GetMorphballTransitionState() != CPlayer::EPlayerMorphBallState::Morphed) | ||||
|         { | ||||
|             x833_24_isFidgeting = (player.GetSurfaceRestraint() != CPlayer::ESurfaceRestraints::Water && | ||||
|                 mgr.GetPlayerState()->GetCurrentVisor() != CPlayerState::EPlayerVisor::Scan && | ||||
|                 (x2f4_fireButtonStates & 0x3) == 0 && x32c_ == 0 && !x832_29_ && (x2f8_ & 0x8) != 0x8 && | ||||
|                 x364_ <= 0.f && player.GetPlayerMovementState() == CPlayer::EPlayerMovementState::OnGround && | ||||
|                 !player.IsInFreeLook() && !player.GetFreeLookStickState() && x304_ == 0 && | ||||
|                 std::fabs(player.GetAngularVelocityOR().angle()) <= 0.1f && camBobT <= 0.01f && | ||||
|                 !mgr.GetCameraManager()->IsInCinematicCamera() && | ||||
|                 player.GetGunHolsterState() == CPlayer::EGunHolsterState::Drawn && | ||||
|                 player.GetGrappleState() == CPlayer::EGrappleState::None && !x834_30_inBigStrike && | ||||
|                 !x835_25_inPhazonBeam); | ||||
|             if (x833_24_isFidgeting) | ||||
|             { | ||||
|                 if (!x834_30_inBigStrike) | ||||
|                 { | ||||
|                     bool r19 = camBobT > 0.01f && (x2f4_fireButtonStates & 0x3) == 0; | ||||
|                     if (r19) | ||||
|                     { | ||||
|                         x370_gunMotionSpeedMult = 1.f; | ||||
|                         x374_ = 0.f; | ||||
|                         if (x364_ <= 0.f && x368_ <= 0.f) | ||||
|                         { | ||||
|                             x368_ = 8.f; | ||||
|                             x73c_gunMotion->PlayPasAnim(SamusGun::EAnimationState::Wander, mgr, 0.f, false); | ||||
|                             x324_ = 1; | ||||
|                             x550_camBob.SetState(CPlayerCameraBob::ECameraBobState::Walk, mgr); | ||||
|                         } | ||||
|                         x368_ -= dt; | ||||
|                         x360_ -= dt; | ||||
|                     } | ||||
|                     if (!r19 || x834_26_) | ||||
|                         ResetIdle(mgr); | ||||
|                 } | ||||
|                 if (x394_damageTimer > 0.f) | ||||
|                 { | ||||
|                     x394_damageTimer -= dt; | ||||
|                 } | ||||
|                 else if (!x834_31_) | ||||
|                 { | ||||
|                     x394_damageTimer = 0.f; | ||||
|                     x834_31_ = true; | ||||
|                     x73c_gunMotion->BasePosition(true); | ||||
|                 } | ||||
|                 else if (!x73c_gunMotion->GetModelData().GetAnimationData()->IsAnimTimeRemaining(0.001f, "Whole Body")) | ||||
|                 { | ||||
|                     x834_30_inBigStrike = false; | ||||
|                     x834_31_ = false; | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 switch (x3a4_fidget.Update(x2ec_lastFireButtonStates, camBobT > 0.01f, b1, dt, mgr)) | ||||
|                 { | ||||
|                 case CFidget::EState::Zero: | ||||
|                     if (x324_ != 2) | ||||
|                     { | ||||
|                         x73c_gunMotion->PlayPasAnim(SamusGun::EAnimationState::Idle, mgr, 0.f, false); | ||||
|                         x324_ = 2; | ||||
|                     } | ||||
|                     x550_camBob.SetState(CPlayerCameraBob::ECameraBobState::WalkNoBob, mgr); | ||||
|                     break; | ||||
|                 case CFidget::EState::One: | ||||
|                 case CFidget::EState::Two: | ||||
|                 case CFidget::EState::Three: | ||||
|                     if (x324_ != 0) | ||||
|                     { | ||||
|                         x73c_gunMotion->BasePosition(false); | ||||
|                         x324_ = 0; | ||||
|                     } | ||||
|                     AsyncLoadFidget(mgr); | ||||
|                     break; | ||||
|                 case CFidget::EState::Seven: | ||||
|                     if (IsFidgetLoaded()) | ||||
|                         EnterFidget(mgr); | ||||
|                     break; | ||||
|                 case CFidget::EState::Four: | ||||
|                 case CFidget::EState::Five: | ||||
|                     x550_camBob.SetState(CPlayerCameraBob::ECameraBobState::Walk, mgr); | ||||
|                     x833_24_isFidgeting = false; | ||||
|                     x834_26_ = x834_25_ ? x73c_gunMotion->IsAnimPlaying() : | ||||
|                     x72c_currentBeam->GetSolidModelData().GetAnimationData()->IsAnimTimeRemaining(0.001f, "Whole Body"); | ||||
|                     if (!x834_26_) | ||||
|                     { | ||||
|                         x3a4_fidget.ResetMinor(); | ||||
|                         ReturnToRestPose(); | ||||
|                     } | ||||
|                     break; | ||||
|                 default: | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|             x550_camBob.Update(dt, mgr); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static const float chargeShakeTbl[] = { -0.001f, 0.f, 0.001f }; | ||||
| static const CMaterialFilter sAimFilter = | ||||
|     CMaterialFilter::MakeIncludeExclude({EMaterialTypes::Solid}, {EMaterialTypes::ProjectilePassthrough}); | ||||
| @ -943,8 +1401,8 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM | ||||
| 
 | ||||
|     if (becameFrozen || becameThawed) | ||||
|     { | ||||
|         x2f4_ = 0; | ||||
|         x2ec_firing = 0; | ||||
|         x2f4_fireButtonStates = 0; | ||||
|         x2ec_lastFireButtonStates = 0; | ||||
|         CancelFiring(mgr); | ||||
|     } | ||||
| 
 | ||||
| @ -1057,7 +1515,8 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM | ||||
|     if (x740_grappleArm->GetActive() && !x740_grappleArm->IsGrappling()) | ||||
|         UpdateLeftArmTransform(x72c_currentBeam->GetSolidModelData(), mgr); | ||||
| 
 | ||||
|     x6a0_motionState.Update(x2f0_ != 0 && x832_28_ && x32c_ < 2 && !player.IsInFreeLook(), advDt, x4a8_gunWorldXf, mgr); | ||||
|     x6a0_motionState.Update(x2f0_pressedFireButtonStates != 0 && x832_28_ && x32c_ < 2 && | ||||
|                                 !player.IsInFreeLook(), advDt, x4a8_gunWorldXf, mgr); | ||||
| 
 | ||||
|     x72c_currentBeam->GetSolidModelData().AdvanceParticles(x4a8_gunWorldXf, advDt, mgr); | ||||
|     x72c_currentBeam->UpdateGunFx(x380_ > 2.f && x378_ > 0.15f, dt, mgr, x508_elbowLocalXf); | ||||
| @ -1159,7 +1618,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM | ||||
|     UpdateWeaponFire(advDt, playerState, mgr); | ||||
|     UpdateGunIdle(x364_ > 0.f, cameraBobT, advDt, mgr); | ||||
| 
 | ||||
|     if ((x2ec_firing & 0x1) == 0x1) | ||||
|     if ((x2ec_lastFireButtonStates & 0x1) == 0x1) | ||||
|     { | ||||
|         x378_ = 0.f; | ||||
|     } | ||||
| @ -1184,7 +1643,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM | ||||
| 
 | ||||
|     if (x364_ > 0.f) | ||||
|     { | ||||
|         x2f4_ = 0; | ||||
|         x2f4_fireButtonStates = 0; | ||||
|         x364_ -= advDt; | ||||
|     } | ||||
| 
 | ||||
| @ -1214,6 +1673,11 @@ void CPlayerGun::AddToRenderer(const zeus::CFrustum& frustum, const CStateManage | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void CPlayerGun::DropBomb(EBWeapon weapon, CStateManager& mgr) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| TUniqueId CPlayerGun::DropPowerBomb(CStateManager& mgr) | ||||
| { | ||||
|     return {}; | ||||
|  | ||||
| @ -35,7 +35,8 @@ public: | ||||
|     }; | ||||
|     enum class EBWeapon | ||||
|     { | ||||
| 
 | ||||
|         Zero, | ||||
|         One | ||||
|     }; | ||||
|     enum class EGunOverrideMode | ||||
|     { | ||||
| @ -113,11 +114,12 @@ private: | ||||
|     CSfxHandle x2e0_chargeSfx; | ||||
|     CSfxHandle x2e4_invalidSfx; | ||||
|     u32 x2e8_ = 0; | ||||
|     u32 x2ec_firing = 0; | ||||
|     u32 x2f0_ = 0; | ||||
|     u32 x2f4_ = 0; | ||||
|     // 0x1: FireOrBomb, 0x2: MissileOrPowerBomb
 | ||||
|     u32 x2ec_lastFireButtonStates = 0; | ||||
|     u32 x2f0_pressedFireButtonStates = 0; | ||||
|     u32 x2f4_fireButtonStates = 0; | ||||
|     u32 x2f8_ = 1; | ||||
|     u32 x2fc_ = 0; | ||||
|     u32 x2fc_fidgetAnimBits = 0; | ||||
|     u32 x300_ = 0; | ||||
|     u32 x304_ = 0; | ||||
|     u32 x308_bombCount = 3; | ||||
| @ -130,7 +132,7 @@ private: | ||||
|     u32 x324_ = 4; | ||||
|     u32 x328_ = 0x2000; | ||||
|     u32 x32c_ = 0; | ||||
|     u32 x330_chargeWeaponIdx = 0; | ||||
|     EChargeState x330_chargeState = EChargeState::Normal; | ||||
|     u32 x334_ = 0; | ||||
|     u32 x338_ = 0; | ||||
|     EGunOverrideMode x33c_gunOverrideMode = EGunOverrideMode::Normal; | ||||
| @ -169,7 +171,7 @@ private: | ||||
|     zeus::CTransform x4d8_gunLocalXf; | ||||
|     zeus::CTransform x508_elbowLocalXf; | ||||
|     TUniqueId x538_playerId; | ||||
|     TUniqueId x53a_ = kInvalidUniqueId; | ||||
|     TUniqueId x53a_powerBomb = kInvalidUniqueId; | ||||
|     TUniqueId x53c_lightId = kInvalidUniqueId; | ||||
|     std::vector<CToken> x540_handAnimTokens; | ||||
|     CPlayerCameraBob x550_camBob; | ||||
| @ -281,7 +283,19 @@ private: | ||||
|     void DoUserAnimEvents(float dt, CStateManager& mgr); | ||||
|     TUniqueId GetTargetId(CStateManager& mgr) const; | ||||
|     void CancelLockOn(); | ||||
|     void FireSecondary(float dt, CStateManager& mgr); | ||||
|     void ResetCharged(float dt, CStateManager& mgr); | ||||
|     void ActivateCombo(CStateManager& mgr); | ||||
|     void ProcessChargeState(u32 releasedStates, u32 pressedStates, CStateManager& mgr, float dt); | ||||
|     void ResetNormal(CStateManager& mgr); | ||||
|     void UpdateNormalShotCycle(float dt, CStateManager& mgr); | ||||
|     void ProcessNormalState(u32 releasedStates, u32 pressedStates, CStateManager& mgr, float dt); | ||||
|     void UpdateWeaponFire(float dt, const CPlayerState& playerState, CStateManager& mgr); | ||||
|     void EnterFreeLook(CStateManager& mgr); | ||||
|     void SetFidgetAnimBits(int parm2, bool beamOnly); | ||||
|     void AsyncLoadFidget(CStateManager& mgr); | ||||
|     bool IsFidgetLoaded() const; | ||||
|     void EnterFidget(CStateManager& mgr); | ||||
|     void UpdateGunIdle(bool b1, float camBobT, float dt, CStateManager& mgr); | ||||
| 
 | ||||
| public: | ||||
| @ -318,7 +332,8 @@ public: | ||||
|     void PreRender(const CStateManager& mgr, const zeus::CFrustum& frustum, const zeus::CVector3f& camPos); | ||||
|     void Render(const CStateManager& mgr, const zeus::CVector3f& pos, const CModelFlags& flags) const; | ||||
|     void AddToRenderer(const zeus::CFrustum& frustum, const CStateManager& mgr) const; | ||||
|     bool GetFiring() const { return x2ec_firing != 0; } | ||||
|     u32 GetLastFireButtonStates() const { return x2ec_lastFireButtonStates; } | ||||
|     void DropBomb(EBWeapon weapon, CStateManager& mgr); | ||||
|     TUniqueId DropPowerBomb(CStateManager& mgr); | ||||
|     void SetActorAttached(bool b) { x835_31_actorAttached = b; } | ||||
| }; | ||||
|  | ||||
| @ -0,0 +1,18 @@ | ||||
| #include "CPowerBomb.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| CPowerBomb::CPowerBomb(const TToken<CGenDescription>& particle, TUniqueId uid, TAreaId aid, | ||||
|                        TUniqueId playerId, const zeus::CTransform& xf, const CDamageInfo& dInfo) | ||||
| : CWeapon(uid, aid, true, playerId, EWeaponType::PowerBomb, "PowerBomb", xf, | ||||
|           CMaterialFilter::MakeIncludeExclude({EMaterialTypes::Solid, EMaterialTypes::Immovable, | ||||
|                                                EMaterialTypes::Trigger}, | ||||
|                                               {EMaterialTypes::Projectile, EMaterialTypes::PowerBomb}), | ||||
|           {EMaterialTypes::Projectile, EMaterialTypes::PowerBomb}, dInfo, EProjectileAttrib::PowerBombs, | ||||
|           CModelData::CModelDataNull()) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| } | ||||
| @ -0,0 +1,22 @@ | ||||
| #ifndef __URDE_CPOWERBOMB_HPP__ | ||||
| #define __URDE_CPOWERBOMB_HPP__ | ||||
| 
 | ||||
| #include "CWeapon.hpp" | ||||
| #include "CToken.hpp" | ||||
| 
 | ||||
| namespace urde | ||||
| { | ||||
| 
 | ||||
| class CPowerBomb : public CWeapon | ||||
| { | ||||
|     float x15c_curTime = 0.f; | ||||
|     float x160_ = 0.f; | ||||
| public: | ||||
|     CPowerBomb(const TToken<CGenDescription>& particle, TUniqueId uid, TAreaId aid, | ||||
|                TUniqueId playerId, const zeus::CTransform& xf, const CDamageInfo& dInfo); | ||||
|     float GetCurTime() const { return x15c_curTime; } | ||||
| }; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #endif // __URDE_CPOWERBOMB_HPP__
 | ||||
| @ -17,6 +17,7 @@ namespace urde | ||||
| 
 | ||||
| enum class EListenNoiseType | ||||
| { | ||||
|     Zero | ||||
| }; | ||||
| 
 | ||||
| enum class EKnockBackType | ||||
|  | ||||
| @ -666,7 +666,7 @@ float CPlayer::UpdateCameraBob(float dt, CStateManager& mgr) | ||||
|     } | ||||
|     else if (bobMag < 0.01f) | ||||
|     { | ||||
|         if (x490_gun->GetFiring()) | ||||
|         if (x490_gun->GetLastFireButtonStates() != 0) | ||||
|         { | ||||
|             bobMag = 0.f; | ||||
|             state = CPlayerCameraBob::ECameraBobState::GunFireNoBob; | ||||
|  | ||||
| @ -532,6 +532,8 @@ public: | ||||
|     void HolsterGun(CStateManager& mgr); | ||||
|     EPlayerCameraState GetCameraState() const { return x2f4_cameraState; } | ||||
|     EPlayerMorphBallState GetMorphballTransitionState() const { return x2f8_morphBallState; } | ||||
|     EGunHolsterState GetGunHolsterState() const { return x498_gunHolsterState; } | ||||
|     EPlayerMovementState GetPlayerMovementState() const { return x258_movementState; } | ||||
|     bool IsMorphBallTransitioning() const; | ||||
|     void UpdateGrappleArmTransform(const zeus::CVector3f&, CStateManager& mgr, float); | ||||
|     float GetGravity() const; | ||||
| @ -643,7 +645,7 @@ public: | ||||
|     float GetMorphTime() const { return x574_morphTime; } | ||||
|     float GetMorphDuration() const { return x578_morphDuration; } | ||||
|     bool IsInFreeLook() const { return x3dc_inFreeLook; } | ||||
|     bool IsLookControlHeld() const { return x3de_lookAnalogHeld; } | ||||
|     bool GetFreeLookStickState() const { return x3de_lookAnalogHeld; } | ||||
|     CPlayerGun* GetPlayerGun() const { return x490_gun.get(); } | ||||
|     CMorphBall* GetMorphBall() const { return x768_morphball.get(); } | ||||
|     CPlayerCameraBob* GetCameraBob() const { return x76c_cameraBob.get(); } | ||||
|  | ||||
| @ -394,8 +394,7 @@ void CWorldTransManager::EnableTransition(const CAnimRes& samusRes, | ||||
|     x8_textData.reset(); | ||||
|     x20_random.SetSeed(99); | ||||
| 
 | ||||
|     CAssetId beamModelId = g_tweakPlayerRes->GetBeamCineModel( | ||||
|         DataSpec::ITweakPlayerRes::EBeamId(g_GameState->GetPlayerState()->GetCurrentBeam())); | ||||
|     CAssetId beamModelId = g_tweakPlayerRes->GetBeamCineModel(g_GameState->GetPlayerState()->GetCurrentBeam()); | ||||
| 
 | ||||
|     x4_modelData->x14c_beamModel = g_SimplePool->GetObj(SObjectTag{FOURCC('CMDL'), beamModelId}); | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user