291 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
			
		
		
	
	
			291 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
| /**
 | |
|  * vim: set ts=4 :
 | |
|  * =============================================================================
 | |
|  * SourceMod Basefuncommands Plugin
 | |
|  * Provides blind functionality
 | |
|  *
 | |
|  * SourceMod (C)2004-2008 AlliedModders LLC.  All rights reserved.
 | |
|  * =============================================================================
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify it under
 | |
|  * the terms of the GNU General Public License, version 3.0, as published by the
 | |
|  * Free Software Foundation.
 | |
|  * 
 | |
|  * This program is distributed in the hope that it will be useful, but WITHOUT
 | |
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 | |
|  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 | |
|  * details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along with
 | |
|  * this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  *
 | |
|  * As a special exception, AlliedModders LLC gives you permission to link the
 | |
|  * code of this program (as well as its derivative works) to "Half-Life 2," the
 | |
|  * "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software
 | |
|  * by the Valve Corporation.  You must obey the GNU General Public License in
 | |
|  * all respects for all other code used.  Additionally, AlliedModders LLC grants
 | |
|  * this exception to all derivative works.  AlliedModders LLC defines further
 | |
|  * exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007),
 | |
|  * or <http://www.sourcemod.net/license.php>.
 | |
|  *
 | |
|  * Version: $Id$
 | |
|  */
 | |
| 
 | |
| new g_BlindTarget[MAXPLAYERS+1];
 | |
| 
 | |
| PerformBlind(client, target, amount)
 | |
| {
 | |
| 	new targets[2];
 | |
| 	targets[0] = target;
 | |
| 	
 | |
| 	new duration = 1536;
 | |
| 	new holdtime = 1536;
 | |
| 	new flags;
 | |
| 	if (amount == 0)
 | |
| 	{
 | |
| 		flags = (0x0001 | 0x0010);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		flags = (0x0002 | 0x0008);
 | |
| 	}
 | |
| 	
 | |
| 	new color[4] = { 0, 0, 0, 0 };
 | |
| 	color[3] = amount;
 | |
| 	
 | |
| 	new Handle:message = StartMessageEx(g_FadeUserMsgId, targets, 1);
 | |
| 	if (GetUserMessageType() == UM_Protobuf)
 | |
| 	{
 | |
| 		PbSetInt(message, "duration", duration);
 | |
| 		PbSetInt(message, "hold_time", holdtime);
 | |
| 		PbSetInt(message, "flags", flags);
 | |
| 		PbSetColor(message, "clr", color);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		BfWriteShort(message, duration);
 | |
| 		BfWriteShort(message, holdtime);
 | |
| 		BfWriteShort(message, flags);		
 | |
| 		BfWriteByte(message, color[0]);
 | |
| 		BfWriteByte(message, color[1]);
 | |
| 		BfWriteByte(message, color[2]);
 | |
| 		BfWriteByte(message, color[3]);
 | |
| 	}
 | |
| 	
 | |
| 	EndMessage();
 | |
| 
 | |
| 	LogAction(client, target, "\"%L\" set blind on \"%L\", amount %d.", client, target, amount);
 | |
| }
 | |
| 
 | |
| public AdminMenu_Blind(Handle:topmenu, 
 | |
| 					  TopMenuAction:action,
 | |
| 					  TopMenuObject:object_id,
 | |
| 					  param,
 | |
| 					  String:buffer[],
 | |
| 					  maxlength)
 | |
| {
 | |
| 	if (action == TopMenuAction_DisplayOption)
 | |
| 	{
 | |
| 		Format(buffer, maxlength, "%T", "Blind player", param);
 | |
| 	}
 | |
| 	else if (action == TopMenuAction_SelectOption)
 | |
| 	{
 | |
| 		DisplayBlindMenu(param);
 | |
| 	}
 | |
| 	else if (action == TopMenuAction_DrawOption)
 | |
| 	{	
 | |
| 		// Disable if we could not find the user message id for Fade.
 | |
| 		buffer[0] = ((g_FadeUserMsgId == INVALID_MESSAGE_ID) ? ITEMDRAW_IGNORE : ITEMDRAW_DEFAULT);
 | |
| 	}	
 | |
| }
 | |
