|
急需如下这样的插件,但是搜索论坛后有一个基本满足我的需求,可是1.5里面用不了:confused:
http://www.dt-club.net/forum/showthread.php?t=32254
上面这个就是找到的插件.希望能改进下,让1.5也兼容.
希望有高手改进下这个AMXMODX官方论坛上的插件.
下面的这个插件的作用是对指定的一个user赋予无限弹药和手雷(可以标记3种手雷)
amxx.cfg里的设置如下:
// a:HE Grenade; b:Smoke Grenade; c:Flashbang;
// Default value: a
ammo_nade_flags a使用时:
在console里输入amx_ammo <nick,#userid> <0|1>
0表示关闭,1表示打开
希望高手改进成如下形式:
1.使用时console输入
amx_ammo_user <nick,#userid>即可,原来是1(on)就改成0(off),原来是0(off)就改成1(on)
另外加上amx_ammo_all <0|1>
1表示打开所有人弹药无限,0表示关闭所有人弹药无限,但保留个人设置
2.使用时加上可以设定无限的内容,比如有4个标签0,a,b,c
a表示标记大枪弹药无限; b表示手枪弹药无限; c表示手雷无限;
使用时在amxx.cfg里标记;
比如:amx_ammo_flags abc表示三者都无限;amx_ammo_flags 0表示取消无限弹药
3.保留选择无限手雷类型的功能,不过,改下命令
a:HE Grenade; b:Smoke Grenade; c:Flashbang;
使用时:amx_ammon_gren abc
论坛的高手啊,帮帮小弟...
- [FONT=仿宋体]#include <amxmodx>
- #include <amxmisc>
- #include <engine>
- #include <cstrike>
- #include <fun>[/font]
- [FONT=仿宋体]#define PLUGIN "Unlimited Ammo"
- #define VERSION "0.3.1"
- #define AUTHOR "v3x"[/font]
- [FONT=仿宋体]#define HE_GRENADE (1<<0)
- #define SMOKE_GRENADE (1<<1)
- #define FLASH_GRENADE (1<<2)[/font]
- [FONT=仿宋体]new const USAGE[] = ": amx_ammo <nick,#userid> <0|1>";[/font]
- [FONT=仿宋体]new gCvar_flags;[/font]
- [FONT=仿宋体]public plugin_init()
- {
- register_plugin(PLUGIN , VERSION , AUTHOR);
- register_concmd("amx_ammo" , "concmd_Ammo" , ADMIN_LEVEL_A , USAGE);
- register_event("CurWeapon" , "event_CurWeapon" , "be" , "1=1");
- gCvar_flags = register_cvar("ammo_nade_flags" , "a");
- }[/font]
- [FONT=仿宋体]new bool:has_ammo[33];[/font]
- [FONT=仿宋体]public concmd_Ammo(id , lvl , cid)
- {
- if(!cmd_access(id , lvl , cid , 3))
- return PLUGIN_HANDLED;[/font]
- [FONT=仿宋体]static arg1[33] , arg2[8];
- read_argv(1 , arg1 , 32);
- read_argv(2 , arg2 , 7);[/font]
- [FONT=仿宋体]remove_quotes(arg2);[/font]
- [FONT=仿宋体]static pid;
- pid = cmd_target(id , arg1 , 0);[/font]
- [FONT=仿宋体]if(!pid)
- return PLUGIN_HANDLED;[/font]
- [FONT=仿宋体]if(equali(arg2 , "ON" , 2) || str_to_num(arg2) == 1)
- {
- if(!task_exists(id))
- set_task(0.3 , "check_for_nades" , id , _ , _ , "b");
- has_ammo[pid] = true;
- }
- else if(equali(arg2 , "OFF" , 2) || !str_to_num(arg2))
- {
- if(task_exists(id))
- remove_task(id);
- has_ammo[pid] = false;
- }
- else
- {
- console_print(id , "[AMXX] Usage%s" , USAGE);
- return PLUGIN_HANDLED;
- }[/font]
- [FONT=仿宋体]static pname1[33] , pname2[33];
- get_user_name(id , pname1 , 32);
- get_user_name(pid , pname2 , 32);[/font]
- [FONT=仿宋体]static s;
- s = has_ammo[pid];[/font]
- [FONT=仿宋体]switch(get_cvar_num("amx_show_activity"))
- {
- case 1: client_print(0 , print_chat , "ADMIN: %s unlimited ammo on %s" , s ? "Set" : "Unset" , pname2);
- case 2: client_print(0 , print_chat , "ADMIN %s: %s unlimited ammo on %s" , pname1 , s ? "Set" : "Unset" , pname2);
- }[/font]
- [FONT=仿宋体]return PLUGIN_HANDLED;
- }[/font]
- [FONT=仿宋体]public event_CurWeapon(id)
- {
- if(!is_user_alive(id))
- return PLUGIN_CONTINUE;[/font]
- [FONT=仿宋体]if(has_ammo[id])
- {
- static wpnid, clip;
- wpnid = read_data(2);
- clip = read_data(3);[/font]
- [FONT=仿宋体]give_ammo(id , wpnid , clip);
- }[/font]
- [FONT=仿宋体]return PLUGIN_CONTINUE;
- }[/font]
- [FONT=仿宋体]public client_connect(id)
- {
- has_ammo[id] = false;
- if(task_exists(id))
- remove_task(id);
- }[/font]
- [FONT=仿宋体]public client_disconnect(id)
- {
- has_ammo[id] = false;
- if(task_exists(id))
- remove_task(id);
- }[/font]
- [FONT=仿宋体]public give_ammo(id , wpnid , clip)
- {
- if(!is_user_alive(id))
- return;[/font]
- [FONT=仿宋体]if( wpnid==CSW_C4 ||
- wpnid==CSW_KNIFE ||
- wpnid==CSW_HEGRENADE ||
- wpnid==CSW_SMOKEGRENADE ||
- wpnid==CSW_FLASHBANG )
- return;[/font]
- [FONT=仿宋体]if(!clip)
- {
- static weapname[33];
- get_weaponname(wpnid , weapname , 32);[/font]
- [FONT=仿宋体]static wpn
- wpn = -1;
- while((wpn = find_ent_by_class(wpn , weapname)) != 0)
- {
- if(id == entity_get_edict(wpn , EV_ENT_owner))
- {
- cs_set_weapon_ammo(wpn , maxclip(wpnid))
- break;
- }
- }
- }
- }[/font]
- [FONT=仿宋体]public check_for_nades(id)
- {
- if(!is_user_alive(id))
- return;[/font]
- [FONT=仿宋体]if(nade_flags() & HE_GRENADE)
- {
- if(!user_has_weapon(id , CSW_HEGRENADE))
- give_item(id , "weapon_hegrenade");
- }
- if(nade_flags() & SMOKE_GRENADE)
- {
- if(!user_has_weapon(id , CSW_SMOKEGRENADE))
- give_item(id , "weapon_smokegrenade");
- }
- if(nade_flags() & FLASH_GRENADE)
- {
- if(!user_has_weapon(id , CSW_FLASHBANG))
- give_item(id , "weapon_flashbang");
- }
- }[/font]
- [FONT=仿宋体]// Taken from a superhero found on Google. Sorry, I don't know which one!
- stock maxclip(wpnid)
- {
- static ca;
- ca = 0;[/font]
- [FONT=仿宋体]switch (wpnid)
- {
- case CSW_P228 : ca = 13;
- case CSW_SCOUT : ca = 10;
- case CSW_HEGRENADE : ca = 0;
- case CSW_XM1014 : ca = 7;
- case CSW_C4 : ca = 0;
- case CSW_MAC10 : ca = 30;
- case CSW_AUG : ca = 30;
- case CSW_SMOKEGRENADE : ca = 0;
- case CSW_ELITE : ca = 15;
- case CSW_FIVESEVEN : ca = 20;
- case CSW_UMP45 : ca = 25;
- case CSW_SG550 : ca = 30;
- case CSW_GALI : ca = 35;
- case CSW_FAMAS : ca = 25;
- case CSW_USP : ca = 12;
- case CSW_GLOCK18 : ca = 20;
- case CSW_AWP : ca = 10;
- case CSW_MP5NAVY : ca = 30;
- case CSW_M249 : ca = 100;
- case CSW_M3 : ca = 8;
- case CSW_M4A1 : ca = 30;
- case CSW_TMP : ca = 30;
- case CSW_G3SG1 : ca = 20;
- case CSW_FLASHBANG : ca = 0;
- case CSW_DEAGLE : ca = 7;
- case CSW_SG552 : ca = 30;
- case CSW_AK47 : ca = 30;
- case CSW_P90 : ca = 50;
- }
- return ca;
- }[/font]
- [FONT=仿宋体]stock nade_flags()
- {
- static buffer[8];
- get_pcvar_string(gCvar_flags , buffer , 7);[/font]
- [FONT=仿宋体]return read_flags(buffer);
- }[/font]
复制代码 |
|