updated icecap plugins so its not interfering with ztele and events. also made zombie hunting plugin aln always active

This commit is contained in:
jenz 2024-08-01 20:24:16 +02:00
parent 983652c974
commit f420bfc7ed
2 changed files with 391 additions and 260 deletions

View File

@ -51,17 +51,14 @@ public void OnPluginStart()
public Action Command_ztele(int client, const char[] Command, int Args) public Action Command_ztele(int client, const char[] Command, int Args)
{ {
if (!g_b_is_icecap_act2) if (g_b_is_icecap_act2)
{ {
return Plugin_Handled;
}
if (IsValidClient(client)) if (IsValidClient(client))
{ {
int userid = GetClientUserId(client); int userid = GetClientUserId(client);
ServerCommand("sm_forceinputplayer #%i Clearparent", userid); ServerCommand("sm_forceinputplayer #%i Clearparent", userid);
} }
return Plugin_Handled; }
} }
public void OnClientPostAdminCheck(int client) public void OnClientPostAdminCheck(int client)
@ -78,25 +75,23 @@ stock bool IsValidClient(int client)
//right before round end deactivate gameUI and unparent players from moving vehicles. //right before round end deactivate gameUI and unparent players from moving vehicles.
public void OnRoundEnd(Handle event, const char[] name, bool dontBroadcast) public void OnRoundEnd(Handle event, const char[] name, bool dontBroadcast)
{ {
if (!g_b_is_icecap_act2) if (g_b_is_icecap_act2)
{ {
return;
}
//its the correct map if it contains icecap_escape_act2 //its the correct map if it contains icecap_escape_act2
ServerCommand("sm_forceinput Game Deactivate; sm_forceinput Game2 Deactivate;sm_forceinput Game3 Deactivate;sm_forceinput Game4 Deactivate; sm_forceinput Gameleft Deactivate; sm_forceinput Gameright Deactivate; sm_forceinput Gameseat Deactivate; sm_forceinput Gameseat2 Deactivate; sm_forceinput Gameseat3 Deactivate; sm_forceinput Gameseat4 Deactivate; sm_forceinput Gameseat5 Deactivate; sm_forceinput Gameseat6 Deactivate;"); ServerCommand("sm_forceinput Game Deactivate; sm_forceinput Game2 Deactivate;sm_forceinput Game3 Deactivate;sm_forceinput Game4 Deactivate; sm_forceinput Gameleft Deactivate; sm_forceinput Gameright Deactivate; sm_forceinput Gameseat Deactivate; sm_forceinput Gameseat2 Deactivate; sm_forceinput Gameseat3 Deactivate; sm_forceinput Gameseat4 Deactivate; sm_forceinput Gameseat5 Deactivate; sm_forceinput Gameseat6 Deactivate;");
ServerCommand("sm_forceinput player Clearparent;"); ServerCommand("sm_forceinput player Clearparent;");
ServerCommand("sm_forceinput heli kill; sm_forceinput moblie kill; sm_forceinput car kill; sm_forceinput battery kill;"); ServerCommand("sm_forceinput heli kill; sm_forceinput moblie kill; sm_forceinput car kill; sm_forceinput battery kill;");
}
} }
public void trigger_teleport(const char[] output, int entity_index, int client, float delay) public void trigger_teleport(const char[] output, int entity_index, int client, float delay)
{ {
if (!g_b_is_icecap_act2) if (g_b_is_icecap_act2)
{ {
return;
}
if (IsValidClient(client)) if (IsValidClient(client))
{ {
int userid = GetClientUserId(client); int userid = GetClientUserId(client);
ServerCommand("sm_forceinputplayer #%i Clearparent", userid); ServerCommand("sm_forceinputplayer #%i Clearparent", userid);
} }
}
} }

View File

