mirror of https://github.com/AxioDL/metaforce.git
CHudRadarInterface: Make use of const where applicable
Same behavior, but makes it obvious some references are only used in a read-only manner.
This commit is contained in:
parent
29cd228d03
commit
3a5a3e2011
|
@ -45,19 +45,22 @@ void CHudRadarInterface::DoDrawRadarPaint(const zeus::CVector3f& translate, floa
|
||||||
|
|
||||||
void CHudRadarInterface::DrawRadarPaint(const zeus::CVector3f& enemyPos, float radius, float alpha,
|
void CHudRadarInterface::DrawRadarPaint(const zeus::CVector3f& enemyPos, float radius, float alpha,
|
||||||
const SRadarPaintDrawParms& parms) {
|
const SRadarPaintDrawParms& parms) {
|
||||||
zeus::CVector2f playerToEnemy = enemyPos.toVec2f() - parms.x0_playerPos.toVec2f();
|
const zeus::CVector2f playerToEnemy = enemyPos.toVec2f() - parms.x0_playerPos.toVec2f();
|
||||||
|
const float zDelta = std::fabs(enemyPos.z() - parms.x0_playerPos.z());
|
||||||
|
|
||||||
float zDelta = std::fabs(enemyPos.z() - parms.x0_playerPos.z());
|
if (playerToEnemy.magnitude() > parms.x78_xyRadius || zDelta > parms.x7c_zRadius) {
|
||||||
|
return;
|
||||||
if (playerToEnemy.magnitude() <= parms.x78_xyRadius && zDelta <= parms.x7c_zRadius) {
|
|
||||||
if (zDelta > parms.x80_ZCloseRadius)
|
|
||||||
alpha *= 1.f - (zDelta - parms.x80_ZCloseRadius) / (parms.x7c_zRadius - parms.x80_ZCloseRadius);
|
|
||||||
zeus::CVector2f scopeScaled = playerToEnemy * parms.x70_scopeScalar;
|
|
||||||
zeus::CColor color = g_tweakGuiColors->GetRadarEnemyPaintColor();
|
|
||||||
color.a() *= alpha;
|
|
||||||
color.a() *= parms.x74_alpha;
|
|
||||||
DoDrawRadarPaint(parms.xc_preTranslate * zeus::CVector3f(scopeScaled.x(), 0.f, scopeScaled.y()), radius, color);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (zDelta > parms.x80_ZCloseRadius) {
|
||||||
|
alpha *= 1.f - (zDelta - parms.x80_ZCloseRadius) / (parms.x7c_zRadius - parms.x80_ZCloseRadius);
|
||||||
|
}
|
||||||
|
|
||||||
|
const zeus::CVector2f scopeScaled = playerToEnemy * parms.x70_scopeScalar;
|
||||||
|
zeus::CColor color = g_tweakGuiColors->GetRadarEnemyPaintColor();
|
||||||
|
color.a() *= alpha;
|
||||||
|
color.a() *= parms.x74_alpha;
|
||||||
|
DoDrawRadarPaint(parms.xc_preTranslate * zeus::CVector3f(scopeScaled.x(), 0.f, scopeScaled.y()), radius, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CHudRadarInterface::SetIsVisibleGame(bool v) {
|
void CHudRadarInterface::SetIsVisibleGame(bool v) {
|
||||||
|
@ -66,29 +69,33 @@ void CHudRadarInterface::SetIsVisibleGame(bool v) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void CHudRadarInterface::Update(float dt, const CStateManager& mgr) {
|
void CHudRadarInterface::Update(float dt, const CStateManager& mgr) {
|
||||||
CPlayerState& playerState = *mgr.GetPlayerState();
|
const CPlayerState& playerState = *mgr.GetPlayerState();
|
||||||
float visorTransFactor = (playerState.GetCurrentVisor() == CPlayerState::EPlayerVisor::Combat)
|
const float visorTransFactor = (playerState.GetCurrentVisor() == CPlayerState::EPlayerVisor::Combat)
|
||||||
? playerState.GetVisorTransitionFactor()
|
? playerState.GetVisorTransitionFactor()
|
||||||
: 0.f;
|
: 0.f;
|
||||||
zeus::CColor color = g_tweakGuiColors->GetRadarStuffColor();
|
zeus::CColor color = g_tweakGuiColors->GetRadarStuffColor();
|
||||||
color.a() *= g_GameState->GameOptions().GetHUDAlpha() / 255.f * visorTransFactor;
|
color.a() *= g_GameState->GameOptions().GetHUDAlpha() / 255.f * visorTransFactor;
|
||||||
x40_BaseWidget_RadarStuff->SetColor(color);
|
x40_BaseWidget_RadarStuff->SetColor(color);
|
||||||
bool tweakVis = g_tweakGui->GetHudVisMode() >= ITweakGui::EHudVisMode::Three;
|
const bool tweakVis = g_tweakGui->GetHudVisMode() >= ITweakGui::EHudVisMode::Three;
|
||||||
if (tweakVis != x3c_25_visibleDebug) {
|
|
||||||
x3c_25_visibleDebug = tweakVis;
|
if (tweakVis == x3c_25_visibleDebug) {
|
||||||
x40_BaseWidget_RadarStuff->SetVisibility(x3c_25_visibleDebug && x3c_24_visibleGame, ETraversalMode::Children);
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
x3c_25_visibleDebug = tweakVis;
|
||||||
|
x40_BaseWidget_RadarStuff->SetVisibility(x3c_25_visibleDebug && x3c_24_visibleGame, ETraversalMode::Children);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
||||||
alpha *= g_GameState->GameOptions().GetHUDAlpha() / 255.f;
|
alpha *= g_GameState->GameOptions().GetHUDAlpha() / 255.f;
|
||||||
if (g_tweakGui->GetHudVisMode() == ITweakGui::EHudVisMode::Zero || !x3c_24_visibleGame || !x0_txtrRadarPaint ||
|
if (g_tweakGui->GetHudVisMode() == ITweakGui::EHudVisMode::Zero || !x3c_24_visibleGame || !x0_txtrRadarPaint ||
|
||||||
!x0_txtrRadarPaint.IsLoaded())
|
!x0_txtrRadarPaint.IsLoaded()) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SRadarPaintDrawParms drawParms;
|
SRadarPaintDrawParms drawParms;
|
||||||
|
|
||||||
CPlayer& player = mgr.GetPlayer();
|
const CPlayer& player = mgr.GetPlayer();
|
||||||
if (player.IsOverrideRadarRadius()) {
|
if (player.IsOverrideRadarRadius()) {
|
||||||
drawParms.x78_xyRadius = player.GetRadarXYRadiusOverride();
|
drawParms.x78_xyRadius = player.GetRadarXYRadiusOverride();
|
||||||
drawParms.x7c_zRadius = player.GetRadarZRadiusOverride();
|
drawParms.x7c_zRadius = player.GetRadarZRadiusOverride();
|
||||||
|
@ -102,13 +109,13 @@ void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
||||||
drawParms.x6c_scopeRadius = g_tweakGui->GetRadarScopeCoordRadius();
|
drawParms.x6c_scopeRadius = g_tweakGui->GetRadarScopeCoordRadius();
|
||||||
drawParms.x70_scopeScalar = drawParms.x6c_scopeRadius / drawParms.x78_xyRadius;
|
drawParms.x70_scopeScalar = drawParms.x6c_scopeRadius / drawParms.x78_xyRadius;
|
||||||
|
|
||||||
float camZ =
|
const float camZ =
|
||||||
zeus::CEulerAngles(zeus::CQuaternion(mgr.GetCameraManager()->GetCurrentCamera(mgr)->GetTransform().basis)).z();
|
zeus::CEulerAngles(zeus::CQuaternion(mgr.GetCameraManager()->GetCurrentCamera(mgr)->GetTransform().basis)).z();
|
||||||
zeus::CRelAngle angleZ(camZ);
|
zeus::CRelAngle angleZ(camZ);
|
||||||
angleZ.makeRel();
|
angleZ.makeRel();
|
||||||
drawParms.xc_preTranslate = zeus::CTransform::RotateY(angleZ);
|
drawParms.xc_preTranslate = zeus::CTransform::RotateY(angleZ);
|
||||||
drawParms.x3c_postTranslate = x40_BaseWidget_RadarStuff->GetWorldTransform();
|
drawParms.x3c_postTranslate = x40_BaseWidget_RadarStuff->GetWorldTransform();
|
||||||
float enemyRadius = g_tweakGui->GetRadarEnemyPaintRadius();
|
const float enemyRadius = g_tweakGui->GetRadarEnemyPaintRadius();
|
||||||
|
|
||||||
m_paintInsts.clear();
|
m_paintInsts.clear();
|
||||||
x44_camera->Draw(CGuiWidgetDrawParms{0.f, zeus::CVector3f{}});
|
x44_camera->Draw(CGuiWidgetDrawParms{0.f, zeus::CVector3f{}});
|
||||||
|
@ -118,7 +125,7 @@ void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
||||||
playerColor.a() *= alpha;
|
playerColor.a() *= alpha;
|
||||||
DoDrawRadarPaint(zeus::skZero3f, g_tweakGui->GetRadarPlayerPaintRadius(), playerColor);
|
DoDrawRadarPaint(zeus::skZero3f, g_tweakGui->GetRadarPlayerPaintRadius(), playerColor);
|
||||||
|
|
||||||
zeus::CAABox radarBounds(
|
const zeus::CAABox radarBounds(
|
||||||
player.GetTranslation().x() - drawParms.x78_xyRadius, player.GetTranslation().y() - drawParms.x78_xyRadius,
|
player.GetTranslation().x() - drawParms.x78_xyRadius, player.GetTranslation().y() - drawParms.x78_xyRadius,
|
||||||
player.GetTranslation().z() - drawParms.x7c_zRadius, player.GetTranslation().x() + drawParms.x78_xyRadius,
|
player.GetTranslation().z() - drawParms.x7c_zRadius, player.GetTranslation().x() + drawParms.x78_xyRadius,
|
||||||
player.GetTranslation().y() + drawParms.x78_xyRadius, player.GetTranslation().z() + drawParms.x7c_zRadius);
|
player.GetTranslation().y() + drawParms.x78_xyRadius, player.GetTranslation().z() + drawParms.x7c_zRadius);
|
||||||
|
@ -132,15 +139,17 @@ void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
||||||
drawParms.x0_playerPos = mgr.GetPlayer().GetTranslation();
|
drawParms.x0_playerPos = mgr.GetPlayer().GetTranslation();
|
||||||
drawParms.x74_alpha = alpha;
|
drawParms.x74_alpha = alpha;
|
||||||
|
|
||||||
for (TUniqueId id : nearList) {
|
for (const TUniqueId id : nearList) {
|
||||||
if (TCastToConstPtr<CActor> act = mgr.GetObjectById(id)) {
|
if (const TCastToConstPtr<CActor> act = mgr.GetObjectById(id)) {
|
||||||
if (!act->GetActive())
|
if (!act->GetActive()) {
|
||||||
continue;
|
continue;
|
||||||
if (TCastToConstPtr<CWallCrawlerSwarm> swarm = act.GetPtr()) {
|
}
|
||||||
float radius = enemyRadius * 0.5f;
|
if (const TCastToConstPtr<CWallCrawlerSwarm> swarm = act.GetPtr()) {
|
||||||
|
const float radius = enemyRadius * 0.5f;
|
||||||
for (const CWallCrawlerSwarm::CBoid& boid : swarm->GetBoids()) {
|
for (const CWallCrawlerSwarm::CBoid& boid : swarm->GetBoids()) {
|
||||||
if (!boid.GetActive())
|
if (!boid.GetActive()) {
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
DrawRadarPaint(boid.GetTranslation(), radius, 0.5f, drawParms);
|
DrawRadarPaint(boid.GetTranslation(), radius, 0.5f, drawParms);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue