mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 21:30:25 +00:00 
			
		
		
		
	Allows using container sizes and capacities without needing to cast them, allowing for dehardcoding of array sizes in some scenarios.
		
			
				
	
	
		
			114 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "Runtime/Character/CSequenceHelper.hpp"
 | |
| 
 | |
| #include <array>
 | |
| 
 | |
| #include "Runtime/Character/CAnimSysContext.hpp"
 | |
| #include "Runtime/Character/CBoolPOINode.hpp"
 | |
| #include "Runtime/Character/CInt32POINode.hpp"
 | |
| #include "Runtime/Character/CParticlePOINode.hpp"
 | |
| #include "Runtime/Character/CSoundPOINode.hpp"
 | |
| #include "Runtime/Character/CTreeUtils.hpp"
 | |
| #include "Runtime/Character/IMetaAnim.hpp"
 | |
| 
 | |
| namespace urde {
 | |
| 
 | |
| CSequenceFundamentals::CSequenceFundamentals(const CSteadyStateAnimInfo& ssInfo, std::vector<CBoolPOINode> boolNodes,
 | |
|                                              std::vector<CInt32POINode> int32Nodes,
 | |
|                                              std::vector<CParticlePOINode> particleNodes,
 | |
|                                              std::vector<CSoundPOINode> soundNodes)
 | |
| : x0_ssInfo(ssInfo)
 | |
| , x18_boolNodes(std::move(boolNodes))
 | |
| , x28_int32Nodes(std::move(int32Nodes))
 | |
| , x38_particleNodes(std::move(particleNodes))
 | |
| , x48_soundNodes(std::move(soundNodes)) {}
 | |
| 
 | |
| CSequenceHelper::CSequenceHelper(const std::shared_ptr<CAnimTreeNode>& a, const std::shared_ptr<CAnimTreeNode>& b,
 | |
|                                  CAnimSysContext animCtx)
 | |
| : x0_animCtx(std::move(animCtx)) {
 | |
|   x10_treeNodes.reserve(2);
 | |
|   x10_treeNodes.push_back(a);
 | |
|   x10_treeNodes.push_back(b);
 | |
| }
 | |
| 
 | |
| CSequenceHelper::CSequenceHelper(const std::vector<std::shared_ptr<IMetaAnim>>& nodes, CAnimSysContext animCtx)
 | |
| : x0_animCtx(std::move(animCtx)) {
 | |
|   x10_treeNodes.reserve(nodes.size());
 | |
|   for (const std::shared_ptr<IMetaAnim>& meta : nodes)
 | |
|     x10_treeNodes.push_back(meta->GetAnimationTree(x0_animCtx, CMetaAnimTreeBuildOrders::NoSpecialOrders()));
 | |
| }
 | |
| 
 | |
| CSequenceFundamentals CSequenceHelper::ComputeSequenceFundamentals() {
 | |
|   CCharAnimTime duration;
 | |
|   zeus::CVector3f offset;
 | |
|   std::vector<CBoolPOINode> boolNodes;
 | |
|   std::vector<CInt32POINode> int32Nodes;
 | |
|   std::vector<CParticlePOINode> particleNodes;
 | |
|   std::vector<CSoundPOINode> soundNodes;
 | |
|   if (x10_treeNodes.size() > 0) {
 | |
|     std::shared_ptr<CAnimTreeNode> node = CAnimTreeNode::Cast(x10_treeNodes[0]->Clone());
 | |
|     for (size_t i = 0; i < x10_treeNodes.size(); ++i) {
 | |
|       std::array<CBoolPOINode, 64> boolNodeArr;
 | |
|       const size_t numBools =
 | |
|           node->GetBoolPOIList(CCharAnimTime::Infinity(), boolNodeArr.data(), boolNodeArr.size(), 0, 0);
 | |
|       boolNodes.reserve(boolNodes.size() + numBools);
 | |
|       for (size_t j = 0; j < numBools; ++j) {
 | |
|         CBoolPOINode& n = boolNodeArr[j];
 | |
|         n.SetTime(n.GetTime() + duration);
 | |
|         boolNodes.push_back(n);
 | |
|       }
 | |
| 
 | |
|       std::array<CInt32POINode, 64> int32NodeArr;
 | |
|       const size_t numInt32s =
 | |
|           node->GetInt32POIList(CCharAnimTime::Infinity(), int32NodeArr.data(), int32NodeArr.size(), 0, 0);
 | |
|       int32Nodes.reserve(int32Nodes.size() + numInt32s);
 | |
|       for (size_t j = 0; j < numInt32s; ++j) {
 | |
|         CInt32POINode& n = int32NodeArr[j];
 | |
|         n.SetTime(n.GetTime() + duration);
 | |
|         int32Nodes.push_back(n);
 | |
|       }
 | |
| 
 | |
|       std::array<CParticlePOINode, 64> particleNodeArr;
 | |
|       const size_t numParticles =
 | |
|           node->GetParticlePOIList(CCharAnimTime::Infinity(), particleNodeArr.data(), particleNodeArr.size(), 0, 0);
 | |
|       particleNodes.reserve(particleNodes.size() + numParticles);
 | |
|       for (size_t j = 0; j < numParticles; ++j) {
 | |
|         CParticlePOINode& n = particleNodeArr[j];
 | |
|         n.SetTime(n.GetTime() + duration);
 | |
|         particleNodes.push_back(n);
 | |
|       }
 | |
| 
 | |
|       std::array<CSoundPOINode, 64> soundNodeArr;
 | |
|       const size_t numSounds =
 | |
|           node->GetSoundPOIList(CCharAnimTime::Infinity(), soundNodeArr.data(), soundNodeArr.size(), 0, 0);
 | |
|       soundNodes.reserve(soundNodes.size() + numSounds);
 | |
|       for (size_t j = 0; j < numSounds; ++j) {
 | |
|         CSoundPOINode& n = soundNodeArr[j];
 | |
|         n.SetTime(n.GetTime() + duration);
 | |
|         soundNodes.push_back(n);
 | |
|       }
 | |
| 
 | |
|       duration += node->VGetTimeRemaining();
 | |
| 
 | |
|       CCharAnimTime remTime = node->VGetTimeRemaining();
 | |
|       while (!remTime.EqualsZero() && !remTime.EpsilonZero()) {
 | |
|         SAdvancementResults res = node->VAdvanceView(remTime);
 | |
|         auto simp = node->Simplified();
 | |
|         if (simp)
 | |
|           node = CAnimTreeNode::Cast(std::move(*simp));
 | |
|         // CCharAnimTime prevRemTime = remTime;
 | |
|         remTime = res.x0_remTime;
 | |
|         /* This was originally accumulating uninitialized register values (stack variable misuse?) */
 | |
|         offset += res.x8_deltas.x0_posDelta;
 | |
|       }
 | |
| 
 | |
|       if (i < x10_treeNodes.size() - 1) {
 | |
|         node = CTreeUtils::GetTransitionTree(node, CAnimTreeNode::Cast(x10_treeNodes[i + 1]->Clone()), x0_animCtx);
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   return {{false, duration, offset}, boolNodes, int32Nodes, particleNodes, soundNodes};
 | |
| }
 | |
| 
 | |
| } // namespace urde
 |