// 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 "amxxmodule.h" #include "ns.h" #include "utilfunctions.h" #include "NEW_Util.h" #include "ParticleManager.h" #include <am-vector.h> #include <am-string.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); }