mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-06 23:46:43 +00:00
69 lines
1.5 KiB
C
69 lines
1.5 KiB
C
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose: a class for performing cube-mapped spherical sample lookups.
|
||
|
//
|
||
|
// $Workfile: $
|
||
|
// $Date: $
|
||
|
// $NoKeywords: $
|
||
|
//===========================================================================//
|
||
|
|
||
|
#ifndef CUBEMAP_H
|
||
|
#define CUBEMAP_H
|
||
|
|
||
|
#ifdef _WIN32
|
||
|
#pragma once
|
||
|
#endif
|
||
|
|
||
|
#include "tier0/platform.h"
|
||
|
#include "tier1/utlmemory.h"
|
||
|
#include "mathlib/mathlib.h"
|
||
|
|
||
|
template<class T, int RES> struct CCubeMap
|
||
|
{
|
||
|
T m_Samples[6][RES][RES];
|
||
|
|
||
|
public:
|
||
|
FORCEINLINE void GetCoords( Vector const &vecNormalizedDirection, int &nX, int &nY, int &nFace )
|
||
|
{
|
||
|
// find largest magnitude component
|
||
|
int nLargest = 0;
|
||
|
int nAxis0 = 1;
|
||
|
int nAxis1 = 2;
|
||
|
if ( fabs( vecNormalizedDirection[1] ) > fabs( vecNormalizedDirection[0] ) )
|
||
|
{
|
||
|
nLargest = 1;
|
||
|
nAxis0 = 0;
|
||
|
nAxis1 = 2;
|
||
|
}
|
||
|
if ( fabs( vecNormalizedDirection[2] ) > fabs( vecNormalizedDirection[nLargest] ) )
|
||
|
{
|
||
|
nLargest = 2;
|
||
|
nAxis0 = 0;
|
||
|
nAxis1 = 1;
|
||
|
}
|
||
|
float flZ = vecNormalizedDirection[nLargest];
|
||
|
if ( flZ < 0 )
|
||
|
{
|
||
|
flZ = - flZ;
|
||
|
nLargest += 3;
|
||
|
}
|
||
|
nFace = nLargest;
|
||
|
flZ = 1.0 / flZ;
|
||
|
nX = RemapValClamped( vecNormalizedDirection[nAxis0] * flZ, -1, 1, 0, RES - 1 );
|
||
|
nY = RemapValClamped( vecNormalizedDirection[nAxis1] * flZ, -1, 1, 0, RES - 1 );
|
||
|
}
|
||
|
|
||
|
FORCEINLINE T & GetSample( Vector const &vecNormalizedDirection )
|
||
|
{
|
||
|
int nX, nY, nFace;
|
||
|
GetCoords( vecNormalizedDirection, nX, nY, nFace );
|
||
|
return m_Samples[nFace][nX][nY];
|
||
|
}
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
#endif // CUBEMAP_H
|