mirror of https://github.com/AxioDL/metaforce.git
Merge branch 'master' of https://github.com/AxioDL/urde
This commit is contained in:
commit
5cb420a703
|
@ -9,6 +9,7 @@ set(MP1_SOURCES
|
||||||
CNewIntroBoss.hpp CNewIntroBoss.cpp
|
CNewIntroBoss.hpp CNewIntroBoss.cpp
|
||||||
CBeetle.hpp CBeetle.cpp
|
CBeetle.hpp CBeetle.cpp
|
||||||
CWarWasp.hpp CWarWasp.cpp
|
CWarWasp.hpp CWarWasp.cpp
|
||||||
|
CSpacePirate.hpp CSpacePirate.cpp
|
||||||
MP1.hpp MP1.cpp)
|
MP1.hpp MP1.cpp)
|
||||||
|
|
||||||
runtime_add_list(MP1 MP1_SOURCES)
|
runtime_add_list(MP1 MP1_SOURCES)
|
||||||
|
|
|
@ -23,6 +23,7 @@ public:
|
||||||
u32 GetACSFile() const { return x0_ancs; }
|
u32 GetACSFile() const { return x0_ancs; }
|
||||||
u32 GetCharacter() const { return x4_charIdx; }
|
u32 GetCharacter() const { return x4_charIdx; }
|
||||||
u32 GetInitialAnimation() const { return x8_defaultAnim; }
|
u32 GetInitialAnimation() const { return x8_defaultAnim; }
|
||||||
|
void SetCharacter(u32 charIdx) { x4_charIdx = charIdx; }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,8 +19,10 @@ class CPatterned : public CAi
|
||||||
public:
|
public:
|
||||||
enum class EUnknown
|
enum class EUnknown
|
||||||
{
|
{
|
||||||
|
Zero = 0,
|
||||||
Three = 3,
|
Three = 3,
|
||||||
TwentyThree = 23,
|
TwentyThree = 23,
|
||||||
|
ThirtyFour = 34,
|
||||||
ThirtyNine
|
ThirtyNine
|
||||||
};
|
};
|
||||||
enum class EFlavorType
|
enum class EFlavorType
|
||||||
|
|
|
@ -60,6 +60,7 @@ public:
|
||||||
CPatternedInfo(CInputStream& in, u32 pcount);
|
CPatternedInfo(CInputStream& in, u32 pcount);
|
||||||
static std::pair<bool, u32> HasCorrectParameterCount(CInputStream& in);
|
static std::pair<bool, u32> HasCorrectParameterCount(CInputStream& in);
|
||||||
|
|
||||||
|
CAnimationParameters& GetAnimationParameters() { return xec_animParams; }
|
||||||
const CAnimationParameters& GetAnimationParameters() const {return xec_animParams;}
|
const CAnimationParameters& GetAnimationParameters() const {return xec_animParams;}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -45,6 +45,7 @@
|
||||||
#include "MP1/CNewIntroBoss.hpp"
|
#include "MP1/CNewIntroBoss.hpp"
|
||||||
#include "MP1/CBeetle.hpp"
|
#include "MP1/CBeetle.hpp"
|
||||||
#include "MP1/CWarWasp.hpp"
|
#include "MP1/CWarWasp.hpp"
|
||||||
|
#include "MP1/CSpacePirate.hpp"
|
||||||
#include "CPatternedInfo.hpp"
|
#include "CPatternedInfo.hpp"
|
||||||
#include "CSimplePool.hpp"
|
#include "CSimplePool.hpp"
|
||||||
#include "Collision/CCollidableOBBTreeGroup.hpp"
|
#include "Collision/CCollidableOBBTreeGroup.hpp"
|
||||||
|
@ -1321,7 +1322,29 @@ CEntity* ScriptLoader::LoadWarWasp(CStateManager& mgr, CInputStream& in,
|
||||||
CEntity* ScriptLoader::LoadSpacePirate(CStateManager& mgr, CInputStream& in,
|
CEntity* ScriptLoader::LoadSpacePirate(CStateManager& mgr, CInputStream& in,
|
||||||
int propCount, const CEntityInfo& info)
|
int propCount, const CEntityInfo& info)
|
||||||
{
|
{
|
||||||
|
if (!EnsurePropertyCount(propCount, 34, "SpacePirate"))
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
SScaledActorHead head = LoadScaledActorHead(in, mgr);
|
||||||
|
std::pair<bool, u32> verifyPair = CPatternedInfo::HasCorrectParameterCount(in);
|
||||||
|
if (!verifyPair.first)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
CPatternedInfo pInfo(in, verifyPair.second);
|
||||||
|
CActorParameters aParams = LoadActorParameters(in);
|
||||||
|
CAnimationParameters& animParms = pInfo.GetAnimationParameters();
|
||||||
|
|
||||||
|
if (g_ResFactory->GetResourceTypeById(animParms.GetACSFile()) != SBIG('ANCS'))
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
if (animParms.GetCharacter() == 0)
|
||||||
|
{
|
||||||
|
Log.report(logvisor::Warning, "SpacePirate <%s> has AnimationInformation property with invalid character selected", head.x0_name.c_str());
|
||||||
|
animParms.SetCharacter(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
CModelData mData(CAnimRes(animParms.GetACSFile(), animParms.GetCharacter(), head.x40_scale, animParms.GetInitialAnimation(), true));
|
||||||
|
|
||||||
|
return new MP1::CSpacePirate(mgr.AllocateUniqueId(), head.x0_name, info, head.x10_transform, std::move(mData), aParams, pInfo, in, propCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
CEntity* ScriptLoader::LoadFlyingPirate(CStateManager& mgr, CInputStream& in,
|
CEntity* ScriptLoader::LoadFlyingPirate(CStateManager& mgr, CInputStream& in,
|
||||||
|
|
Loading…
Reference in New Issue