Minor fixes to CMetroidAreaCollider and CHudThreatInterface

This commit is contained in:
Phillip Stephens 2018-05-24 18:23:27 -07:00
parent 3ceaa82035
commit 48f41b6c73
2 changed files with 7 additions and 6 deletions

View File

@ -211,7 +211,8 @@ static zeus::CVector3f ClipRayToPlane(const zeus::CVector3f& a, const zeus::CVec
bool CMetroidAreaCollider::ConvexPolyCollision(const zeus::CPlane* planes, const zeus::CVector3f* verts, bool CMetroidAreaCollider::ConvexPolyCollision(const zeus::CPlane* planes, const zeus::CVector3f* verts,
zeus::CAABox& aabb) zeus::CAABox& aabb)
{ {
rstl::reserved_vector<zeus::CVector3f, 20> vecs[2]; /* FIXME: HACK: Increasing the size from 20 to 128 to give us more headroom, we should try and trim this back down to a more reasonable size */
rstl::reserved_vector<zeus::CVector3f, 128> vecs[2];
g_CalledClip += 1; g_CalledClip += 1;
g_RejectedByClip -= 1; g_RejectedByClip -= 1;
@ -224,8 +225,8 @@ bool CMetroidAreaCollider::ConvexPolyCollision(const zeus::CPlane* planes, const
int otherVecIdx = 1; int otherVecIdx = 1;
for (int i=0 ; i<6 ; ++i) for (int i=0 ; i<6 ; ++i)
{ {
rstl::reserved_vector<zeus::CVector3f, 20>& vec = vecs[vecIdx]; rstl::reserved_vector<zeus::CVector3f, 128>& vec = vecs[vecIdx];
rstl::reserved_vector<zeus::CVector3f, 20>& otherVec = vecs[otherVecIdx]; rstl::reserved_vector<zeus::CVector3f, 128>& otherVec = vecs[otherVecIdx];
otherVec.clear(); otherVec.clear();
bool inFrontOf = planes[i].pointToPlaneDist(vec.front()) >= 0.f; bool inFrontOf = planes[i].pointToPlaneDist(vec.front()) >= 0.f;
@ -245,7 +246,7 @@ bool CMetroidAreaCollider::ConvexPolyCollision(const zeus::CPlane* planes, const
otherVecIdx ^= 1; otherVecIdx ^= 1;
} }
rstl::reserved_vector<zeus::CVector3f, 20>& accumVec = vecs[otherVecIdx ^ 1]; rstl::reserved_vector<zeus::CVector3f, 128>& accumVec = vecs[otherVecIdx ^ 1];
for (const zeus::CVector3f& point : accumVec) for (const zeus::CVector3f& point : accumVec)
aabb.accumulateBounds(point); aabb.accumulateBounds(point);

View File

@ -231,7 +231,7 @@ void CHudThreatInterface::Update(float dt)
color.a = x48_warningLerpAlpha * xc_damagePulse; color.a = x48_warningLerpAlpha * xc_damagePulse;
x68_textpane_threatwarning->SetColor(color); x68_textpane_threatwarning->SetColor(color);
} }
if (x68_textpane_threatwarning->GetGeometryColor().a) if (x68_textpane_threatwarning->GetGeometryColor().a > 0.f)
x68_textpane_threatwarning->SetIsVisible(true); x68_textpane_threatwarning->SetIsVisible(true);
else else
x68_textpane_threatwarning->SetIsVisible(false); x68_textpane_threatwarning->SetIsVisible(false);
@ -240,7 +240,7 @@ void CHudThreatInterface::Update(float dt)
if (x4c_threatStatus == EThreatStatus::Damage) if (x4c_threatStatus == EThreatStatus::Damage)
x50_warningColorLerp = std::min(x50_warningColorLerp + 2.f * dt, 1.f); x50_warningColorLerp = std::min(x50_warningColorLerp + 2.f * dt, 1.f);
else else
x50_warningColorLerp = std::min(x50_warningColorLerp - 2.f * dt, 1.f); x50_warningColorLerp = std::max(0.f, x50_warningColorLerp - 2.f * dt);
} }
std::pair<zeus::CVector3f, zeus::CVector3f> CHudThreatInterface::CombatThreatBarCoordFunc(float t) std::pair<zeus::CVector3f, zeus::CVector3f> CHudThreatInterface::CombatThreatBarCoordFunc(float t)