ZombieManager: add zombie shield
This commit is contained in:
parent
24e4648b16
commit
2c0f31077c
@ -5,12 +5,18 @@
|
|||||||
#include <multicolors>
|
#include <multicolors>
|
||||||
#include <zombiereloaded>
|
#include <zombiereloaded>
|
||||||
#include <AFKManager>
|
#include <AFKManager>
|
||||||
|
#include <clientprefs>
|
||||||
#tryinclude <entWatch_core>
|
#tryinclude <entWatch_core>
|
||||||
|
|
||||||
bool g_bTestRound;
|
bool g_bTestRound;
|
||||||
bool g_bAdminTestRound;
|
bool g_bAdminTestRound;
|
||||||
bool g_bMotherZM[MAXPLAYERS + 1] = { false, ...};
|
bool g_bMotherZM[MAXPLAYERS + 1] = { false, ...};
|
||||||
|
|
||||||
|
bool g_bZHP[MAXPLAYERS + 1] = { false, ... };
|
||||||
|
Handle g_hCookieZHP = null;
|
||||||
|
int g_iZHPMax[MAXPLAYERS + 1];
|
||||||
|
int g_iZShield[MAXPLAYERS + 1];
|
||||||
|
|
||||||
bool g_Plugin_entWatch;
|
bool g_Plugin_entWatch;
|
||||||
|
|
||||||
int g_iAFKTime;
|
int g_iAFKTime;
|
||||||
@ -20,7 +26,7 @@ public Plugin myinfo =
|
|||||||
name = "Zombie Manager",
|
name = "Zombie Manager",
|
||||||
author = "Dogan",
|
author = "Dogan",
|
||||||
description = "Tools to manage testround and zombies",
|
description = "Tools to manage testround and zombies",
|
||||||
version = "1.3.0",
|
version = "2.0.0",
|
||||||
url = ""
|
url = ""
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -32,16 +38,22 @@ public void OnPluginStart()
|
|||||||
RegAdminCmd("sm_testround", Command_Testround, ADMFLAG_GENERIC, "Toggle to enable/disable a test round.");
|
RegAdminCmd("sm_testround", Command_Testround, ADMFLAG_GENERIC, "Toggle to enable/disable a test round.");
|
||||||
|
|
||||||
CreateTimer(20.0, Timer_MessageTestRound, _, TIMER_REPEAT);
|
CreateTimer(20.0, Timer_MessageTestRound, _, TIMER_REPEAT);
|
||||||
|
CreateTimer(0.2, Timer_HandleHPShield, _, TIMER_REPEAT); // health_regen_interval = 0.2
|
||||||
|
|
||||||
HookEvent("round_start", OnRoundStart);
|
HookEvent("round_start", OnRoundStart);
|
||||||
HookEvent("player_spawn", OnClientSpawn);
|
HookEvent("player_spawn", OnClientSpawn);
|
||||||
HookEvent("player_team", OnPlayerTeam);
|
HookEvent("player_team", OnPlayerTeam);
|
||||||
|
HookEvent("player_hurt", OnPlayerHurt);
|
||||||
|
|
||||||
ConVar cvar;
|
ConVar cvar;
|
||||||
HookConVarChange((cvar = CreateConVar("sm_player_afk_time", "120", "AFK Time in seconds after which a player won't turn into a motherzombie")), Cvar_AFKTime);
|
HookConVarChange((cvar = CreateConVar("sm_player_afk_time", "120", "AFK Time in seconds after which a player won't turn into a motherzombie")), Cvar_AFKTime);
|
||||||
g_iAFKTime = cvar.IntValue;
|
g_iAFKTime = cvar.IntValue;
|
||||||
delete cvar;
|
delete cvar;
|
||||||
|
|
||||||
|
RegConsoleCmd("sm_zhp", OnToggleZHP, "Toggle blocking Zombie HP and Shield display");
|
||||||
|
g_hCookieZHP = RegClientCookie("zhp_blocked", "are zombie hp and shield display blocked", CookieAccess_Protected);
|
||||||
|
SetCookieMenuItem(MenuHandler_CookieMenu, 0, "Zombie HP Shield Display");
|
||||||
|
|
||||||
AutoExecConfig(true, "plugin.ZombieManager");
|
AutoExecConfig(true, "plugin.ZombieManager");
|
||||||
|
|
||||||
AddMultiTargetFilter("@mzombie", Filter_Motherzombies, "Mother Zombies", false);
|
AddMultiTargetFilter("@mzombie", Filter_Motherzombies, "Mother Zombies", false);
|
||||||
@ -71,6 +83,93 @@ public void OnPluginEnd()
|
|||||||
RemoveMultiTargetFilter("@mzombie", Filter_Motherzombies);
|
RemoveMultiTargetFilter("@mzombie", Filter_Motherzombies);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Action OnToggleZHP(int client, int args)
|
||||||
|
{
|
||||||
|
ToggleZHP(client);
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ToggleZHP(int client)
|
||||||
|
{
|
||||||
|
g_bZHP[client] = !g_bZHP[client];
|
||||||
|
|
||||||
|
SetClientCookie(client, g_hCookieZHP, g_bZHP[client] ? "1" : "");
|
||||||
|
CPrintToChat(client, "{lightgreen}[ZR] {yellow}%s", g_bZHP[client] ? "Zombie HP and Shield display disabled." : "Zombie HP and Shield display enabled.");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnClientCookiesCached(int client)
|
||||||
|
{
|
||||||
|
char sBuffer[2];
|
||||||
|
|
||||||
|
GetClientCookie(client, g_hCookieZHP, sBuffer, sizeof(sBuffer));
|
||||||
|
if(sBuffer[0] != '\0')
|
||||||
|
g_bZHP[client] = true;
|
||||||
|
else
|
||||||
|
g_bZHP[client] = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnClientDisconnect(int client)
|
||||||
|
{
|
||||||
|
g_bZHP[client] = false;
|
||||||
|
g_iZHPMax[client] = 0;
|
||||||
|
g_iZShield[client] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ShowSettingsMenu(int client)
|
||||||
|
{
|
||||||
|
Menu menu = new Menu(MenuHandler_MainMenu);
|
||||||
|
|
||||||
|
menu.SetTitle("Zombie HP Shield Display Settings", client);
|
||||||
|
|
||||||
|
char sBuffer[128];
|
||||||
|
|
||||||
|
Format(sBuffer, sizeof(sBuffer), "Zombie HP and Shield Display: %s", g_bZHP[client] ? "Disabled" : "Enabled");
|
||||||
|
menu.AddItem("0", sBuffer);
|
||||||
|
|
||||||
|
menu.ExitBackButton = true;
|
||||||
|
|
||||||
|
menu.Display(client, MENU_TIME_FOREVER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void MenuHandler_CookieMenu(int client, CookieMenuAction action, any info, char[] buffer, int maxlen)
|
||||||
|
{
|
||||||
|
switch(action)
|
||||||
|
{
|
||||||
|
case(CookieMenuAction_DisplayOption):
|
||||||
|
{
|
||||||
|
Format(buffer, maxlen, "Zombie HP Shield Display", client);
|
||||||
|
}
|
||||||
|
case(CookieMenuAction_SelectOption):
|
||||||
|
{
|
||||||
|
ShowSettingsMenu(client);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int MenuHandler_MainMenu(Menu menu, MenuAction action, int client, int selection)
|
||||||
|
{
|
||||||
|
switch(action)
|
||||||
|
{
|
||||||
|
case(MenuAction_Select):
|
||||||
|
{
|
||||||
|
switch(selection)
|
||||||
|
{
|
||||||
|
case(0): ToggleZHP(client);
|
||||||
|
}
|
||||||
|
|
||||||
|
ShowSettingsMenu(client);
|
||||||
|
}
|
||||||
|
case(MenuAction_Cancel):
|
||||||
|
{
|
||||||
|
ShowCookieMenu(client);
|
||||||
|
}
|
||||||
|
case(MenuAction_End):
|
||||||
|
{
|
||||||
|
delete menu;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void Cvar_AFKTime(ConVar convar, const char[] oldValue, const char[] newValue)
|
public void Cvar_AFKTime(ConVar convar, const char[] oldValue, const char[] newValue)
|
||||||
{
|
{
|
||||||
g_iAFKTime = convar.IntValue;
|
g_iAFKTime = convar.IntValue;
|
||||||
@ -84,6 +183,8 @@ public void OnRoundStart(Event hEvent, const char[] sName, bool bDontBroadcast)
|
|||||||
for(int i = 1; i <= MaxClients; i++)
|
for(int i = 1; i <= MaxClients; i++)
|
||||||
{
|
{
|
||||||
g_bMotherZM[i] = false;
|
g_bMotherZM[i] = false;
|
||||||
|
g_iZHPMax[i] = 0;
|
||||||
|
g_iZShield[i] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -120,6 +221,8 @@ public Action ZR_OnClientMotherZombieEligible(int client)
|
|||||||
public void ZR_OnClientInfected(int client, int attacker, bool motherInfect, bool respawnOverride, bool respawn)
|
public void ZR_OnClientInfected(int client, int attacker, bool motherInfect, bool respawnOverride, bool respawn)
|
||||||
{
|
{
|
||||||
g_bMotherZM[client] = motherInfect;
|
g_bMotherZM[client] = motherInfect;
|
||||||
|
|
||||||
|
g_iZHPMax[client] = GetClientHealth(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action ZR_OnInfectCountdown()
|
public Action ZR_OnInfectCountdown()
|
||||||
@ -134,6 +237,7 @@ public void OnClientSpawn(Event hEvent, const char[] sName, bool bDontBroadcast)
|
|||||||
{
|
{
|
||||||
int client = GetClientOfUserId(hEvent.GetInt("userid"));
|
int client = GetClientOfUserId(hEvent.GetInt("userid"));
|
||||||
|
|
||||||
|
g_iZShield[client] = 0;
|
||||||
g_bMotherZM[client] = false;
|
g_bMotherZM[client] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,6 +248,23 @@ public Action OnPlayerTeam(Event event, const char[] name, bool dontBroadcast)
|
|||||||
g_bMotherZM[client] = false;
|
g_bMotherZM[client] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Action OnPlayerHurt(Event event, const char[] name, bool dontBroadcast)
|
||||||
|
{
|
||||||
|
int client = GetClientOfUserId(GetEventInt(event, "userid"));
|
||||||
|
int damage = GetEventInt(event, "dmg_health");
|
||||||
|
|
||||||
|
if(!IsClientInGame(client) || !IsPlayerAlive(client) || !ZR_IsClientZombie(client))
|
||||||
|
return Plugin_Continue;
|
||||||
|
|
||||||
|
if(g_iZShield[client] > 0)
|
||||||
|
{
|
||||||
|
g_iZShield[client] = g_iZShield[client] - damage;
|
||||||
|
SetEntityHealth(client, g_iZHPMax[client]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return Plugin_Continue;
|
||||||
|
}
|
||||||
|
|
||||||
public bool Filter_Motherzombies(const char[] sPattern, Handle hClients, int client)
|
public bool Filter_Motherzombies(const char[] sPattern, Handle hClients, int client)
|
||||||
{
|
{
|
||||||
for(int i = 1; i <= MaxClients; i++)
|
for(int i = 1; i <= MaxClients; i++)
|
||||||
@ -262,3 +383,47 @@ public Action Timer_MessageTestRound(Handle timer)
|
|||||||
|
|
||||||
return Plugin_Continue;
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Action Timer_HandleHPShield(Handle timer)
|
||||||
|
{
|
||||||
|
char sNemesis[32];
|
||||||
|
GetConVarString(FindConVar("sm_info_message_file"), sNemesis, sizeof(sNemesis));
|
||||||
|
bool bNemesis = StrEqual(sNemesis, "nemesis");
|
||||||
|
|
||||||
|
for(int i = 1; i <= MaxClients; i++)
|
||||||
|
{
|
||||||
|
if(!IsClientInGame(i) || !IsPlayerAlive(i) || !ZR_IsClientZombie(i))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
bool bHasItem;
|
||||||
|
#if defined entWatch_core_included
|
||||||
|
if(g_Plugin_entWatch)
|
||||||
|
bHasItem = EW_ClientHasItem(i);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if(bHasItem)
|
||||||
|
g_iZShield[i] = 0; //zombies with items
|
||||||
|
else if(GetClientHealth(i) >= g_iZHPMax[i] && bNemesis)
|
||||||
|
g_iZShield[i] = 0; //disable for now on nemesis
|
||||||
|
//g_iZShield[i] = g_iZShield[i] + 12; // health_regen_amount = 12
|
||||||
|
else if(GetClientHealth(i) >= g_iZHPMax[i] && !bNemesis)
|
||||||
|
g_iZShield[i] = g_iZShield[i] + 6; // health_regen_amount = 6
|
||||||
|
|
||||||
|
UpdateHintMessage(i, bHasItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
return Plugin_Continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void UpdateHintMessage(int client, bool bHasItem)
|
||||||
|
{
|
||||||
|
bool bVote = IsVoteInProgress();
|
||||||
|
|
||||||
|
if(g_bZHP[client] || bVote)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(g_iZShield[client] <= 0 || bHasItem)
|
||||||
|
PrintHintText(client, "HP: %d - Shield: none", GetClientHealth(client));
|
||||||
|
else
|
||||||
|
PrintHintText(client, "HP: %d - Shield: %d", GetClientHealth(client), g_iZShield[client]);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user