mirror of https://github.com/AxioDL/metaforce.git
CCompoundTargetReticle: Make use of std::array where applicable
Same behavior, stronger typing. While we're at it, we can eliminate a case of variable shadowing.
This commit is contained in:
parent
c6278c0e9f
commit
e26afe887f
|
@ -71,10 +71,11 @@ CCompoundTargetReticle::CCompoundTargetReticle(const CStateManager& mgr)
|
||||||
|
|
||||||
CCompoundTargetReticle::SScanReticuleRenderer::SScanReticuleRenderer() {
|
CCompoundTargetReticle::SScanReticuleRenderer::SScanReticuleRenderer() {
|
||||||
CGraphics::CommitResources([this](boo::IGraphicsDataFactory::Context& ctx) {
|
CGraphics::CommitResources([this](boo::IGraphicsDataFactory::Context& ctx) {
|
||||||
for (int i = 0; i < 2; ++i) {
|
for (size_t i = 0; i < m_lineRenderers.size(); ++i) {
|
||||||
m_lineRenderers[i].emplace(ctx, CLineRenderer::EPrimitiveMode::Lines, 8, nullptr, true, true);
|
m_lineRenderers[i].emplace(ctx, CLineRenderer::EPrimitiveMode::Lines, 8, nullptr, true, true);
|
||||||
for (int j = 0; j < 4; ++j)
|
for (auto& stripRenderer : m_stripRenderers[i]) {
|
||||||
m_stripRenderers[i][j].emplace(ctx, CLineRenderer::EPrimitiveMode::LineStrip, 4, nullptr, true, true);
|
stripRenderer.emplace(ctx, CLineRenderer::EPrimitiveMode::LineStrip, 4, nullptr, true, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
} BooTrace);
|
} BooTrace);
|
||||||
|
@ -822,8 +823,8 @@ void CCompoundTargetReticle::DrawNextLockOnGroup(const zeus::CMatrix3f& rot, con
|
||||||
float alpha = 0.5f * factor;
|
float alpha = 0.5f * factor;
|
||||||
zeus::CColor color = g_tweakGuiColors->GetScanReticuleColor();
|
zeus::CColor color = g_tweakGuiColors->GetScanReticuleColor();
|
||||||
color.a() *= alpha;
|
color.a() *= alpha;
|
||||||
for (int i = 0; i < 2; ++i) {
|
for (size_t i = 0; i < m_scanRetRenderer.m_lineRenderers.size(); ++i) {
|
||||||
float lineWidth = i ? 2.5f : 1.f;
|
float lineWidth = i != 0 ? 2.5f : 1.f;
|
||||||
auto& rend = *m_scanRetRenderer.m_lineRenderers[i];
|
auto& rend = *m_scanRetRenderer.m_lineRenderers[i];
|
||||||
rend.Reset();
|
rend.Reset();
|
||||||
rend.AddVertex({-0.5f, 0.f, 0.f}, color, lineWidth);
|
rend.AddVertex({-0.5f, 0.f, 0.f}, color, lineWidth);
|
||||||
|
@ -836,17 +837,17 @@ void CCompoundTargetReticle::DrawNextLockOnGroup(const zeus::CMatrix3f& rot, con
|
||||||
rend.AddVertex({0.f, 0.f, 20.5f}, color, lineWidth);
|
rend.AddVertex({0.f, 0.f, 20.5f}, color, lineWidth);
|
||||||
rend.Render();
|
rend.Render();
|
||||||
|
|
||||||
for (int j = 0; j < 4; ++j) {
|
for (size_t j = 0; j < m_scanRetRenderer.m_stripRenderers[i].size(); ++j) {
|
||||||
float xSign = j < 2 ? -1.f : 1.f;
|
float xSign = j < 2 ? -1.f : 1.f;
|
||||||
float zSign = (j & 0x1) ? -1.f : 1.f;
|
float zSign = (j & 0x1) != 0 ? -1.f : 1.f;
|
||||||
// begin line strip
|
// begin line strip
|
||||||
auto& rend = *m_scanRetRenderer.m_stripRenderers[i][j];
|
auto& stripRend = *m_scanRetRenderer.m_stripRenderers[i][j];
|
||||||
rend.Reset();
|
stripRend.Reset();
|
||||||
rend.AddVertex({0.5f * xSign, 0.f, 0.1f * zSign}, color, lineWidth);
|
stripRend.AddVertex({0.5f * xSign, 0.f, 0.1f * zSign}, color, lineWidth);
|
||||||
rend.AddVertex({0.5f * xSign, 0.f, 0.35f * zSign}, color, lineWidth);
|
stripRend.AddVertex({0.5f * xSign, 0.f, 0.35f * zSign}, color, lineWidth);
|
||||||
rend.AddVertex({0.35f * xSign, 0.f, 0.5f * zSign}, color, lineWidth);
|
stripRend.AddVertex({0.35f * xSign, 0.f, 0.5f * zSign}, color, lineWidth);
|
||||||
rend.AddVertex({0.1f * xSign, 0.f, 0.5f * zSign}, color, lineWidth);
|
stripRend.AddVertex({0.1f * xSign, 0.f, 0.5f * zSign}, color, lineWidth);
|
||||||
rend.Render();
|
stripRend.Render();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <array>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "Runtime/CPlayerState.hpp"
|
#include "Runtime/CPlayerState.hpp"
|
||||||
|
@ -125,8 +126,8 @@ private:
|
||||||
u32 x228_ = 0;
|
u32 x228_ = 0;
|
||||||
|
|
||||||
struct SScanReticuleRenderer {
|
struct SScanReticuleRenderer {
|
||||||
std::optional<CLineRenderer> m_lineRenderers[2];
|
std::array<std::optional<CLineRenderer>, 2> m_lineRenderers;
|
||||||
std::optional<CLineRenderer> m_stripRenderers[2][4];
|
std::array<std::array<std::optional<CLineRenderer>, 4>, 2> m_stripRenderers;
|
||||||
SScanReticuleRenderer();
|
SScanReticuleRenderer();
|
||||||
};
|
};
|
||||||
SScanReticuleRenderer m_scanRetRenderer;
|
SScanReticuleRenderer m_scanRetRenderer;
|
||||||
|
|
Loading…
Reference in New Issue