CGraphics: Make use of std::array
This commit is contained in:
parent
bf9233779a
commit
ece0aec27a
|
@ -24,11 +24,11 @@ CGraphics::ELightingMode CGraphics::sLightMode;
|
||||||
uint32 CGraphics::sNumLights;
|
uint32 CGraphics::sNumLights;
|
||||||
CColor CGraphics::sAreaAmbientColor = CColor::skTransparentBlack;
|
CColor CGraphics::sAreaAmbientColor = CColor::skTransparentBlack;
|
||||||
float CGraphics::sWorldLightMultiplier;
|
float CGraphics::sWorldLightMultiplier;
|
||||||
CLight CGraphics::sDefaultDirectionalLights[3] = {
|
std::array<CLight, 3> CGraphics::sDefaultDirectionalLights{{
|
||||||
CLight::BuildDirectional(CVector3f(0), CVector3f(0.f, -0.866025f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f)),
|
CLight::BuildDirectional(CVector3f(0), CVector3f(0.f, -0.866025f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f)),
|
||||||
CLight::BuildDirectional(CVector3f(0), CVector3f(-0.75f, 0.433013f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f)),
|
CLight::BuildDirectional(CVector3f(0), CVector3f(-0.75f, 0.433013f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f)),
|
||||||
CLight::BuildDirectional(CVector3f(0), CVector3f( 0.75f, 0.433013f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f))
|
CLight::BuildDirectional(CVector3f(0), CVector3f(0.75f, 0.433013f, -0.5f), CColor(0.3f, 0.3f, 0.3f, 0.3f)),
|
||||||
};
|
}};
|
||||||
|
|
||||||
// ************ FUNCTIONS ************
|
// ************ FUNCTIONS ************
|
||||||
void CGraphics::Initialize()
|
void CGraphics::Initialize()
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include <Common/Math/CMatrix4f.h>
|
#include <Common/Math/CMatrix4f.h>
|
||||||
#include <Common/Math/CVector3f.h>
|
#include <Common/Math/CVector3f.h>
|
||||||
#include <Common/Math/CVector4f.h>
|
#include <Common/Math/CVector4f.h>
|
||||||
|
#include <array>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* todo: this entire thing needs to be further abstracted, other classes shouldn't
|
* todo: this entire thing needs to be further abstracted, other classes shouldn't
|
||||||
|
@ -43,8 +44,8 @@ public:
|
||||||
// SVertexBlock
|
// SVertexBlock
|
||||||
struct SVertexBlock
|
struct SVertexBlock
|
||||||
{
|
{
|
||||||
CMatrix4f TexMatrices[10];
|
std::array<CMatrix4f, 10> TexMatrices;
|
||||||
CMatrix4f PostMatrices[20];
|
std::array<CMatrix4f, 20> PostMatrices;
|
||||||
CColor COLOR0_Amb;
|
CColor COLOR0_Amb;
|
||||||
CColor COLOR0_Mat;
|
CColor COLOR0_Mat;
|
||||||
CColor COLOR1_Amb;
|
CColor COLOR1_Amb;
|
||||||
|
@ -55,15 +56,15 @@ public:
|
||||||
// SPixelBlock
|
// SPixelBlock
|
||||||
struct SPixelBlock
|
struct SPixelBlock
|
||||||
{
|
{
|
||||||
CColor Konst[4];
|
std::array<CColor, 4> Konst;
|
||||||
CColor TevColor[4];
|
std::array<CColor, 4> TevColor;
|
||||||
CColor TintColor;
|
CColor TintColor;
|
||||||
float LightmapMultiplier;
|
float LightmapMultiplier;
|
||||||
float Padding[3];
|
std::array<float, 3> Padding;
|
||||||
|
|
||||||
void SetAllTevColors(const CColor& color)
|
void SetAllTevColors(const CColor& color)
|
||||||
{
|
{
|
||||||
std::fill(std::begin(TevColor), std::end(TevColor), color);
|
TevColor.fill(color);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
static SPixelBlock sPixelBlock;
|
static SPixelBlock sPixelBlock;
|
||||||
|
@ -79,7 +80,7 @@ public:
|
||||||
CVector4f DistAtten;
|
CVector4f DistAtten;
|
||||||
CVector4f AngleAtten;
|
CVector4f AngleAtten;
|
||||||
};
|
};
|
||||||
SGXLight Lights[8];
|
std::array<SGXLight, 8> Lights;
|
||||||
};
|
};
|
||||||
static SLightBlock sLightBlock;
|
static SLightBlock sLightBlock;
|
||||||
|
|
||||||
|
@ -90,7 +91,7 @@ public:
|
||||||
static constexpr CColor skDefaultAmbientColor{0.5f, 0.5f, 0.5f, 0.0f};
|
static constexpr CColor skDefaultAmbientColor{0.5f, 0.5f, 0.5f, 0.0f};
|
||||||
static CColor sAreaAmbientColor;
|
static CColor sAreaAmbientColor;
|
||||||
static float sWorldLightMultiplier;
|
static float sWorldLightMultiplier;
|
||||||
static CLight sDefaultDirectionalLights[3];
|
static std::array<CLight, 3> sDefaultDirectionalLights;
|
||||||
|
|
||||||
// Functions
|
// Functions
|
||||||
static void Initialize();
|
static void Initialize();
|
||||||
|
|
|
@ -198,8 +198,9 @@ CStructProperty* CLight::GetProperties() const
|
||||||
// ************ OTHER ************
|
// ************ OTHER ************
|
||||||
void CLight::Load() const
|
void CLight::Load() const
|
||||||
{
|
{
|
||||||
uint8 Index = (uint8) CGraphics::sNumLights;
|
const auto Index = static_cast<uint8>(CGraphics::sNumLights);
|
||||||
if (Index >= 8) return;
|
if (Index >= CGraphics::sLightBlock.Lights.size())
|
||||||
|
return;
|
||||||
|
|
||||||
CGraphics::SLightBlock::SGXLight *pLight = &CGraphics::sLightBlock.Lights[Index];
|
CGraphics::SLightBlock::SGXLight *pLight = &CGraphics::sLightBlock.Lights[Index];
|
||||||
|
|
||||||
|
|
|
@ -181,13 +181,13 @@ bool CMaterial::SetCurrent(FRenderOptions Options)
|
||||||
glBlendFuncSeparate(srcRGB, dstRGB, srcAlpha, dstAlpha);
|
glBlendFuncSeparate(srcRGB, dstRGB, srcAlpha, dstAlpha);
|
||||||
|
|
||||||
// Set konst inputs
|
// Set konst inputs
|
||||||
for (uint32 iKonst = 0; iKonst < 4; iKonst++)
|
CGraphics::sPixelBlock.Konst = mKonstColors;
|
||||||
CGraphics::sPixelBlock.Konst[iKonst] = mKonstColors[iKonst];
|
|
||||||
|
|
||||||
// Set TEV registers
|
// Set TEV registers
|
||||||
if (mVersion >= EGame::Corruption)
|
if (mVersion >= EGame::Corruption)
|
||||||
for (uint32 iTev = 0; iTev < 4; iTev++)
|
{
|
||||||
CGraphics::sPixelBlock.TevColor[iTev] = mTevColors[iTev];
|
CGraphics::sPixelBlock.TevColor = mTevColors;
|
||||||
|
}
|
||||||
|
|
||||||
// Set color channels
|
// Set color channels
|
||||||
// COLOR0_Amb,Mat is initialized by the node instead of by the material
|
// COLOR0_Amb,Mat is initialized by the node instead of by the material
|
||||||
|
@ -242,21 +242,21 @@ uint64 CMaterial::HashParameters()
|
||||||
{
|
{
|
||||||
CFNV1A Hash(CFNV1A::EHashLength::k64Bit);
|
CFNV1A Hash(CFNV1A::EHashLength::k64Bit);
|
||||||
|
|
||||||
Hash.HashLong((int) mVersion);
|
Hash.HashLong(static_cast<int>(mVersion));
|
||||||
Hash.HashLong(mOptions);
|
Hash.HashLong(mOptions);
|
||||||
Hash.HashLong(mVtxDesc);
|
Hash.HashLong(mVtxDesc);
|
||||||
Hash.HashData(mKonstColors, sizeof(CColor) * 4);
|
Hash.HashData(mKonstColors.data(), sizeof(mKonstColors));
|
||||||
Hash.HashData(mTevColors, sizeof(CColor) * 4);
|
Hash.HashData(mTevColors.data(), sizeof(mTevColors));
|
||||||
Hash.HashLong(mBlendSrcFac);
|
Hash.HashLong(mBlendSrcFac);
|
||||||
Hash.HashLong(mBlendDstFac);
|
Hash.HashLong(mBlendDstFac);
|
||||||
Hash.HashByte(mLightingEnabled);
|
Hash.HashByte(mLightingEnabled);
|
||||||
Hash.HashLong(mEchoesUnknownA);
|
Hash.HashLong(mEchoesUnknownA);
|
||||||
Hash.HashLong(mEchoesUnknownB);
|
Hash.HashLong(mEchoesUnknownB);
|
||||||
|
|
||||||
for (uint32 iPass = 0; iPass < mPasses.size(); iPass++)
|
for (auto& pass : mPasses)
|
||||||
mPasses[iPass]->HashParameters(Hash);
|
pass->HashParameters(Hash);
|
||||||
|
|
||||||
uint64 NewHash = Hash.GetHash64();
|
const uint64 NewHash = Hash.GetHash64();
|
||||||
|
|
||||||
if (mParametersHash != NewHash)
|
if (mParametersHash != NewHash)
|
||||||
ClearShader();
|
ClearShader();
|
||||||
|
|
|
@ -83,8 +83,8 @@ private:
|
||||||
EGame mVersion;
|
EGame mVersion;
|
||||||
FMaterialOptions mOptions; // See the EMaterialOption enum above
|
FMaterialOptions mOptions; // See the EMaterialOption enum above
|
||||||
FVertexDescription mVtxDesc; // Descriptor of vertex attributes used by this material
|
FVertexDescription mVtxDesc; // Descriptor of vertex attributes used by this material
|
||||||
CColor mKonstColors[4]; // Konst color values for TEV
|
std::array<CColor, 4> mKonstColors; // Konst color values for TEV
|
||||||
CColor mTevColors[4]; // Initial TEV color register values (for MP3 materials only)
|
std::array<CColor, 4> mTevColors; // Initial TEV color register values (for MP3 materials only)
|
||||||
GLenum mBlendSrcFac; // Source blend factor
|
GLenum mBlendSrcFac; // Source blend factor
|
||||||
GLenum mBlendDstFac; // Dest blend factor
|
GLenum mBlendDstFac; // Dest blend factor
|
||||||
bool mLightingEnabled; // Color channel control flags; indicate whether lighting is enabled
|
bool mLightingEnabled; // Color channel control flags; indicate whether lighting is enabled
|
||||||
|
|
Loading…
Reference in New Issue