mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-26 19:30:24 +00:00 
			
		
		
		
	CScriptSteam: Fixes from decomp
This commit is contained in:
		
							parent
							
								
									d29df977f3
								
							
						
					
					
						commit
						e9cfa6aff4
					
				| @ -17,14 +17,8 @@ CScriptSteam::CScriptSteam(TUniqueId uid, std::string_view name, const CEntityIn | |||||||
| , x158_(f1) | , x158_(f1) | ||||||
| , x15c_alphaInDur(f2 / f1) | , x15c_alphaInDur(f2 / f1) | ||||||
| , x160_alphaOutDur(f3 / f1) { | , x160_alphaOutDur(f3 / f1) { | ||||||
|   float r3 = (aabb.max.z() < aabb.max.y() ? aabb.max.z() : aabb.max.y()); |   float r3 = std::min(aabb.max.x(), std::min(aabb.max.y(), aabb.max.z())); | ||||||
|   r3 = (r3 < aabb.max.x() ? r3 : aabb.max.x()); |   x164_ = zeus::close_enough(f4, 0.f) ? r3 : std::min(f4, r3); | ||||||
| 
 |  | ||||||
|   if (zeus::close_enough(f4, 0.f)) { |  | ||||||
|     r3 = (r3 < f2 ? r3 : f4); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   x164_ = r3; |  | ||||||
|   x168_ = 1.f / x164_; |   x168_ = 1.f / x164_; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -32,7 +26,7 @@ void CScriptSteam::Accept(IVisitor& visitor) { visitor.Visit(this); } | |||||||
| 
 | 
 | ||||||
| void CScriptSteam::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId uid, CStateManager& mgr) { | void CScriptSteam::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId uid, CStateManager& mgr) { | ||||||
|   if (msg == EScriptObjectMessage::Deactivate) { |   if (msg == EScriptObjectMessage::Deactivate) { | ||||||
|     mgr.Player()->SetVisorSteam(0.f, x158_, x160_alphaOutDur, CAssetId(), x150_); |     mgr.Player()->SetVisorSteam(0.f, x158_, x160_alphaOutDur, CAssetId(), !x150_); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   CScriptTrigger::AcceptScriptMsg(msg, uid, mgr); |   CScriptTrigger::AcceptScriptMsg(msg, uid, mgr); | ||||||
| @ -50,12 +44,12 @@ void CScriptSteam::Think(float dt, CStateManager& mgr) { | |||||||
|     const zeus::CVector3f posDiff = (GetTranslation() - eyePos); |     const zeus::CVector3f posDiff = (GetTranslation() - eyePos); | ||||||
|     const float mag = posDiff.magnitude(); |     const float mag = posDiff.magnitude(); | ||||||
|     const float distance = (mag >= x164_ ? 0.f : std::cos((1.5707964f * mag) * x168_) * x158_); |     const float distance = (mag >= x164_ ? 0.f : std::cos((1.5707964f * mag) * x168_) * x158_); | ||||||
|     mgr.Player()->SetVisorSteam(distance, x15c_alphaInDur, x160_alphaOutDur, x154_texture, x150_); |     mgr.Player()->SetVisorSteam(distance, x15c_alphaInDur, x160_alphaOutDur, x154_texture, !x150_); | ||||||
|     if (x150_) { |     if (x150_) { | ||||||
|       mgr.GetEnvFxManager()->SetSplashRate(2.f * distance); |       mgr.GetEnvFxManager()->SetSplashRate(2.f * distance); | ||||||
|     } |     } | ||||||
|   } else { |   } else { | ||||||
|     mgr.Player()->SetVisorSteam(0.f, x15c_alphaInDur, x160_alphaOutDur, CAssetId(), x150_); |     mgr.Player()->SetVisorSteam(0.f, x15c_alphaInDur, x160_alphaOutDur, CAssetId(), !x150_); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user