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,20 +45,23 @@ void CHudRadarInterface::DoDrawRadarPaint(const zeus::CVector3f& translate, floa
|
|||
|
||||
void CHudRadarInterface::DrawRadarPaint(const zeus::CVector3f& enemyPos, float radius, float alpha,
|
||||
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)
|
||||
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;
|
||||
}
|
||||
|
||||
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) {
|
||||
x3c_24_visibleGame = v;
|
||||
|
@ -66,29 +69,33 @@ void CHudRadarInterface::SetIsVisibleGame(bool v) {
|
|||
}
|
||||
|
||||
void CHudRadarInterface::Update(float dt, const CStateManager& mgr) {
|
||||
CPlayerState& playerState = *mgr.GetPlayerState();
|
||||
float visorTransFactor = (playerState.GetCurrentVisor() == CPlayerState::EPlayerVisor::Combat)
|
||||
const CPlayerState& playerState = *mgr.GetPlayerState();
|
||||
const float visorTransFactor = (playerState.GetCurrentVisor() == CPlayerState::EPlayerVisor::Combat)
|
||||
? playerState.GetVisorTransitionFactor()
|
||||
: 0.f;
|
||||
zeus::CColor color = g_tweakGuiColors->GetRadarStuffColor();
|
||||
color.a() *= g_GameState->GameOptions().GetHUDAlpha() / 255.f * visorTransFactor;
|
||||
x40_BaseWidget_RadarStuff->SetColor(color);
|
||||
bool tweakVis = g_tweakGui->GetHudVisMode() >= ITweakGui::EHudVisMode::Three;
|
||||
if (tweakVis != x3c_25_visibleDebug) {
|
||||
const bool tweakVis = g_tweakGui->GetHudVisMode() >= ITweakGui::EHudVisMode::Three;
|
||||
|
||||
if (tweakVis == x3c_25_visibleDebug) {
|
||||
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) {
|
||||
alpha *= g_GameState->GameOptions().GetHUDAlpha() / 255.f;
|
||||
if (g_tweakGui->GetHudVisMode() == ITweakGui::EHudVisMode::Zero || !x3c_24_visibleGame || !x0_txtrRadarPaint ||
|
||||
!x0_txtrRadarPaint.IsLoaded())
|
||||
!x0_txtrRadarPaint.IsLoaded()) {
|
||||
return;
|
||||
}
|
||||
|
||||
SRadarPaintDrawParms drawParms;
|
||||
|
||||
CPlayer& player = mgr.GetPlayer();
|
||||
const CPlayer& player = mgr.GetPlayer();
|
||||
if (player.IsOverrideRadarRadius()) {
|
||||
drawParms.x78_xyRadius = player.GetRadarXYRadiusOverride();
|
||||
drawParms.x7c_zRadius = player.GetRadarZRadiusOverride();
|
||||
|
@ -102,13 +109,13 @@ void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
|||
drawParms.x6c_scopeRadius = g_tweakGui->GetRadarScopeCoordRadius();
|
||||
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::CRelAngle angleZ(camZ);
|
||||
angleZ.makeRel();
|
||||
drawParms.xc_preTranslate = zeus::CTransform::RotateY(angleZ);
|
||||
drawParms.x3c_postTranslate = x40_BaseWidget_RadarStuff->GetWorldTransform();
|
||||
float enemyRadius = g_tweakGui->GetRadarEnemyPaintRadius();
|
||||
const float enemyRadius = g_tweakGui->GetRadarEnemyPaintRadius();
|
||||
|
||||
m_paintInsts.clear();
|
||||
x44_camera->Draw(CGuiWidgetDrawParms{0.f, zeus::CVector3f{}});
|
||||
|
@ -118,7 +125,7 @@ void CHudRadarInterface::Draw(const CStateManager& mgr, float alpha) {
|
|||
playerColor.a() *= alpha;
|
||||
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().z() - drawParms.x7c_zRadius, player.GetTranslation().x() + drawParms.x78_xyRadius,
|
||||
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.x74_alpha = alpha;
|
||||
|
||||
for (TUniqueId id : nearList) {
|
||||
if (TCastToConstPtr<CActor> act = mgr.GetObjectById(id)) {
|
||||
if (!act->GetActive())
|
||||
for (const TUniqueId id : nearList) {
|
||||
if (const TCastToConstPtr<CActor> act = mgr.GetObjectById(id)) {
|
||||
if (!act->GetActive()) {
|
||||
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()) {
|
||||
if (!boid.GetActive())
|
||||
if (!boid.GetActive()) {
|
||||
continue;
|
||||
}
|
||||
DrawRadarPaint(boid.GetTranslation(), radius, 0.5f, drawParms);
|
||||
}
|
||||
} else {
|
||||
|
|
Loading…
Reference in New Issue