@ -19,6 +19,8 @@ int ping_ents[MAXPLAYERS + 1];
int g_iAnnounce_zone_controll = 0; int g_iAnnounce_zone_controll = 0;
bool g_permit_zone_benefits = false; bool g_permit_zone_benefits = false;
bool g_is_zh_map = false;
bool round_start_delay; bool round_start_delay;
//spawning the markers //spawning the markers
@ -78,6 +80,8 @@ public void OnPluginStart()
public Action announce_zone_controlls(Handle hTimer) public Action announce_zone_controlls(Handle hTimer)
{ {
if (g_is_zh_map)
{
float fought_zone = 0.0; float fought_zone = 0.0;
float ct_controlled_zone = 0.0; float ct_controlled_zone = 0.0;
float zm_controlled_zone = 0.0; float zm_controlled_zone = 0.0;
@ -182,26 +186,39 @@ public Action announce_zone_controlls(Handle hTimer)
{ {
g_iAnnounce_zone_controll = 0; g_iAnnounce_zone_controll = 0;
} }
}
return Plugin_Handled; return Plugin_Handled;
} }
public void OnClientPutInServer(int client) public void OnClientPutInServer(int client)
{ {
if (g_is_zh_map)
{
SDKHook(client, SDKHook_OnTakeDamage, OnTakeDamage); SDKHook(client, SDKHook_OnTakeDamage, OnTakeDamage);
}
} }
public Action OnTakeDamage(int client, int &attacker, int &inflictor, float &damage, int &damagetype) public Action OnTakeDamage(int client, int &attacker, int &inflictor, float &damage, int &damagetype)
{ {
if (g_is_zh_map)
{
if (IsValidClient(attacker) && GetClientTeam(attacker) == CS_TEAM_CT && g_human_damage_addition != 1.0) if (IsValidClient(attacker) && GetClientTeam(attacker) == CS_TEAM_CT && g_human_damage_addition != 1.0)
{ {
damage += (g_human_damage_addition * damage); damage += (g_human_damage_addition * damage);
return Plugin_Changed; return Plugin_Changed;
} }
}
return Plugin_Continue; return Plugin_Continue;
} }
public Action give_zm_zone_boosts(Handle hTimer) public Action give_zm_zone_boosts(Handle hTimer)
{ {
if (!g_is_zh_map)
{
return Plugin_Handled;
}
for (int client; client < MaxClients; client++) for (int client; client < MaxClients; client++)
{ {
if (IsValidClient(client) && IsPlayerAlive(client) && GetClientTeam(client) == CS_TEAM_T) if (IsValidClient(client) && IsPlayerAlive(client) && GetClientTeam(client) == CS_TEAM_T)
@ -238,16 +255,23 @@ public void OnPluginEnd()
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
public void OnClientDisconnect(int client) public void OnClientDisconnect(int client)
{ {
if (g_is_zh_map)
{
g_iCT_Damage_in_zone[client] = 0; g_iCT_Damage_in_zone[client] = 0;
client_target[client] = 0; client_target[client] = 0;
g_client_in_zone[client] = -1; g_client_in_zone[client] = -1;
adjust_clients(); //calling GetClientTeam inside adjust_clients complaints that client already disconnected. adjust_clients(); //calling GetClientTeam inside adjust_clients complaints that client already disconnected.
g_bBlockRespawn[client] = 0; g_bBlockRespawn[client] = 0;
SDKUnhook(client, SDKHook_OnTakeDamage, OnTakeDamage); SDKUnhook(client, SDKHook_OnTakeDamage, OnTakeDamage);
}
} }
public void adjust_clients() public void adjust_clients()
{ {
if (!g_is_zh_map)
{
return;
}
for (int i = 0; i < MAXZONES; i++) for (int i = 0; i < MAXZONES; i++)
{ {
g_cZones_CT_count[i] = 0; g_cZones_CT_count[i] = 0;
@ -276,6 +300,8 @@ public void adjust_clients()
public void OnRoundEnd(Event hEvent, const char[] sEvent, bool bDontBroadcast) public void OnRoundEnd(Event hEvent, const char[] sEvent, bool bDontBroadcast)
{ {
if (g_is_zh_map)
{
if(g_hZoneBenefits != INVALID_HANDLE) if(g_hZoneBenefits != INVALID_HANDLE)
{ {
KillTimer(g_hZoneBenefits); KillTimer(g_hZoneBenefits);
@ -304,10 +330,15 @@ public void OnRoundEnd(Event hEvent, const char[] sEvent, bool bDontBroadcast)
PrintToChatAll("Humans failed!"); PrintToChatAll("Humans failed!");
PrintToChatAll("Humans failed!"); PrintToChatAll("Humans failed!");
} }
}
} }
public Action permit_zone_benefits(Handle hTimer) public Action permit_zone_benefits(Handle hTimer)
{ {
if (!g_is_zh_map)
{
return Plugin_Handled;
}
g_permit_zone_benefits = true; g_permit_zone_benefits = true;
return Plugin_Handled; return Plugin_Handled;
} }
@ -317,6 +348,8 @@ public Action permit_zone_benefits(Handle hTimer)
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
public void OnRoundStart(Event hEvent, const char[] sEvent, bool bDontBroadcast) public void OnRoundStart(Event hEvent, const char[] sEvent, bool bDontBroadcast)
{ {
if (g_is_zh_map)
{
g_permit_zone_benefits = false; g_permit_zone_benefits = false;
g_hZoneBenefits = CreateTimer(35.0, permit_zone_benefits); g_hZoneBenefits = CreateTimer(35.0, permit_zone_benefits);
g_human_damage_addition = 1.0; g_human_damage_addition = 1.0;
@ -339,10 +372,15 @@ public void OnRoundStart(Event hEvent, const char[] sEvent, bool bDontBroadcast)
} }
round_start_delay = true; round_start_delay = true;
CreateTimer(5.0, enable_pings); CreateTimer(5.0, enable_pings);
}
} }
public Action enable_pings(Handle timer, any data) public Action enable_pings(Handle timer, any data)
{ {
if (!g_is_zh_map)
{
return Plugin_Handled;
}
round_start_delay = false; round_start_delay = false;
return Plugin_Handled; return Plugin_Handled;
} }
@ -352,6 +390,8 @@ public Action enable_pings(Handle timer, any data)
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
public void OnClientDeath(Event hEvent, const char[] sEvent, bool bDontBroadcast) public void OnClientDeath(Event hEvent, const char[] sEvent, bool bDontBroadcast)
{ {
if (g_is_zh_map)
{
int victim = GetClientOfUserId(hEvent.GetInt("userid")); int victim = GetClientOfUserId(hEvent.GetInt("userid"));
g_client_in_zone[victim] = -1; g_client_in_zone[victim] = -1;
adjust_clients(); adjust_clients();
@ -360,10 +400,13 @@ public void OnClientDeath(Event hEvent, const char[] sEvent, bool bDontBroadcast
return; return;
PrintToChat(victim, "\x04[ZR]\x01 You have %i respawns left for this round.", g_hRespawnTreshold.IntValue - g_bBlockRespawn[victim]); PrintToChat(victim, "\x04[ZR]\x01 You have %i respawns left for this round.", g_hRespawnTreshold.IntValue - g_bBlockRespawn[victim]);
g_bBlockRespawn[victim]++; g_bBlockRespawn[victim]++;
}
} }
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)
{ {
if (g_is_zh_map)
{
int index = g_client_in_zone[client]; int index = g_client_in_zone[client];
if (index != -1) if (index != -1)
{ {
@ -375,6 +418,7 @@ public void ZR_OnClientInfected(int client, int attacker, bool motherInfect, boo
g_cZones_ZM_count[index]++; g_cZones_ZM_count[index]++;
UpdateMarkers(); UpdateMarkers();
} }
}
} }
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
@ -390,6 +434,10 @@ stock bool IsValidClient(int client)
public float get_power_distance(int target_player, float pos[3]) public float get_power_distance(int target_player, float pos[3])
{ {
if (!g_is_zh_map)
{
return 0.0;
}
float vec[3]; float vec[3];
GetClientAbsOrigin(target_player, vec); GetClientAbsOrigin(target_player, vec);
return GetVectorDistance(vec, pos); return GetVectorDistance(vec, pos);
@ -397,14 +445,21 @@ public float get_power_distance(int target_player, float pos[3])
public Action ZR_OnClientRespawn(&client, &ZR_RespawnCondition:condition) public Action ZR_OnClientRespawn(&client, &ZR_RespawnCondition:condition)
{ {
if (g_is_zh_map)
{
if (g_bBlockRespawn[client] > g_hRespawnTreshold.IntValue) if (g_bBlockRespawn[client] > g_hRespawnTreshold.IntValue)
return Plugin_Handled; return Plugin_Handled;
find_teleport_target(client); find_teleport_target(client);
}
return Plugin_Continue; return Plugin_Continue;
} }
public void find_teleport_target(int client) public void find_teleport_target(int client)
{ {
if (!g_is_zh_map)
{
return;
}
//teleport player to team members with farthest distance to enemy just. //teleport player to team members with farthest distance to enemy just.
//checking all alive clients to determine which client has highest dist_target to its closest enemy //checking all alive clients to determine which client has highest dist_target to its closest enemy
float total_furthest_distance = -1.0; float total_furthest_distance = -1.0;
@ -472,13 +527,20 @@ public bool TraceRayHitOnlyEnt(int entityhit, int mask, any data) {
public void OnClientPostAdminCheck(int client) public void OnClientPostAdminCheck(int client)
{ {
if (g_is_zh_map)
{
g_iCT_Damage_in_zone[client] = 0; g_iCT_Damage_in_zone[client] = 0;
client_target[client] = 0; client_target[client] = 0;
g_client_in_zone[client] = -1; g_client_in_zone[client] = -1;
}
} }
public Action tp_client(Handle timer, int client) public Action tp_client(Handle timer, int client)
{ {
if (!g_is_zh_map)
{
return Plugin_Handled;
}
if (IsValidClient(client) && IsValidClient(client_target[client])) if (IsValidClient(client) && IsValidClient(client_target[client]))
{ {
float posd[3]; float posd[3];
@ -492,6 +554,8 @@ public Action tp_client(Handle timer, int client)
public void unloze_zoneLeave(int client, char[] zone) public void unloze_zoneLeave(int client, char[] zone)
{ {
if (g_is_zh_map)
{
int index = g_client_in_zone[client]; int index = g_client_in_zone[client];
if (index < 0) if (index < 0)
{ {
@ -516,15 +580,23 @@ public void unloze_zoneLeave(int client, char[] zone)
} }
SetEntityRenderColor(client, 255, 255, 255, 255); SetEntityRenderColor(client, 255, 255, 255, 255);
UpdateMarkers(); UpdateMarkers();
}
} }
public void unloze_zoneCreated() public void unloze_zoneCreated()
{ {
if (g_is_zh_map)
{
ReadZoneFile(); ReadZoneFile();
}
} }
public Action retry_zoneEntry(Handle timer, DataPack data) public Action retry_zoneEntry(Handle timer, DataPack data)
{ {
if (!g_is_zh_map)
{
return Plugin_Handled;
}
ResetPack(data); ResetPack(data);
char zone[256]; char zone[256];
data.ReadString(zone, sizeof(zone)); data.ReadString(zone, sizeof(zone));
@ -542,6 +614,8 @@ public Action retry_zoneEntry(Handle timer, DataPack data)
public void unloze_zoneEntry(int client, char[] zone) public void unloze_zoneEntry(int client, char[] zone)
{ {
if (g_is_zh_map)
{
int index = -1; int index = -1;
//unfortunately it can happen that a zone is entered before the current one is left, which can lead to -1 index //unfortunately it can happen that a zone is entered before the current one is left, which can lead to -1 index
//when leaving the zone again. //when leaving the zone again.
@ -579,10 +653,15 @@ public void unloze_zoneEntry(int client, char[] zone)
g_iLast_Client_In_Zone[index] = client; g_iLast_Client_In_Zone[index] = client;
display_hud_text(index, client); display_hud_text(index, client);
UpdateMarkers(); UpdateMarkers();
}
} }
public void handle_pings(int i, int pingtype) public void handle_pings(int i, int pingtype)
{ {
if (!g_is_zh_map)
{
return;
}
if (round_start_delay) if (round_start_delay)
{ {
return; //preventing pings from spawning exactly on roundStart as it might cause too many entities return; //preventing pings from spawning exactly on roundStart as it might cause too many entities
@ -604,6 +683,10 @@ public void handle_pings(int i, int pingtype)
public void display_hud_text(int index, int client) public void display_hud_text(int index, int client)
{ {
if (!g_is_zh_map)
{
return;
}
if (hText != INVALID_HANDLE) if (hText != INVALID_HANDLE)
{ {
char msg[256]; char msg[256];
@ -635,6 +718,8 @@ public void display_hud_text(int index, int client)
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
public Action ReadZoneFile() public Action ReadZoneFile()
{ {
if (g_is_zh_map)
{
int i_zoneTemp; int i_zoneTemp;
char l_cMapName[MAXZONES]; char l_cMapName[MAXZONES];
GetCurrentMap(l_cMapName, sizeof(l_cMapName)); GetCurrentMap(l_cMapName, sizeof(l_cMapName));
@ -680,11 +765,42 @@ public Action ReadZoneFile()
} }
g_zoneCount = i_zoneTemp; g_zoneCount = i_zoneTemp;
delete l_hZoneFile; delete l_hZoneFile;
}
return Plugin_Handled; return Plugin_Handled;
} }
public void OnMapStart() public void OnMapStart()
{ {
g_is_zh_map = false;
char sConfigFile[PLATFORM_MAX_PATH];
BuildPath(Path_SM, sConfigFile, sizeof(sConfigFile), "configs/zh_maps.cfg");
if(!FileExists(sConfigFile))
{
LogMessage("Could not find config: \"%s\"", sConfigFile);
return;
}
char map[PLATFORM_MAX_PATH];
GetCurrentMap(map, PLATFORM_MAX_PATH);
new Handle:fileHandle = OpenFile(sConfigFile, "r" );
char lineBuffer[256];
while( !IsEndOfFile( fileHandle ) && ReadFileLine( fileHandle, lineBuffer, sizeof( lineBuffer ) ) )
{
TrimString( lineBuffer );
if (StrEqual(lineBuffer, map, false))
{
g_is_zh_map = true;
break;
}
}
CloseHandle( fileHandle );
if (!g_is_zh_map)
{
return;
}
g_human_damage_addition = 1.0; g_human_damage_addition = 1.0;
//resetting coordinates and setup. //resetting coordinates and setup.
for (int i = 0; i < MAXZONES; i++) for (int i = 0; i < MAXZONES; i++)
@ -956,6 +1072,10 @@ stock void ReplaceStrings(char[] str, char[] strReplace)
public void SpawnPing(int skin, float pos[3], int index) public void SpawnPing(int skin, float pos[3], int index)
{ {
if (!g_is_zh_map)
{
return;
}
int Ent = CreateEntityByName("prop_dynamic"); int Ent = CreateEntityByName("prop_dynamic");
SetEntityModel(Ent, "models/unloze/unloze_ping.mdl"); SetEntityModel(Ent, "models/unloze/unloze_ping.mdl");
DispatchKeyValue(Ent, "modelscale", "1.5"); DispatchKeyValue(Ent, "modelscale", "1.5");
@ -978,6 +1098,10 @@ public void SpawnPing(int skin, float pos[3], int index)
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
public void RemovePing(int index) public void RemovePing(int index)
{ {
if (!g_is_zh_map)
{
return;
}
if (ping_ents[index] != -1 && IsValidEdict(ping_ents[index])) if (ping_ents[index] != -1 && IsValidEdict(ping_ents[index]))
{ {
char m_szClassname[64]; char m_szClassname[64];
@ -992,6 +1116,10 @@ public void RemovePing(int index)
public void UpdateMarkers() public void UpdateMarkers()
{ {
if (!g_is_zh_map)
{
return;
}
//this only works because of knowing that order of ping coordinates match with zone order. //this only works because of knowing that order of ping coordinates match with zone order.
for (int i = 0; i <= g_zoneCount; i++) for (int i = 0; i <= g_zoneCount; i++)
{ {
@ -1063,6 +1191,10 @@ public void UpdateMarkers()
public void reward_zm_zone_points(int i) public void reward_zm_zone_points(int i)
{ {
if (!g_is_zh_map)
{
return;
}
for (int j = 0; j < MaxClients; j++) for (int j = 0; j < MaxClients; j++)
{ {
//is validclient, is ct, is alive, is inside the zone that just changed from fought to T controlled //is validclient, is ct, is alive, is inside the zone that just changed from fought to T controlled
@ -1078,6 +1210,10 @@ public void reward_zm_zone_points(int i)
public void reward_ct_zone_points(int i) public void reward_ct_zone_points(int i)
{ {
if (!g_is_zh_map)
{
return;
}
for (int j = 0; j < MaxClients; j++) for (int j = 0; j < MaxClients; j++)
{ {
//is validclient, is ct, is alive, is inside the zone that just changed from fought to CT controlled //is validclient, is ct, is alive, is inside the zone that just changed from fought to CT controlled