Seaside/SpyCustom/EventListener.hpp
2021-06-16 16:08:23 +03:00

407 lines
14 KiB
C++

#ifndef EVENTLISTEN
#define EVENTLISTEN
#pragma once
#pragma comment( lib, "Winmm.lib" )
#include "Interfaces.hpp"
#include "c_baseentity.h"
#include "Options.hpp"
struct bullet
{
bullet(int userID, Vector pos, int dmg, bool hs, float curtime)
{
this->userid = userid;
this->hs = hs;
this->curtime = curtime;
this->time = curtime + 0.0f;
this->pos = pos;
this->dmg = dmg;
}
int userid;
bool hs;
float time;
float curtime;
Vector pos;
int dmg;
};
std::vector<bullet> bulletdata;
#define PI 3.14159265
class EventListener : public IGameEventListener2
{
public:
EventListener()
{
if (!iff.g_pGameEvents->AddListener(this, "bullet_impact", false))
{
#ifdef DEBUG
std::cout << "Can't add listener bullet_impact\n";
#endif
}
if (!iff.g_pGameEvents->AddListener(this, "player_hurt", false))
{
#ifdef DEBUG
std::cout << "Can't add listener player_hurt\n";
#endif
}
if (!iff.g_pGameEvents->AddListener(this, "vote_cast", false))
{
#ifdef DEBUG
std::cout << "Can't add listener vote_cast\n";
#endif
}
if (!iff.g_pGameEvents->AddListener(this, "game_newmap", false))
{
#ifdef DEBUG
std::cout << "Can't add listener game_newmap\n";
#endif
}
#ifdef DEBUG
std::cout << "Event Listener created\n";
#endif
}
~EventListener()
{
iff.g_pGameEvents->RemoveListener(this);
}
int GetEventDebugID() override
{
return EVENT_DEBUG_ID_INIT;
}
virtual void FireGameEvent(IGameEvent* event)
{
if (*g_Options.hitmarker || *g_Options.hitsound) {
if (!strcmp(event->GetName(), "player_hurt"))
{
short hitgroup = event->GetInt("hitgroup");
short attacker = event->GetInt("attacker");
short userid = event->GetInt("userid");
short dmg_health = event->GetInt("dmg_health");
if (iff.g_pEngineClient->GetPlayerForUserID(attacker) == iff.g_pEngineClient->GetLocalPlayer()) {
int pid = iff.g_pEngineClient->GetPlayerForUserID(userid);
C_BasePlayer* pEntity = (C_BasePlayer*)iff.g_pEntityList->GetClientEntity(pid);
Vector pos = pEntity->GetBonePosition(8);
if (hitgroup == 1)
{
bool badInput = false;
int i_dec = 0;
if (*g_Options.hitsound) {
try
{
i_dec = std::stoi(g_Options.hspath.value->mystring);
}
catch (...)
{
badInput = true;
PlaySoundA(g_Options.hspath.value->mystring, NULL, SND_ASYNC);
}
if (!badInput && FindResource(opt.hModuleGlobal, MAKEINTRESOURCE(i_dec), "WAVE")) {
PlaySoundA((char*)i_dec, opt.hModuleGlobal, SND_RESOURCE | SND_ASYNC);
}
}
if (*g_Options.hitmarker)
bulletdata.push_back(bullet(userid, pos, dmg_health, 1, iff.g_pGlobals->curtime));
}
else
{
bool badInput = false;
int i_dec = 0;
if (*g_Options.hitsound) {
try
{
i_dec = std::stoi(g_Options.obpath.value->mystring);
}
catch (...)
{
badInput = true;
PlaySoundA(g_Options.obpath.value->mystring, NULL, SND_ASYNC);
}
if (!badInput && FindResource(opt.hModuleGlobal, MAKEINTRESOURCE(i_dec), "WAVE")) {
PlaySoundA((char*)i_dec, opt.hModuleGlobal, SND_RESOURCE | SND_ASYNC);
}
}
if (*g_Options.hitmarker)
bulletdata.push_back(bullet(userid, pos, dmg_health, 0, iff.g_pGlobals->curtime));
}
}
}
}
if (!strcmp(event->GetName(), "bullet_impact"))
{
short userid = event->GetInt("userid");
int localplayer = iff.g_pEngineClient->GetLocalPlayer();
if (iff.g_pEngineClient->GetPlayerForUserID(userid) == localplayer) {
float x = event->GetFloat("x");
float y = event->GetFloat("y");
float z = event->GetFloat("z");
C_BasePlayer* pEntity = (C_BasePlayer*)iff.g_pEntityList->GetClientEntity(localplayer);
Vector src = pEntity->GetOrigin() + pEntity->GetViewOffset();
Vector dst = { x,y,z };
Vector ang = pEntity->GetAngles();
ang.x -= 90.0f; ang.y -= 90.0f;
static float margin = 3.0f;
static float coeff = 1.5f;
src.x += cos(ang.x * PI / 180) * margin * sin(ang.y * PI / 180) + cos(ang.y * PI / 180) * margin * coeff;
src.y += -cos(ang.x * PI / 180) * margin * cos(ang.y * PI / 180) + sin(ang.y * PI / 180) * margin * coeff;
src.z += sin(ang.x * PI / 180) * margin;
if (*g_Options.beamtrace) {
BeamInfo_t beamInfo;
beamInfo.m_nType = *g_Options.beamtype;
beamInfo.m_pszModelName = g_Options.beampath.value->mystring;
beamInfo.m_nModelIndex = -1;
beamInfo.m_flHaloScale = 0.0f;
beamInfo.m_pStartEnt = pEntity;
beamInfo.m_pEndEnt = NULL;
beamInfo.m_vecEnd = dst;
beamInfo.m_vecStart = src;
beamInfo.m_flLife = *g_Options.beamlife;
beamInfo.m_flFadeLength = *g_Options.beamfadelength;
beamInfo.m_flAmplitude = *g_Options.beamamplitude;
beamInfo.m_nSegments = *g_Options.beamsegments;
beamInfo.m_bRenderable = true;
beamInfo.m_flSpeed = *g_Options.beamspeed;
beamInfo.m_nStartFrame = *g_Options.beamstartframe;
beamInfo.m_flFrameRate = *g_Options.beamframerate;
beamInfo.m_flWidth = *g_Options.beamwidth;
beamInfo.m_flEndWidth = *g_Options.beamwidth;
beamInfo.m_flBlue = g_Options.beamcolor.value->b * 255.0f;
beamInfo.m_flGreen = g_Options.beamcolor.value->g * 255.0f;
beamInfo.m_flRed = g_Options.beamcolor.value->r * 255.0f;
beamInfo.m_flBrightness = g_Options.beamcolor.value->a * 255.0f;
beamInfo.m_nFlags = *g_Options.beamflags;
Beam_t* myBeam = iff.g_pViewRenderBeams->CreateBeamPoints(beamInfo);
if (myBeam) iff.g_pViewRenderBeams->DrawBeam(myBeam);
else
{
}
}
if (*g_Options.attacheffects) {
switch (g_Options.effects.value->type) {
case 0:
{
switch (g_Options.effects.value->selectedc)
{
case 0:
{
iff.g_pEffects->Smoke(dst, -1, g_Options.effects.value->fx_fsize, g_Options.effects.value->fx_fspeed);
break;
}
case 2:
{
iff.g_pEffects->Dust(dst, Vector(0.0f, 0.0f, 1.0f), g_Options.effects.value->fx_fsize, g_Options.effects.value->fx_fspeed);
break;
}
case 1:
{
iff.g_pEffects->Sparks(dst, g_Options.effects.value->fx_magnitude, g_Options.effects.value->fx_traillength);
break;
}
case 3:
{
iff.g_pEffects->MuzzleFlash(dst, CalcAngle(dst, src), g_Options.effects.value->fx_fsize, g_Options.effects.value->fx_itype);
break;
}
case 4:
{
iff.g_pEffects->MetalSparks(dst, Vector( 0.0f, 0.0f, 0.0f ) );
break;
}
case 6:
{
iff.g_pEffects->Ricochet(dst, Vector(0.0f, 0.0f, 1.0f));
break;
}
case 5:
{
iff.g_pEffects->EnergySplash(dst, src, g_Options.effects.value->fx_bexplosive);
break;
}
}
break;
}
case 1:
{
CEffectData asscock;
asscock.m_fFlags = g_Options.effects.value->fflags;
asscock.m_vOrigin = dst;
asscock.m_vStart = src;
asscock.m_vNormal.Init(0.0f, 0.0f, 1.0f);
asscock.m_flScale = g_Options.effects.value->fscale;
asscock.m_nColor = g_Options.effects.value->icolors;
asscock.m_flMagnitude = g_Options.effects.value->fmagtinude;
asscock.m_flRadius = g_Options.effects.value->fradius;
iff.DispatchEffect(opt.DispatchEffect.at(g_Options.effects.value->selectedc).c_str(), asscock);
break;
}
case 2:
{
switch (g_Options.effects.value->selectedc)
{
case 0:
{
CTeslaInfo teslaInfo;
teslaInfo.m_flBeamWidth = g_Options.effects.value->fbeamwidth;
teslaInfo.m_flRadius = g_Options.effects.value->teslaradius;
teslaInfo.m_nEntIndex = -1;
teslaInfo.m_vColor.Init(g_Options.effects.value->teslacolor[0], g_Options.effects.value->teslacolor[1], g_Options.effects.value->teslacolor[2]);
teslaInfo.m_vPos = dst;
teslaInfo.m_flTimeVisible = g_Options.effects.value->fltimevisible;
teslaInfo.m_nBeams = g_Options.effects.value->ibeams;
teslaInfo.m_pszSpriteName = g_Options.effects.value->szSpriteName;
iff.FX_Tesla(teslaInfo);
break;
}
case 1:
{
dlight_t* pDlight = iff.g_pEfx->CL_AllocDlight(1);
pDlight->origin = dst;
pDlight->radius = g_Options.effects.value->frad;
pDlight->color.r = g_Options.effects.value->dlightcolor[0]*255.0f;
pDlight->color.g = g_Options.effects.value->dlightcolor[1] * 255.0f;
pDlight->color.b = g_Options.effects.value->dlightcolor[2] * 255.0f;
pDlight->color.exponent = 5;
pDlight->die = iff.g_pGlobals->curtime + g_Options.effects.value->fdie;
pDlight->decay = 0;
pDlight->key = g_Options.effects.value->key;
pDlight->style = g_Options.effects.value->style;
break;
}
}
break;
}
}
}
}
}
if (*g_Options.votereveal) {
if (!strcmp(event->GetName(), "vote_cast"))
{
int vote = event->GetInt("vote_option");
int id = event->GetInt("entityid");
if (iff.g_pChatElement)
{
player_info_t pinfo;
iff.g_pEngineClient->GetPlayerInfo(id, &pinfo);
if (pinfo.name) {
#ifdef DEBUG
printf("%s voted %d\n", pinfo.name, vote);
#endif
iff.g_pChatElement->ChatPrintf2(0, 0, std::string("").
append(" \x06").
append(pinfo.name).
append(" \x01").
append("voted").
append((vote == 0 ? std::string(" \x04").append("YES") : std::string(" \x02").append("NO"))).c_str());
}
}
}
}
if (!strcmp(event->GetName(), "game_newmap"))
{
#ifdef DEBUG
printf("game_newmap\n");
#endif
OnLevelInit();
}
}
};
#endif