mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2024-12-27 07:15:37 +03:00
257 lines
7.2 KiB
C++
257 lines
7.2 KiB
C++
// vim: set ts=4 sw=4 tw=99 noet:
|
|
//
|
|
// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO").
|
|
// Copyright (C) The AMX Mod X Development Team.
|
|
//
|
|
// This software is licensed under the GNU General Public License, version 3 or higher.
|
|
// Additional exceptions apply. For full license details, see LICENSE.txt or visit:
|
|
// https://alliedmods.net/amxmodx-license
|
|
|
|
//
|
|
// Natural Selection Module
|
|
//
|
|
|
|
#include "../sdk/amxxmodule.h"
|
|
|
|
#include "../ns.h"
|
|
#include "../utilfunctions.h"
|
|
#include "../NEW_Util.h"
|
|
|
|
#include "../CVector.h"
|
|
#include "../CString.h"
|
|
#include "../ParticleManager.h"
|
|
|
|
#define KVI(__KEY) PSKeyValueI(__KEY,amx,params)
|
|
#define KVF(__KEY) PSKeyValueF(__KEY,amx,params)
|
|
#define KVS(__KEY) PSKeyValueS(__KEY,amx,params)
|
|
#define NEXT params[__pcount++]
|
|
|
|
typedef enum partsystype_e
|
|
{
|
|
PSYS_TYPE_INT,
|
|
PSYS_TYPE_FLOAT,
|
|
PSYS_TYPE_STRING
|
|
}partsystype;
|
|
typedef struct partsyskey_s
|
|
{
|
|
const char *Name;
|
|
partsystype type;
|
|
}partsyskey;
|
|
|
|
cell PSKeyValueI(const char *name, AMX *amx, cell *params)
|
|
{
|
|
if (params[1]==0)
|
|
{
|
|
MF_LogError(amx,AMX_ERR_NATIVE,"Invalid particle system handle provided!");
|
|
return 0;
|
|
}
|
|
KeyValueData kvd;
|
|
|
|
char StrData[1024];
|
|
|
|
UTIL_Format(StrData, sizeof(StrData)-1, "%d", params[2]);
|
|
|
|
kvd.szClassName=const_cast<char *>(STRING(reinterpret_cast<edict_t *>(params[1])->v.classname));
|
|
kvd.szKeyName=name;
|
|
kvd.szValue=&StrData[0];
|
|
kvd.fHandled=0;
|
|
//printf("\"%s\" \"%s\"\n",kvd.szKeyName,kvd.szValue);
|
|
|
|
MDLL_KeyValue(reinterpret_cast<edict_t *>(params[1]),&kvd);
|
|
|
|
return 1;
|
|
}
|
|
cell PSKeyValueF(const char *name, AMX *amx, cell *params)
|
|
{
|
|
if (params[1]==0)
|
|
{
|
|
MF_LogError(amx,AMX_ERR_NATIVE,"Invalid particle system handle provided!");
|
|
return 0;
|
|
}
|
|
KeyValueData kvd;
|
|
|
|
char StrData[1024];
|
|
|
|
UTIL_Format(StrData, sizeof(StrData)-1, "%f", amx_ctof2(params[2]));
|
|
|
|
kvd.szClassName=const_cast<char *>(STRING(reinterpret_cast<edict_t *>(params[1])->v.classname));
|
|
kvd.szKeyName=name;
|
|
kvd.szValue=&StrData[0];
|
|
kvd.fHandled=0;
|
|
|
|
//printf("\"%s\" \"%s\"\n",kvd.szKeyName,kvd.szValue);
|
|
|
|
MDLL_KeyValue(reinterpret_cast<edict_t *>(params[1]),&kvd);
|
|
|
|
return 1;
|
|
|
|
}
|
|
cell PSKeyValueS(const char *name, AMX *amx, cell *params)
|
|
{
|
|
if (params[1]==0)
|
|
{
|
|
MF_LogError(amx,AMX_ERR_NATIVE,"Invalid particle system handle provided!");
|
|
return 0;
|
|
}
|
|
KeyValueData kvd;
|
|
|
|
kvd.szClassName=const_cast<char *>(STRING(reinterpret_cast<edict_t *>(params[1])->v.classname));
|
|
kvd.szKeyName=name;
|
|
kvd.szValue=MF_GetAmxString(amx,params[2],0,NULL);
|
|
kvd.fHandled=0;
|
|
//printf("\"%s\" \"%s\"\n",kvd.szKeyName,kvd.szValue);
|
|
|
|
MDLL_KeyValue(reinterpret_cast<edict_t *>(params[1]),&kvd);
|
|
|
|
return 1;
|
|
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_name(AMX *amx, cell *params)
|
|
{
|
|
return KVS("targetname");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_sprite(AMX *amx, cell *params)
|
|
{
|
|
return KVS("pSprite");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_genrate(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pGenRate");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_genshape(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pGenShape");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_genshape_params(AMX *amx, cell *params)
|
|
{
|
|
return KVS("pGenShapeParams");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_spriteframes(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pSpriteNumFrames");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_numparticles(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pNumParticles");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_size(AMX *amx, cell *params)
|
|
{
|
|
return KVF("pSize");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_vel_params(AMX *amx, cell *params)
|
|
{
|
|
return KVS("pVelParams");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_vel_shape(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pVelShape");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_sys_life(AMX *amx, cell *params)
|
|
{
|
|
return KVF("pSystemLifetime");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_particle_life(AMX *amx, cell *params)
|
|
{
|
|
return KVF("pLifetime");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_rendermode(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pRenderMode");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_to_gen(AMX *amx, cell *params)
|
|
{
|
|
return KVS("pPSToGen");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_anim_speed(AMX *amx, cell *params)
|
|
{
|
|
return KVI("pAnimationSpeed");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_spawn_flags(AMX *amx, cell *params)
|
|
{
|
|
return KVI("spawnflags");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_base_color(AMX *amx, cell *params)
|
|
{
|
|
return KVS("pBaseColor");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_scale(AMX *amx, cell *params)
|
|
{
|
|
return KVF("pScale");
|
|
}
|
|
static cell AMX_NATIVE_CALL ns_set_ps_max_alpha(AMX *amx, cell *params)
|
|
{
|
|
return KVF("pMaxAlpha");
|
|
}
|
|
// ns_create_partsys(const name[], pGenShape, const pGenShapeParams[], pGenRate, const pSprite[],
|
|
// pSpriteFrames, pNumParticles, Float:pSize, const pVelParams[], pVelShape,
|
|
// Float:pSystemLifetime, Float:pParticleLifetime, pRenderMode, const pPSToGen[], pAnimationSpeed, pSpawnFlags)
|
|
static cell AMX_NATIVE_CALL ns_create_partsys(AMX *amx, cell *params)
|
|
{
|
|
return (cell)CREATE_NAMED_ENTITY(MAKE_STRING("env_particles_custom"));
|
|
};
|
|
static cell AMX_NATIVE_CALL ns_spawn_ps(AMX *amx, cell *params)
|
|
{
|
|
if (params[1]==0)
|
|
{
|
|
MF_LogError(amx, AMX_ERR_NATIVE, "Invalid particle system handle");
|
|
return 0;
|
|
}
|
|
|
|
edict_t *Ent=reinterpret_cast<edict_t *>(params[1]);
|
|
MDLL_Spawn(Ent);
|
|
|
|
if (!Ent->free)
|
|
{
|
|
REMOVE_ENTITY(Ent);
|
|
}
|
|
return ParticleMan.Add(STRING(Ent->v.targetname),0);
|
|
}
|
|
// ns_fire_ps(Particle:id,Float:origin[3],Float:angles[3],flags=0)
|
|
static cell AMX_NATIVE_CALL ns_fire_partsys(AMX *amx, cell *params)
|
|
{
|
|
float *origin=(float*)MF_GetAmxAddr(amx,params[2]);
|
|
float *angles=(float*)MF_GetAmxAddr(amx,params[3]);
|
|
|
|
ParticleMan.FireSystem(static_cast<int>(params[1]),origin,angles,static_cast<int>(params[4]));
|
|
|
|
return 0;
|
|
};
|
|
|
|
static cell AMX_NATIVE_CALL ns_get_partsys_id(AMX *amx, cell *params)
|
|
{
|
|
return ParticleMan.Find(MF_GetAmxString(amx,params[1],0,NULL));;
|
|
};
|
|
|
|
AMX_NATIVE_INFO particle_natives[] = {
|
|
{ "ns_create_ps", ns_create_partsys },
|
|
{ "ns_set_ps_name", ns_set_ps_name },
|
|
{ "ns_set_ps_sprite", ns_set_ps_sprite },
|
|
{ "ns_set_ps_genrate", ns_set_ps_genrate },
|
|
{ "ns_set_ps_genshape", ns_set_ps_genshape },
|
|
{ "ns_set_ps_genshape_params", ns_set_ps_genshape_params },
|
|
{ "ns_set_ps_spriteframes", ns_set_ps_spriteframes },
|
|
{ "ns_set_ps_numparticles", ns_set_ps_numparticles },
|
|
{ "ns_set_ps_size", ns_set_ps_size },
|
|
{ "ns_set_ps_vel_params", ns_set_ps_vel_params },
|
|
{ "ns_set_ps_vel_shape", ns_set_ps_vel_shape },
|
|
{ "ns_set_ps_sys_life", ns_set_ps_sys_life },
|
|
{ "ns_set_ps_particle_life", ns_set_ps_particle_life },
|
|
{ "ns_set_ps_rendermode", ns_set_ps_rendermode },
|
|
{ "ns_set_ps_to_gen", ns_set_ps_to_gen },
|
|
{ "ns_set_ps_anim_speed", ns_set_ps_anim_speed },
|
|
{ "ns_set_ps_spawn_flags", ns_set_ps_spawn_flags },
|
|
{ "ns_set_ps_base_color", ns_set_ps_base_color },
|
|
{ "ns_set_ps_scale", ns_set_ps_scale },
|
|
{ "ns_set_ps_max_alpha", ns_set_ps_max_alpha },
|
|
{ "ns_spawn_ps", ns_spawn_ps },
|
|
|
|
{ "ns_fire_ps", ns_fire_partsys },
|
|
{ "ns_get_ps_id", ns_get_partsys_id },
|
|
|
|
{ NULL, NULL }
|
|
};
|
|
void AddNatives_Particles()
|
|
{
|
|
MF_AddNatives(particle_natives);
|
|
}
|