| 
 | |
| DisplayBlindMenu(client)
 | |
| {
 | |
| 	new Handle:menu = CreateMenu(MenuHandler_Blind);
 | |
| 	
 | |
| 	decl String:title[100];
 | |
| 	Format(title, sizeof(title), "%T:", "Blind player", client);
 | |
| 	SetMenuTitle(menu, title);
 | |
| 	SetMenuExitBackButton(menu, true);
 | |
| 	
 | |
| 	AddTargetsToMenu(menu, client, true, true);
 | |
| 	
 | |
| 	DisplayMenu(menu, client, MENU_TIME_FOREVER);
 | |
| }
 | |
| 
 | |
| DisplayAmountMenu(client)
 | |
| {
 | |
| 	new Handle:menu = CreateMenu(MenuHandler_Amount);
 | |
| 	
 | |
| 	decl String:title[100];
 | |
| 	Format(title, sizeof(title), "%T: %N", "Blind amount", client, GetClientOfUserId(g_BlindTarget[client]));
 | |
| 	SetMenuTitle(menu, title);
 | |
| 	SetMenuExitBackButton(menu, true);
 | |
| 	
 | |
| 	AddMenuItem(menu, "255", "Fully blind");
 | |
| 	AddMenuItem(menu, "240", "Half blind");
 | |
| 	AddMenuItem(menu, "0", "No blind");
 | |
| 	
 | |
| 	DisplayMenu(menu, client, MENU_TIME_FOREVER);
 | |
| }
 | |
| 
 | |
| public MenuHandler_Blind(Handle:menu, MenuAction:action, param1, param2)
 | |
