ReGameDLL_CS/regamedll/dlls/effects.h

496 lines
14 KiB
C
Raw Normal View History

2015-06-30 12:46:07 +03:00
/*
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at
* your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* In addition, as a special exception, the author gives permission to
* link the code of this program with the Half-Life Game Engine ("HL
* Engine") and Modified Game Libraries ("MODs") developed by Valve,
* L.L.C ("Valve"). You must obey the GNU General Public License in all
* respects for all of the code used other than the HL Engine and MODs
* from Valve. If you modify this file, you may extend this exception
* to your version of the file, but you are not obligated to do so. If
* you do not wish to do so, delete this exception statement from your
* version.
*
*/
#ifndef EFFECTS_H
#define EFFECTS_H
#ifdef _WIN32
#pragma once
#endif
#define SF_BEAM_STARTON 0x0001
#define SF_BEAM_TOGGLE 0x0002
#define SF_BEAM_RANDOM 0x0004
#define SF_BEAM_RING 0x0008
#define SF_BEAM_SPARKSTART 0x0010
#define SF_BEAM_SPARKEND 0x0020
#define SF_BEAM_DECALS 0x0040
#define SF_BEAM_SHADEIN 0x0080
#define SF_BEAM_SHADEOUT 0x0100
#define SF_BEAM_TEMPORARY 0x8000
#define SF_GIBSHOOTER_REPEATABLE 1
#define SF_FUNNEL_REVERSE 1
#define SF_BUBBLES_STARTOFF 0x0001
#define SF_BLOOD_RANDOM 0x0001
#define SF_BLOOD_STREAM 0x0002
#define SF_BLOOD_PLAYER 0x0004
#define SF_BLOOD_DECAL 0x0008
#define SF_SHAKE_EVERYONE 0x0001
#define SF_SHAKE_DISRUPT 0x0002
#define SF_SHAKE_INAIR 0x0004
#define SF_FADE_IN 0x0001
#define SF_FADE_MODULATE 0x0002
#define SF_FADE_ONLYONE 0x0004
#define SF_SPRITE_STARTON 0x0001
#define SF_SPRITE_ONCE 0x0002
#define SF_SPRITE_TEMPORARY 0x8000
#define SF_MESSAGE_ONCE 0x0001 // Fade in, not out
#define SF_MESSAGE_ALL 0x0002 // Send to all clients
class CSprite: public CPointEntity
{
public:
virtual void Spawn();
virtual void Precache();
virtual void Restart();
2015-08-20 13:35:01 +03:00
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual int ObjectCaps()
{
int flags = 0;
if (pev->spawnflags & SF_SPRITE_TEMPORARY)
flags = FCAP_DONT_SAVE;
return (CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION) | flags;
}
2015-08-20 13:35:01 +03:00
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
void EXPORT AnimateThink();
void EXPORT ExpandThink();
2015-06-30 12:46:07 +03:00
2015-08-20 13:35:01 +03:00
void Animate(float frames);
void Expand(float scaleSpeed, float fadeSpeed);
2015-08-20 13:35:01 +03:00
void SpriteInit(const char *pSpriteName, const Vector &origin);
2015-06-30 12:46:07 +03:00
void SetAttachment(edict_t *pEntity, int attachment)
{
if (pEntity != NULL)
2015-06-30 12:46:07 +03:00
{
pev->skin = ENTINDEX(pEntity);
pev->body = attachment;
pev->aiment = pEntity;
pev->movetype = MOVETYPE_FOLLOW;
}
}
void TurnOff();
void TurnOn();
float Frames() const { return m_maxFrame; }
2015-06-30 12:46:07 +03:00
void SetTransparency(int rendermode, int r, int g, int b, int a, int fx)
{
pev->rendermode = rendermode;
pev->rendercolor.x = r;
pev->rendercolor.y = g;
pev->rendercolor.z = b;
pev->renderamt = a;
pev->renderfx = fx;
}
void SetTexture(int spriteIndex) { pev->modelindex = spriteIndex; }
void SetScale(float scale) { pev->scale = scale; }
void SetColor(int r, int g, int b) { pev->rendercolor.x = r; pev->rendercolor.y = g; pev->rendercolor.z = b; }
void SetBrightness(int brightness) { pev->renderamt = brightness; }
2015-09-16 23:19:21 +03:00
void AnimateAndDie(float_precision framerate)
2015-06-30 12:46:07 +03:00
{
SetThink(&CSprite::AnimateUntilDead);
pev->framerate = framerate;
pev->dmgtime = gpGlobals->time + (m_maxFrame / framerate);
pev->nextthink = gpGlobals->time;
}
void EXPORT AnimateUntilDead();
2015-08-20 13:35:01 +03:00
static CSprite *SpriteCreate(const char *pSpriteName, const Vector &origin, BOOL animate);
2015-06-30 12:46:07 +03:00
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[2];
2015-06-30 12:46:07 +03:00
private:
float m_lastTime;
float m_maxFrame;
};
2015-06-30 12:46:07 +03:00
class CBeam: public CBaseEntity
{
public:
virtual void Spawn();
virtual void Precache();
virtual int ObjectCaps()
2015-06-30 12:46:07 +03:00
{
int flags = 0;
if (pev->spawnflags & SF_BEAM_TEMPORARY)
flags = FCAP_DONT_SAVE;
2015-08-20 13:35:01 +03:00
return (CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION) | flags;
2015-06-30 12:46:07 +03:00
}
virtual Vector Center() { return (GetStartPos() + GetEndPos()) * 0.5f; }
2015-06-30 12:46:07 +03:00
public:
2015-08-20 13:35:01 +03:00
void EXPORT TriggerTouch(CBaseEntity *pOther);
2015-06-30 12:46:07 +03:00
void SetType(int type) { pev->rendermode = (pev->rendermode & 0xF0) | (type & 0x0F); }
void SetFlags(int flags) { pev->rendermode = (pev->rendermode & 0x0F) | (flags & 0xF0); }
void SetStartPos(const Vector &pos) { pev->origin = pos; }
void SetEndPos(const Vector &pos) { pev->angles = pos; }
2015-08-20 13:35:01 +03:00
void SetStartEntity(int entityIndex);
void SetEndEntity(int entityIndex);
2015-06-30 12:46:07 +03:00
void SetStartAttachment(int attachment) { pev->sequence = (pev->sequence & 0x0FFF) | ((attachment & 0xF) << 12); }
void SetEndAttachment(int attachment) { pev->skin = (pev->skin & 0x0FFF) | ((attachment & 0xF) << 12); }
void SetTexture(int spriteIndex) { pev->modelindex = spriteIndex; }
void SetWidth(int width) { pev->scale = width; }
void SetNoise(int amplitude) { pev->body = amplitude; }
void SetColor(int r, int g, int b) { pev->rendercolor.x = r; pev->rendercolor.y = g; pev->rendercolor.z = b; }
void SetBrightness(int brightness) { pev->renderamt = brightness; }
void SetFrame(float frame) { pev->frame = frame; }
void SetScrollRate(int speed) { pev->animtime = speed; }
int GetType() const { return pev->rendermode & 0x0F; }
int GetFlags() const { return pev->rendermode & 0xF0; }
int GetStartEntity() const { return pev->sequence & 0xFFF; }
int GetEndEntity() const { return pev->skin & 0xFFF; }
const Vector &GetStartPos();
const Vector &GetEndPos();
int GetTexture() const { return pev->modelindex; }
int GetWidth() const { return pev->scale; }
int GetNoise() const { return pev->body; }
int GetBrightness() const { return pev->renderamt; }
int GetFrame() const { return pev->frame; }
int GetScrollRate() const { return pev->animtime; }
void RelinkBeam();
2015-08-20 13:35:01 +03:00
void DoSparks(const Vector &start, const Vector &end);
CBaseEntity *RandomTargetname(const char *szName);
void BeamDamage(TraceResult *ptr);
void BeamInit(const char *pSpriteName, int width);
void PointsInit(const Vector &start, const Vector &end);
void PointEntInit(const Vector &start, int endIndex);
void EntsInit(int startIndex, int endIndex);
void HoseInit(const Vector &start, const Vector &direction);
2015-06-30 12:46:07 +03:00
2015-08-20 13:35:01 +03:00
static CBeam *BeamCreate(const char *pSpriteName, int width);
2015-06-30 12:46:07 +03:00
void LiveForTime(float time)
{
SetThink(&CBeam::SUB_Remove);
pev->nextthink = gpGlobals->time + time;
}
void BeamDamageInstant(TraceResult *ptr, float damage)
{
pev->dmg = damage;
pev->dmgtime = gpGlobals->time - 1;
BeamDamage(ptr);
}
};
2015-06-30 12:46:07 +03:00
class CLaser: public CBeam
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
void TurnOn();
void TurnOff();
int IsOn();
2015-06-30 12:46:07 +03:00
2015-08-20 13:35:01 +03:00
void FireAtPoint(TraceResult &point);
void EXPORT StrikeThink();
2015-06-30 12:46:07 +03:00
public:
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[3];
2015-06-30 12:46:07 +03:00
CSprite *m_pSprite;
int m_iszSpriteName;
Vector m_firePosition;
};
2015-06-30 12:46:07 +03:00
class CBubbling: public CBaseEntity
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual int ObjectCaps() { return (CBaseEntity::ObjectCaps() & ~FCAP_ACROSS_TRANSITION); }
2015-08-20 13:35:01 +03:00
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
void EXPORT FizzThink();
2015-06-30 12:46:07 +03:00
public:
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[3];
2015-06-30 12:46:07 +03:00
int m_density;
int m_frequency;
int m_bubbleModel;
int m_state;
};
2015-06-30 12:46:07 +03:00
class CLightning: public CBeam
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual void Activate();
2015-06-30 12:46:07 +03:00
public:
void EXPORT StrikeThink();
void EXPORT DamageThink();
void RandomArea();
2015-06-30 12:46:07 +03:00
void RandomPoint(Vector &vecSrc);
void Zap(const Vector &vecSrc, const Vector &vecDest);
void EXPORT StrikeUse(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
void EXPORT ToggleUse(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
inline BOOL ServerSide() const
2015-06-30 12:46:07 +03:00
{
2015-09-16 23:19:21 +03:00
if (!m_life && !(pev->spawnflags & SF_BEAM_RING))
return TRUE;
2015-06-30 12:46:07 +03:00
return FALSE;
}
void BeamUpdateVars();
2015-06-30 12:46:07 +03:00
public:
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[13];
2015-06-30 12:46:07 +03:00
int m_active;
int m_iszStartEntity;
int m_iszEndEntity;
float m_life;
int m_boltWidth;
int m_noiseAmplitude;
int m_brightness;
int m_speed;
float m_restrike;
int m_spriteTexture;
int m_iszSpriteName;
int m_frameStart;
float m_radius;
};
2015-06-30 12:46:07 +03:00
class CGlow: public CPointEntity
{
public:
virtual void Spawn();
2015-08-20 13:35:01 +03:00
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual void Think();
2015-06-30 12:46:07 +03:00
2015-08-20 13:35:01 +03:00
void Animate(float frames);
2015-06-30 12:46:07 +03:00
public:
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[2];
2015-06-30 12:46:07 +03:00
float m_lastTime;
float m_maxFrame;
};
2015-06-30 12:46:07 +03:00
class CBombGlow: public CSprite
{
public:
virtual void Spawn();
virtual void Think();
2015-06-30 12:46:07 +03:00
public:
float m_lastTime;
float m_tmBeepPeriod;
bool m_bSetModel;
};
2015-06-30 12:46:07 +03:00
2015-09-16 23:19:21 +03:00
class CGibShooter: public CBaseDelay
{
public:
virtual void Spawn();
virtual void Precache();
2015-06-30 12:46:07 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual int Save(CSave &save);
virtual int Restore(CRestore &restore);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
virtual CGib *CreateGib();
2015-06-30 12:46:07 +03:00
public:
void EXPORT ShootThink();
2015-06-30 12:46:07 +03:00
public:
2015-12-09 01:39:54 +03:00
static TYPEDESCRIPTION IMPL(m_SaveData)[7];
2015-06-30 12:46:07 +03:00
int m_iGibs;
int m_iGibCapacity;
int m_iGibMaterial;
int m_iGibModelIndex;
float m_flGibVelocity;
float m_flVariance;
2015-09-16 23:19:21 +03:00
float m_flGibLife;
};
2015-06-30 12:46:07 +03:00
class CEnvShooter: public CGibShooter
{
public:
virtual void Precache();
2015-06-30 12:46:07 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual CGib *CreateGib();
};
2015-06-30 12:46:07 +03:00
#define MAX_BEAM 24
class CTestEffect: public CBaseDelay
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
void EXPORT TestThink();
2015-06-30 12:46:07 +03:00
public:
int m_iLoop;
int m_iBeam;
CBeam *m_pBeam[ MAX_BEAM ];
2015-09-16 23:19:21 +03:00
2015-06-30 12:46:07 +03:00
float m_flBeamTime[ MAX_BEAM ];
float m_flStartTime;
};
2015-06-30 12:46:07 +03:00
class CBlood: public CPointEntity
{
public:
virtual void Spawn();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
int Color() const { return pev->impulse; }
float BloodAmount() const { return pev->dmg; }
void SetColor(int color) { pev->impulse = color; }
void SetBloodAmount(float amount) { pev->dmg = amount; }
2015-06-30 12:46:07 +03:00
public:
Vector Direction();
2015-06-30 12:46:07 +03:00
Vector BloodPosition(CBaseEntity *pActivator);
};
2015-06-30 12:46:07 +03:00
class CShake: public CPointEntity
{
public:
virtual void Spawn();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
float Amplitude() const { return pev->scale; }
float Frequency() const { return pev->dmg_save; }
float Duration() const { return pev->dmg_take; }
float Radius() const { return pev->dmg; }
2015-06-30 12:46:07 +03:00
void SetAmplitude(float amplitude) { pev->scale = amplitude; }
void SetFrequency(float frequency) { pev->dmg_save = frequency; }
void SetDuration(float duration) { pev->dmg_take = duration; }
void SetRadius(float radius) { pev->dmg = radius; }
};
2015-06-30 12:46:07 +03:00
class CFade: public CPointEntity
{
public:
virtual void Spawn();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
float Duration() const { return pev->dmg_take; }
float HoldTime() const { return pev->dmg_save; }
2015-06-30 12:46:07 +03:00
void SetDuration(float duration) { pev->dmg_take = duration; }
void SetHoldTime(float hold) { pev->dmg_save = hold; }
};
2015-06-30 12:46:07 +03:00
class CMessage: public CPointEntity
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void KeyValue(KeyValueData *pkvd);
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
};
2015-06-30 12:46:07 +03:00
class CEnvFunnel: public CBaseDelay
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
2015-06-30 12:46:07 +03:00
public:
int m_iSprite;
};
2015-06-30 12:46:07 +03:00
class CEnvBeverage: public CBaseDelay
{
public:
virtual void Spawn();
virtual void Precache();
2015-08-20 13:35:01 +03:00
virtual void Use(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value);
};
2015-06-30 12:46:07 +03:00
class CItemSoda: public CBaseEntity
{
public:
virtual void Spawn();
virtual void Precache();
2015-06-30 12:46:07 +03:00
public:
void EXPORT CanThink();
2015-06-30 12:46:07 +03:00
void EXPORT CanTouch(CBaseEntity *pOther);
};
2015-06-30 12:46:07 +03:00
2015-08-20 13:35:01 +03:00
int IsPointEntity(CBaseEntity *pEnt);
2015-06-30 12:46:07 +03:00
#endif // EFFECTS_H