mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-04 02:55:45 +03:00
161 lines
3.4 KiB
C++
161 lines
3.4 KiB
C++
#include "precompiled.h"
|
|
|
|
TYPEDESCRIPTION CLight::m_SaveData[] =
|
|
{
|
|
DEFINE_FIELD(CLight, m_iStyle, FIELD_INTEGER),
|
|
DEFINE_FIELD(CLight, m_iszPattern, FIELD_STRING),
|
|
};
|
|
|
|
LINK_ENTITY_TO_CLASS(light, CLight, CCSLight)
|
|
IMPLEMENT_SAVERESTORE(CLight, CPointEntity)
|
|
|
|
// Cache user-entity-field values until spawn is called.
|
|
void CLight::KeyValue(KeyValueData *pkvd)
|
|
{
|
|
if (FStrEq(pkvd->szKeyName, "style"))
|
|
{
|
|
m_iStyle = Q_atoi(pkvd->szValue);
|
|
pkvd->fHandled = TRUE;
|
|
}
|
|
else if (FStrEq(pkvd->szKeyName, "pitch"))
|
|
{
|
|
pev->angles.x = Q_atof(pkvd->szValue);
|
|
pkvd->fHandled = TRUE;
|
|
}
|
|
else if (FStrEq(pkvd->szKeyName, "pattern"))
|
|
{
|
|
m_iszPattern = ALLOC_STRING(pkvd->szValue);
|
|
pkvd->fHandled = TRUE;
|
|
}
|
|
else
|
|
{
|
|
CPointEntity::KeyValue(pkvd);
|
|
}
|
|
}
|
|
|
|
void CLight::Spawn()
|
|
{
|
|
// inert light
|
|
if (FStringNull(pev->targetname))
|
|
{
|
|
REMOVE_ENTITY(ENT(pev));
|
|
return;
|
|
}
|
|
|
|
m_iStartedOff = (pev->spawnflags & SF_LIGHT_START_OFF) != 0;
|
|
|
|
if (m_iStyle >= 32)
|
|
{
|
|
if (pev->spawnflags & SF_LIGHT_START_OFF)
|
|
LIGHT_STYLE(m_iStyle, "a");
|
|
|
|
else if (m_iszPattern)
|
|
LIGHT_STYLE(m_iStyle, (char *)STRING(m_iszPattern));
|
|
else
|
|
LIGHT_STYLE(m_iStyle, "m");
|
|
}
|
|
}
|
|
|
|
void CLight::Restart()
|
|
{
|
|
if (m_iStyle >= 32)
|
|
{
|
|
if (m_iStartedOff)
|
|
{
|
|
pev->spawnflags |= SF_LIGHT_START_OFF;
|
|
LIGHT_STYLE(m_iStyle, "a");
|
|
}
|
|
else
|
|
{
|
|
pev->spawnflags &= ~SF_LIGHT_START_OFF;
|
|
|
|
if (m_iszPattern)
|
|
LIGHT_STYLE(m_iStyle, (char *)STRING(m_iszPattern));
|
|
else
|
|
LIGHT_STYLE(m_iStyle, "m");
|
|
}
|
|
}
|
|
}
|
|
|
|
void CLight::Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
|
|
{
|
|
if (m_iStyle >= 32)
|
|
{
|
|
if (!ShouldToggle(useType, !(pev->spawnflags & SF_LIGHT_START_OFF)))
|
|
return;
|
|
|
|
if (pev->spawnflags & SF_LIGHT_START_OFF)
|
|
{
|
|
if (m_iszPattern)
|
|
LIGHT_STYLE(m_iStyle, (char *)STRING(m_iszPattern));
|
|
else
|
|
LIGHT_STYLE(m_iStyle, "m");
|
|
|
|
pev->spawnflags &= ~SF_LIGHT_START_OFF;
|
|
}
|
|
else
|
|
{
|
|
LIGHT_STYLE(m_iStyle, "a");
|
|
pev->spawnflags |= SF_LIGHT_START_OFF;
|
|
}
|
|
}
|
|
}
|
|
|
|
LINK_ENTITY_TO_CLASS(light_spot, CLight, CCSLight)
|
|
LINK_ENTITY_TO_CLASS(light_environment, CEnvLight, CCSEnvLight)
|
|
|
|
void CEnvLight::KeyValue(KeyValueData *pkvd)
|
|
{
|
|
if (FStrEq(pkvd->szKeyName, "_light"))
|
|
{
|
|
int r, g, b, v, j;
|
|
j = sscanf(pkvd->szValue, "%d %d %d %d\n", &r, &g, &b, &v);
|
|
|
|
if (j == 1)
|
|
g = b = r;
|
|
|
|
else if (j == 4)
|
|
{
|
|
r = r * (v / 255.0);
|
|
g = g * (v / 255.0);
|
|
b = b * (v / 255.0);
|
|
}
|
|
|
|
// simulate qrad direct, ambient,and gamma adjustments, as well as engine scaling
|
|
r = Q_pow(r / 114.0, 0.6) * 264;
|
|
g = Q_pow(g / 114.0, 0.6) * 264;
|
|
b = Q_pow(b / 114.0, 0.6) * 264;
|
|
|
|
pkvd->fHandled = TRUE;
|
|
|
|
char szColor[64];
|
|
Q_sprintf(szColor, "%d", r);
|
|
CVAR_SET_STRING("sv_skycolor_r", szColor);
|
|
Q_sprintf(szColor, "%d", g);
|
|
CVAR_SET_STRING("sv_skycolor_g", szColor);
|
|
Q_sprintf(szColor, "%d", b);
|
|
CVAR_SET_STRING("sv_skycolor_b", szColor);
|
|
}
|
|
else
|
|
{
|
|
CLight::KeyValue(pkvd);
|
|
}
|
|
}
|
|
|
|
void CEnvLight::Spawn()
|
|
{
|
|
char szVector[64];
|
|
UTIL_MakeAimVectors(pev->angles);
|
|
|
|
Q_sprintf(szVector, "%f", gpGlobals->v_forward.x);
|
|
CVAR_SET_STRING("sv_skyvec_x", szVector);
|
|
|
|
Q_sprintf(szVector, "%f", gpGlobals->v_forward.y);
|
|
CVAR_SET_STRING("sv_skyvec_y", szVector);
|
|
|
|
Q_sprintf(szVector, "%f", gpGlobals->v_forward.z);
|
|
CVAR_SET_STRING("sv_skyvec_z", szVector);
|
|
|
|
CLight::Spawn();
|
|
}
|