| {
 | |
| 	if (action == MenuAction_End)
 | |
| 	{
 | |
| 		CloseHandle(menu);
 | |
| 	}
 | |
| 	else if (action == MenuAction_Cancel)
 | |
| 	{
 | |
| 		if (param2 == MenuCancel_ExitBack && hTopMenu != INVALID_HANDLE)
 | |
| 		{
 | |
| 			DisplayTopMenu(hTopMenu, param1, TopMenuPosition_LastCategory);
 | |
| 		}
 | |
| 	}
 | |
| 	else if (action == MenuAction_Select)
 | |
| 	{
 | |
| 		decl String:info[32];
 | |
| 		new userid, target;
 | |
| 		
 | |
| 		GetMenuItem(menu, param2, info, sizeof(info));
 | |
| 		userid = StringToInt(info);
 | |
| 
 | |
| 		if ((target = GetClientOfUserId(userid)) == 0)
 | |
| 		{
 | |
| 			PrintToChat(param1, "[SM] %t", "Player no longer available");
 | |
| 		}
 | |
| 		else if (!CanUserTarget(param1, target))
 | |
| 		{
 | |
| 			PrintToChat(param1, "[SM] %t", "Unable to target");
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			g_BlindTarget[param1] = userid;
 | |
| 			DisplayAmountMenu(param1);
 | |
| 			return;	// Return, because we went to a new menu and don't want the re-draw to occur.
 | |
| 		}
 | |
| 		
 | |
| 		/* Re-draw the menu if they're still valid */
 | |
| 		if (IsClientInGame(param1) && !IsClientInKickQueue(param1))
 | |
| 		{
 | |
| 			DisplayBlindMenu(param1);
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| public MenuHandler_Amount(Handle:menu, MenuAction:action, param1, param2)
 | |
| {
 | |
| 	if (action == MenuAction_End)
 | |
| 	{
 | |
| 		CloseHandle(menu);
 | |
| 	}
 | |
| 	else if (action == MenuAction_Cancel)
 | |
| 	{
 | |
| 		if (param2 == MenuCancel_ExitBack && hTopMenu != INVALID_HANDLE)
 | |
| 		{
 | |
| 			DisplayTopMenu(hTopMenu, param1, TopMenuPosition_LastCategory);
 | |
| 		}
 | |
| 	}
 | |
| 	else if (action == MenuAction_Select)
 | |
| 	{
 | |
| 		decl String:info[32];
 | |
| 		new amount, target;
 | |
| 		
 | |
| 		GetMenuItem(menu, param2, info, sizeof(info));
 | |
| 		amount = StringToInt(info);
 | |
| 
 | |
| 		if ((target = GetClientOfUserId(g_BlindTarget[param1])) == 0)
 | |
| 		{
 | |
| 			PrintToChat(param1, "[SM] %t", "Player no longer available");
 | |
| 		}
 | |
| 		else if (!CanUserTarget(param1, target))
 | |
| 		{
 | |
| 			PrintToChat(param1, "[SM] %t", "Unable to target");
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			new String:name[32];
 | |
| 			GetClientName(target, name, sizeof(name));
 | |
| 			
 | |
| 			PerformBlind(param1, target, amount);
 | |
| 			ShowActivity2(param1, "[SM] ", "%t", "Set blind on target", "_s", name, amount);
 | |
| 		}
 | |
| 		
 | |
| 		/* Re-draw the menu if they're still valid */
 | |
| 		if (IsClientInGame(param1) && !IsClientInKickQueue(param1))
 | |
| 		{
 | |
| 			DisplayBlindMenu(param1);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| public Action:Command_Blind(client, args)
 | |
| {
 | |
| 	if (args < 1)
 | |
| 	{
 | |
| 		ReplyToCommand(client, "[SM] Usage: sm_blind <#userid|name> [amount]");
 | |
| 		return Plugin_Handled;
 | |
| 	}
 | |
| 
 | |
| 	decl String:arg[65];
 | |
| 	GetCmdArg(1, arg, sizeof(arg));
 | |
| 	
 | |
| 	new amount = 0;
 | |
| 	if (args > 1)
 | |
| 	{
 | |
| 		decl String:arg2[20];
 | |
| 		GetCmdArg(2, arg2, sizeof(arg2));
 | |
| 		if (StringToIntEx(arg2, amount) == 0)
 | |
| 		{
 | |
| 			ReplyToCommand(client, "[SM] %t", "Invalid Amount");
 | |
| 			return Plugin_Handled;
 | |
| 		}
 | |
| 		
 | |
| 		if (amount < 0)
 | |
| 		{
 | |
| 			amount = 0;
 | |
| 		}
 | |
| 		
 | |
| 		if (amount > 255)
 | |
| 		{
 | |
| 			amount = 255;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	decl String:target_name[MAX_TARGET_LENGTH];
 | |
| 	decl target_list[MAXPLAYERS], target_count, bool:tn_is_ml;
 | |
| 	
 | |
| 	if ((target_count = ProcessTargetString(
 | |
| 			arg,
 | |
| 			client,
 | |
| 			target_list,
 | |
| 			MAXPLAYERS,
 | |
| 			COMMAND_FILTER_ALIVE,
 | |
| 			target_name,
 | |
| 			sizeof(target_name),
 | |
| 			tn_is_ml)) <= 0)
 | |
| 	{
 | |
| 		ReplyToTargetError(client, target_count);
 | |
| 		return Plugin_Handled;
 | |
| 	}
 | |
| 	
 | |
| 	for (new i = 0; i < target_count; i++)
 | |
| 	{
 | |
| 		PerformBlind(client, target_list[i], amount);
 | |
| 	}
 | |
| 	
 | |
| 	if (tn_is_ml)
 | |
| 	{
 | |
| 		ShowActivity2(client, "[SM] ", "%t", "Set blind on target", target_name);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		ShowActivity2(client, "[SM] ", "%t", "Set blind on target", "_s", target_name);
 | |
| 	}
 | |
| 	
 | |
| 	return Plugin_Handled;
 | |
| }
 |