new plugin: FixPointViewcontrol
This commit is contained in:
parent
bbc658518c
commit
04123d38c6
97
FixPointViewcontrol/scripting/FixPointViewcontrol.sp
Normal file
97
FixPointViewcontrol/scripting/FixPointViewcontrol.sp
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
#pragma semicolon 1
|
||||||
|
#pragma newdecls required
|
||||||
|
|
||||||
|
#include <sourcemod>
|
||||||
|
#include <sdkhooks>
|
||||||
|
#include <sdktools>
|
||||||
|
#include <dhooks>
|
||||||
|
|
||||||
|
public Plugin myinfo =
|
||||||
|
{
|
||||||
|
name = "FixPointViewcontrol",
|
||||||
|
author = "xen + BotoX",
|
||||||
|
description = "",
|
||||||
|
version = "1.0",
|
||||||
|
url = ""
|
||||||
|
}
|
||||||
|
|
||||||
|
Handle g_hAcceptInput;
|
||||||
|
int g_iAttachedViewControl[MAXPLAYERS + 1] = {INVALID_ENT_REFERENCE, ...};
|
||||||
|
|
||||||
|
public void OnPluginStart()
|
||||||
|
{
|
||||||
|
HookEvent("player_death", Event_PlayerDeath, EventHookMode_Post);
|
||||||
|
|
||||||
|
// Gamedata.
|
||||||
|
Handle hConfig = LoadGameConfigFile("sdktools.games");
|
||||||
|
if (hConfig == INVALID_HANDLE)
|
||||||
|
SetFailState("Couldn't load sdktools game config!");
|
||||||
|
|
||||||
|
int offset = GameConfGetOffset(hConfig, "AcceptInput");
|
||||||
|
if (offset == -1)
|
||||||
|
SetFailState("Failed to find AcceptInput offset");
|
||||||
|
|
||||||
|
delete hConfig;
|
||||||
|
|
||||||
|
// DHooks.
|
||||||
|
g_hAcceptInput = DHookCreate(offset, HookType_Entity, ReturnType_Bool, ThisPointer_CBaseEntity, Hook_AcceptInput);
|
||||||
|
DHookAddParam(g_hAcceptInput, HookParamType_CharPtr);
|
||||||
|
DHookAddParam(g_hAcceptInput, HookParamType_CBaseEntity);
|
||||||
|
DHookAddParam(g_hAcceptInput, HookParamType_CBaseEntity);
|
||||||
|
DHookAddParam(g_hAcceptInput, HookParamType_Object, 20, DHookPass_ByVal|DHookPass_ODTOR|DHookPass_OCTOR|DHookPass_OASSIGNOP);
|
||||||
|
DHookAddParam(g_hAcceptInput, HookParamType_Int);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Action Event_PlayerDeath(Handle hEvent, const char[] szName, bool bDontBroadcast)
|
||||||
|
{
|
||||||
|
int client = GetClientOfUserId(GetEventInt(hEvent, "userid"));
|
||||||
|
DisableViewControl(client);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnClientDisconnect(int client)
|
||||||
|
{
|
||||||
|
DisableViewControl(client);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DisableViewControl(int client)
|
||||||
|
{
|
||||||
|
if (g_iAttachedViewControl[client] == INVALID_ENT_REFERENCE)
|
||||||
|
return;
|
||||||
|
|
||||||
|
int entity = EntRefToEntIndex(g_iAttachedViewControl[client]);
|
||||||
|
if (entity == INVALID_ENT_REFERENCE)
|
||||||
|
return;
|
||||||
|
|
||||||
|
AcceptEntityInput(entity, "Disable", client, entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnEntityCreated(int entity, const char[] classname)
|
||||||
|
{
|
||||||
|
if (StrEqual(classname, "point_viewcontrol"))
|
||||||
|
{
|
||||||
|
DHookEntity(g_hAcceptInput, false, entity);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public MRESReturn Hook_AcceptInput(int entity, Handle hReturn, Handle hParams)
|
||||||
|
{
|
||||||
|
char sCommand[128];
|
||||||
|
DHookGetParamString(hParams, 1, sCommand, sizeof(sCommand));
|
||||||
|
|
||||||
|
int iActivator = DHookGetParam(hParams, 2);
|
||||||
|
if (iActivator < 1 || iActivator > MaxClients)
|
||||||
|
return MRES_Ignored;
|
||||||
|
|
||||||
|
if (StrEqual(sCommand, "Enable", false))
|
||||||
|
{
|
||||||
|
g_iAttachedViewControl[iActivator] = EntIndexToEntRef(entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (StrEqual(sCommand, "Disable", false))
|
||||||
|
{
|
||||||
|
SetEntPropEnt(entity, Prop_Data, "m_hPlayer", iActivator);
|
||||||
|
g_iAttachedViewControl[iActivator] = INVALID_ENT_REFERENCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return MRES_Ignored;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user