mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-24 22:50:24 +00:00 
			
		
		
		
	
						commit
						02af2c32c0
					
				| @ -203,8 +203,7 @@ void CMetroidPrimeEssence::DoUserAnimEvent(CStateManager& mgr, const CInt32POINo | |||||||
|   } |   } | ||||||
|   case EUserEventType::BeginAction: { |   case EUserEventType::BeginAction: { | ||||||
|     SShockWaveData data(x660_, x698_, 2.f, x664_, x70c_); |     SShockWaveData data(x660_, x698_, 2.f, x664_, x70c_); | ||||||
|     // TODO: Need to fix CElementGen accessing null ParticleAccessParameters
 |     data.SetSpeedIncrease(180.f); | ||||||
|     // data.SetSpeedIncrease(180.f);
 |  | ||||||
|     DropShockwave(mgr, data); |     DropShockwave(mgr, data); | ||||||
|     ShakeCamera(mgr, 1.f); |     ShakeCamera(mgr, 1.f); | ||||||
|     return; |     return; | ||||||
|  | |||||||
| @ -83,7 +83,6 @@ CElementGen::CElementGen(TToken<CGenDescription> gen, EModelOrientationType orie | |||||||
| 
 | 
 | ||||||
|   if (CIntElement* mbspElem = desc->x48_x34_MBSP.get()) |   if (CIntElement* mbspElem = desc->x48_x34_MBSP.get()) | ||||||
|     mbspElem->GetValue(x74_curFrame, x270_MBSP); |     mbspElem->GetValue(x74_curFrame, x270_MBSP); | ||||||
|   m_maxMBSP = x270_MBSP; |  | ||||||
| 
 | 
 | ||||||
|   if (CModVectorElement* elem = desc->x7c_x68_VEL1.get()) { |   if (CModVectorElement* elem = desc->x7c_x68_VEL1.get()) { | ||||||
|     x280_VELSources[0] = elem; |     x280_VELSources[0] = elem; | ||||||
| @ -152,13 +151,15 @@ CElementGen::CElementGen(TToken<CGenDescription> gen, EModelOrientationType orie | |||||||
| 
 | 
 | ||||||
|   if (CIntElement* maxpElem = desc->x28_x1c_MAXP.get()) { |   if (CIntElement* maxpElem = desc->x28_x1c_MAXP.get()) { | ||||||
|     maxpElem->GetValue(x74_curFrame, x90_MAXP); |     maxpElem->GetValue(x74_curFrame, x90_MAXP); | ||||||
|     m_maxMAXP = maxpElem->GetMaxValue(); |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   m_maxMAXP = std::min(m_maxMAXP, 256); |   s32 count = std::min(256, x90_MAXP); | ||||||
|   x30_particles.reserve(m_maxMAXP); |   x30_particles.reserve(count); | ||||||
|  |   if (x26d_28_enableADV) { | ||||||
|  |     x60_advValues.resize(count); | ||||||
|  |   } | ||||||
|   if (x2c_orientType == EModelOrientationType::One) |   if (x2c_orientType == EModelOrientationType::One) | ||||||
|     x50_parentMatrices.resize(m_maxMAXP); |     x50_parentMatrices.resize(x90_MAXP); | ||||||
| 
 | 
 | ||||||
|   x26c_31_LINE = desc->x44_24_x30_24_LINE; |   x26c_31_LINE = desc->x44_24_x30_24_LINE; | ||||||
|   x26d_24_FXLL = desc->x44_25_x30_25_FXLL; |   x26d_24_FXLL = desc->x44_25_x30_25_FXLL; | ||||||
| @ -205,14 +206,14 @@ CElementGen::CElementGen(TToken<CGenDescription> gen, EModelOrientationType orie | |||||||
|     boo::ObjToken<boo::ITexture> tex; |     boo::ObjToken<boo::ITexture> tex; | ||||||
|     if (texr) |     if (texr) | ||||||
|       tex = texr->GetValueTexture(0).GetObj()->GetBooTexture(); |       tex = texr->GetValueTexture(0).GetObj()->GetBooTexture(); | ||||||
|     int maxVerts = (m_maxMAXP == 0 ? 256 : m_maxMAXP); |     int maxVerts = x90_MAXP; | ||||||
|     m_lineRenderer.reset( |     m_lineRenderer.reset( | ||||||
|         new CLineRenderer(CLineRenderer::EPrimitiveMode::Lines, maxVerts * 2, tex, x26c_26_AAPH, x26c_28_zTest)); |         new CLineRenderer(CLineRenderer::EPrimitiveMode::Lines, maxVerts * 2, tex, x26c_26_AAPH, x26c_28_zTest)); | ||||||
|   } else { |   } else { | ||||||
|     m_shaderClass = CElementGenShaders::GetShaderClass(*this); |     m_shaderClass = CElementGenShaders::GetShaderClass(*this); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   size_t maxInsts = x26c_30_MBLR ? (m_maxMBSP * m_maxMAXP) : m_maxMAXP; |   size_t maxInsts = x26c_30_MBLR ? (x270_MBSP * x90_MAXP) : x90_MAXP; | ||||||
|   maxInsts = (maxInsts == 0 ? 256 : maxInsts); |   maxInsts = (maxInsts == 0 ? 256 : maxInsts); | ||||||
| 
 | 
 | ||||||
|   CGraphics::CommitResources([&](boo::IGraphicsDataFactory::Context& ctx) { |   CGraphics::CommitResources([&](boo::IGraphicsDataFactory::Context& ctx) { | ||||||
| @ -274,7 +275,6 @@ bool CElementGen::InternalUpdate(double dt) { | |||||||
|   if (x26c_30_MBLR && dt > 0.0) { |   if (x26c_30_MBLR && dt > 0.0) { | ||||||
|     if (CIntElement* mbspElem = desc->x48_x34_MBSP.get()) |     if (CIntElement* mbspElem = desc->x48_x34_MBSP.get()) | ||||||
|       mbspElem->GetValue(x74_curFrame, x270_MBSP); |       mbspElem->GetValue(x74_curFrame, x270_MBSP); | ||||||
|     x270_MBSP = std::min(x270_MBSP, m_maxMBSP); |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   int frameUpdateCount = 0; |   int frameUpdateCount = 0; | ||||||
| @ -343,12 +343,7 @@ void CElementGen::AccumulateBounds(const zeus::CVector3f& pos, float size) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CElementGen::UpdateAdvanceAccessParameters(u32 activeParticleCount, s32 particleFrame) { | void CElementGen::UpdateAdvanceAccessParameters(u32 activeParticleCount, s32 particleFrame) { | ||||||
|   if (activeParticleCount >= x60_advValues.size()) { |   CGenDescription* desc = x28_loadedGenDesc; | ||||||
|     CParticleGlobals::instance()->m_particleAccessParameters = nullptr; |  | ||||||
|     return; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   CGenDescription* desc = x1c_genDesc.GetObj(); |  | ||||||
| 
 | 
 | ||||||
|   std::array<float, 8>& arr = x60_advValues[activeParticleCount]; |   std::array<float, 8>& arr = x60_advValues[activeParticleCount]; | ||||||
|   CParticleGlobals::instance()->m_particleAccessParameters = &arr; |   CParticleGlobals::instance()->m_particleAccessParameters = &arr; | ||||||
| @ -404,10 +399,7 @@ void CElementGen::UpdateExistingParticles() { | |||||||
| 
 | 
 | ||||||
|   x25c_activeParticleCount = 0; |   x25c_activeParticleCount = 0; | ||||||
|   CParticleGlobals::instance()->SetEmitterTime(x74_curFrame); |   CParticleGlobals::instance()->SetEmitterTime(x74_curFrame); | ||||||
|   if (x25c_activeParticleCount < x60_advValues.size()) |   CParticleGlobals::instance()->m_particleAccessParameters = nullptr; | ||||||
|     CParticleGlobals::instance()->m_particleAccessParameters = &x60_advValues[x25c_activeParticleCount]; |  | ||||||
|   else |  | ||||||
|     CParticleGlobals::instance()->m_particleAccessParameters = nullptr; |  | ||||||
| 
 | 
 | ||||||
|   for (auto it = x30_particles.begin(); it != x30_particles.end();) { |   for (auto it = x30_particles.begin(); it != x30_particles.end();) { | ||||||
|     CParticle& particle = *it; |     CParticle& particle = *it; | ||||||
| @ -484,27 +476,34 @@ void CElementGen::UpdateExistingParticles() { | |||||||
| void CElementGen::CreateNewParticles(int count) { | void CElementGen::CreateNewParticles(int count) { | ||||||
|   CGenDescription* desc = x1c_genDesc.GetObj(); |   CGenDescription* desc = x1c_genDesc.GetObj(); | ||||||
| 
 | 
 | ||||||
|   if (!g_ParticleSystemInitialized) |   if (!g_ParticleSystemInitialized) { | ||||||
|     Initialize(); |     Initialize(); | ||||||
|   if (!count || x30_particles.size() >= x90_MAXP) |   } | ||||||
|     return; |  | ||||||
| 
 | 
 | ||||||
|   if (count + x30_particles.size() > x90_MAXP) |   if (x30_particles.size() >= x90_MAXP) { | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   if (count + x30_particles.size() > x90_MAXP) { | ||||||
|     count = x90_MAXP - x30_particles.size(); |     count = x90_MAXP - x30_particles.size(); | ||||||
|   int newTotalCount = g_ParticleAliveCount + count; |   } | ||||||
|   if (newTotalCount > 2560) | 
 | ||||||
|  |   if (g_ParticleAliveCount + count > 2560) { | ||||||
|     count = 2560 - g_ParticleAliveCount; |     count = 2560 - g_ParticleAliveCount; | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   CGlobalRandom gr(x27c_randState); |   CGlobalRandom gr(x27c_randState); | ||||||
|   x30_particles.reserve(x90_MAXP); |   x30_particles.reserve(count + x90_MAXP); | ||||||
|   if (x26d_28_enableADV && x60_advValues.empty()) |   if (x26d_28_enableADV && x60_advValues.capacity() < count + x30_particles.size()) { | ||||||
|     x60_advValues.resize(m_maxMAXP); |     x60_advValues.resize(std::min(int(x60_advValues.capacity() * 2), x90_MAXP)); | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   CParticleGlobals::instance()->m_particleAccessParameters = nullptr; |   CParticleGlobals::instance()->m_particleAccessParameters = nullptr; | ||||||
| 
 | 
 | ||||||
|   for (int i = 0; i < count; ++i) { |   for (int i = 0; i < count; ++i) { | ||||||
|     CParticle& particle = x30_particles.emplace_back(); |     CParticle& particle = x30_particles.emplace_back(); | ||||||
|     ++g_ParticleAliveCount; |     ++g_ParticleAliveCount; | ||||||
|  |     u32 particleCount = x30_particles.size() - 1; | ||||||
|     ++x25c_activeParticleCount; |     ++x25c_activeParticleCount; | ||||||
|     ++x260_cumulativeParticles; |     ++x260_cumulativeParticles; | ||||||
|     if (x2c_orientType == EModelOrientationType::One) { |     if (x2c_orientType == EModelOrientationType::One) { | ||||||
| @ -518,14 +517,16 @@ void CElementGen::CreateNewParticles(int count) { | |||||||
|     CParticleGlobals::instance()->SetParticleLifetime(particle.x0_endFrame); |     CParticleGlobals::instance()->SetParticleLifetime(particle.x0_endFrame); | ||||||
|     CParticleGlobals::instance()->UpdateParticleLifetimeTweenValues(0); |     CParticleGlobals::instance()->UpdateParticleLifetimeTweenValues(0); | ||||||
|     g_currentParticle = &particle; |     g_currentParticle = &particle; | ||||||
|     if (x26d_28_enableADV) |     if (x26d_28_enableADV) { | ||||||
|       UpdateAdvanceAccessParameters(x30_particles.size() - 1, 0); |       UpdateAdvanceAccessParameters(particleCount, 0); | ||||||
|  |     } | ||||||
|     particle.x0_endFrame += x74_curFrame; |     particle.x0_endFrame += x74_curFrame; | ||||||
| 
 | 
 | ||||||
|     if (CColorElement* colr = desc->x30_x24_COLR.get()) |     if (CColorElement* colr = desc->x30_x24_COLR.get()) { | ||||||
|       colr->GetValue(0, particle.x34_color); |       colr->GetValue(0, particle.x34_color); | ||||||
|     else |     } else { | ||||||
|       particle.x34_color = zeus::skWhite; |       particle.x34_color = zeus::skWhite; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     if (CEmitterElement* emtr = desc->x40_x2c_EMTR.get()) { |     if (CEmitterElement* emtr = desc->x40_x2c_EMTR.get()) { | ||||||
|       emtr->GetValue(x74_curFrame, particle.x4_pos, particle.x1c_vel); |       emtr->GetValue(x74_curFrame, particle.x4_pos, particle.x1c_vel); | ||||||
| @ -840,12 +841,13 @@ void CElementGen::Render(const CActorLights* actorLights) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CElementGen::RenderModels(const CActorLights* actorLights) { | void CElementGen::RenderModels(const CActorLights* actorLights) { | ||||||
|   CGenDescription* desc = x1c_genDesc.GetObj(); |   CParticleGlobals::instance()->m_particleAccessParameters = nullptr; | ||||||
| 
 |  | ||||||
|   if (x26d_26_modelsUseLights) |   if (x26d_26_modelsUseLights) | ||||||
|     CGraphics::SetLightState(x274_backupLightActive); |     CGraphics::SetLightState(x274_backupLightActive); | ||||||
|   CGlobalRandom gr(x27c_randState); |   CGlobalRandom gr(x27c_randState); | ||||||
| 
 | 
 | ||||||
|  |   CGenDescription* desc = x1c_genDesc.GetObj(); | ||||||
|  | 
 | ||||||
|   SUVElementSet uvs = {0.f, 0.f, 1.f, 1.f}; |   SUVElementSet uvs = {0.f, 0.f, 1.f, 1.f}; | ||||||
|   CUVElement* texr = desc->x54_x40_TEXR.get(); |   CUVElement* texr = desc->x54_x40_TEXR.get(); | ||||||
|   CTexture* cachedTex = nullptr; |   CTexture* cachedTex = nullptr; | ||||||
| @ -948,10 +950,10 @@ void CElementGen::RenderModels(const CActorLights* actorLights) { | |||||||
|     CParticleGlobals::instance()->SetParticleLifetime(particle.x0_endFrame - particle.x28_startFrame); |     CParticleGlobals::instance()->SetParticleLifetime(particle.x0_endFrame - particle.x28_startFrame); | ||||||
|     int partFrame = x74_curFrame - particle.x28_startFrame - 1; |     int partFrame = x74_curFrame - particle.x28_startFrame - 1; | ||||||
|     CParticleGlobals::instance()->UpdateParticleLifetimeTweenValues(partFrame); |     CParticleGlobals::instance()->UpdateParticleLifetimeTweenValues(partFrame); | ||||||
|     if (i < x60_advValues.size()) |     if (x26d_28_enableADV) { | ||||||
|       CParticleGlobals::instance()->m_particleAccessParameters = &x60_advValues[i]; |       CParticleGlobals::instance()->m_particleAccessParameters = &x60_advValues[i]; | ||||||
|     else |     } | ||||||
|       CParticleGlobals::instance()->m_particleAccessParameters = nullptr; | 
 | ||||||
|     CVectorElement* pmop = desc->x6c_x58_PMOP.get(); |     CVectorElement* pmop = desc->x6c_x58_PMOP.get(); | ||||||
|     if (pmop) |     if (pmop) | ||||||
|       pmop->GetValue(partFrame, pmopVec); |       pmop->GetValue(partFrame, pmopVec); | ||||||
|  | |||||||
| @ -65,7 +65,6 @@ private: | |||||||
|   bool x88_particleEmission = true; |   bool x88_particleEmission = true; | ||||||
|   float x8c_generatorRemainder = 0.f; |   float x8c_generatorRemainder = 0.f; | ||||||
|   int x90_MAXP = 0; |   int x90_MAXP = 0; | ||||||
|   int m_maxMAXP = 256; |  | ||||||
|   u16 x94_randomSeed = g_GlobalSeed; |   u16 x94_randomSeed = g_GlobalSeed; | ||||||
|   float x98_generatorRate = 1.f; |   float x98_generatorRate = 1.f; | ||||||
|   std::array<float, 16> x9c_externalVars{}; |   std::array<float, 16> x9c_externalVars{}; | ||||||
| @ -101,7 +100,6 @@ private: | |||||||
|   bool x26d_27_enableOPTS : 1; |   bool x26d_27_enableOPTS : 1; | ||||||
|   bool x26d_28_enableADV : 1 = false; |   bool x26d_28_enableADV : 1 = false; | ||||||
|   int x270_MBSP = 0; |   int x270_MBSP = 0; | ||||||
|   int m_maxMBSP = 0; |  | ||||||
|   ERglLightBits x274_backupLightActive = ERglLightBits::None; |   ERglLightBits x274_backupLightActive = ERglLightBits::None; | ||||||
|   std::array<bool, 4> x278_hasVMD{}; |   std::array<bool, 4> x278_hasVMD{}; | ||||||
|   CRandom16 x27c_randState; |   CRandom16 x27c_randState; | ||||||
| @ -225,7 +223,6 @@ public: | |||||||
|   static void SetMoveRedToAlphaBuffer(bool move); |   static void SetMoveRedToAlphaBuffer(bool move); | ||||||
| 
 | 
 | ||||||
|   s32 GetMaxParticles() const { return x90_MAXP; } |   s32 GetMaxParticles() const { return x90_MAXP; } | ||||||
|   s32 GetMaxMaxParticles() const { return m_maxMAXP; } |  | ||||||
| 
 | 
 | ||||||
|   std::vector<CParticle> const& GetParticles() const { return x30_particles; } |   std::vector<CParticle> const& GetParticles() const { return x30_particles; } | ||||||
|   std::vector<CParticle> &GetParticles() { return x30_particles; } |   std::vector<CParticle> &GetParticles() { return x30_particles; } | ||||||
|  | |||||||
| @ -368,15 +368,6 @@ void CNewFlameThrower::UpdateFx(const zeus::CTransform& xf, float dt, CStateMana | |||||||
|         float tmp = std::clamp(unk.magnitude() * 30.f, 1.f, x37c_26_runningSlowish ? 2.f : 4.f); |         float tmp = std::clamp(unk.magnitude() * 30.f, 1.f, x37c_26_runningSlowish ? 2.f : 4.f); | ||||||
| 
 | 
 | ||||||
|         x3b4_numSmokeParticlesSpawned = std::max(static_cast<int>(round(tmp)), x3b4_numSmokeParticlesSpawned - 1); |         x3b4_numSmokeParticlesSpawned = std::max(static_cast<int>(round(tmp)), x3b4_numSmokeParticlesSpawned - 1); | ||||||
|         // INSERT
 |  | ||||||
|         if ((x35c_mainSmokeGen->GetParticles().size() + x3b4_numSmokeParticlesSpawned) > |  | ||||||
|             x35c_mainSmokeGen->GetMaxMaxParticles()) { |  | ||||||
|           x3b4_numSmokeParticlesSpawned = x3b4_numSmokeParticlesSpawned - |  | ||||||
|                                           ((x35c_mainSmokeGen->GetParticles().size() + x3b4_numSmokeParticlesSpawned) - |  | ||||||
|                                            x35c_mainSmokeGen->GetMaxMaxParticles()); |  | ||||||
|         } |  | ||||||
|         // END INSERT
 |  | ||||||
|         // This limit shouldn't be needed, m_maxMAXP should be removed?
 |  | ||||||
| 
 | 
 | ||||||
|         x35c_mainSmokeGen->SetTranslation(swoosh_1.xc_translation); |         x35c_mainSmokeGen->SetTranslation(swoosh_1.xc_translation); | ||||||
|         x35c_mainSmokeGen->SetOrientation(swoosh_1.x38_orientation); |         x35c_mainSmokeGen->SetOrientation(swoosh_1.x38_orientation); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user