Added VOICE_TEAM and VOICE_LISTENTEAM flags to the SDKTools voice functionality.

--HG--
extra : convert_revision : svn%3A39bc706e-5318-0410-9160-8a85361fbb7c/trunk%401474
This commit is contained in:
Michael McKoy 2007-09-23 21:01:07 +00:00
parent 7df54ec38d
commit e4728b0413
2 changed files with 24 additions and 8 deletions

View File

@ -8,7 +8,7 @@
* This program is free software; you can redistribute it and/or modify it under * 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 * the terms of the GNU General Public License, version 3.0, as published by the
* Free Software Foundation. * Free Software Foundation.
* *
* This program is distributed in the hope that it will be useful, but WITHOUT * 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 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
@ -35,6 +35,8 @@
#define SPEAK_MUTED 1 #define SPEAK_MUTED 1
#define SPEAK_ALL 2 #define SPEAK_ALL 2
#define SPEAK_LISTENALL 4 #define SPEAK_LISTENALL 4
#define SPEAK_TEAM 8
#define SPEAK_LISTENTEAM 16
size_t g_VoiceFlags[65]; size_t g_VoiceFlags[65];
size_t g_VoiceFlagsCount = 0; size_t g_VoiceFlagsCount = 0;
@ -43,19 +45,31 @@ SH_DECL_HOOK3(IVoiceServer, SetClientListening, SH_NOATTRIB, 0, bool, int, int,
bool SDKTools::OnSetClientListening(int iReceiver, int iSender, bool bListen) bool SDKTools::OnSetClientListening(int iReceiver, int iSender, bool bListen)
{ {
if (g_VoiceFlags[iSender] & SPEAK_MUTED) if (g_VoiceFlags[iSender] & SPEAK_MUTED)
{ {
RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, false)); RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, false));
} }
if (g_VoiceFlags[iSender] & SPEAK_ALL) if ((g_VoiceFlags[iSender] & SPEAK_ALL) || (g_VoiceFlags[iReceiver] & SPEAK_LISTENALL))
{ {
RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, true)); RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, true));
} }
if (g_VoiceFlags[iReceiver] & SPEAK_LISTENALL) if ((g_VoiceFlags[iSender] & SPEAK_TEAM) || (g_VoiceFlags[iReceiver] & SPEAK_LISTENTEAM))
{ {
RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, true)); IGamePlayer *pReceiver = playerhelpers->GetGamePlayer(iReceiver);
IGamePlayer *pSender = playerhelpers->GetGamePlayer(iSender);
if (pReceiver && pSender && pReceiver->IsInGame() && pSender->IsInGame())
{
IPlayerInfo *pRInfo = pReceiver->GetPlayerInfo();
IPlayerInfo *pSInfo = pSender->GetPlayerInfo();
if (pRInfo && pSInfo && pRInfo->GetTeamIndex() == pSInfo->GetTeamIndex())
{
RETURN_META_VALUE_NEWPARAMS(MRES_IGNORED, bListen, &IVoiceServer::SetClientListening, (iReceiver, iSender, true));
}
}
} }
RETURN_META_VALUE(MRES_IGNORED, bListen); RETURN_META_VALUE(MRES_IGNORED, bListen);
@ -64,7 +78,7 @@ bool SDKTools::OnSetClientListening(int iReceiver, int iSender, bool bListen)
void SDKTools::OnClientDisconnecting(int client) void SDKTools::OnClientDisconnecting(int client)
{ {
if (g_VoiceFlags[client]) if (g_VoiceFlags[client])
{ {
g_VoiceFlags[client] = 0; g_VoiceFlags[client] = 0;
if (!--g_VoiceFlagsCount) if (!--g_VoiceFlagsCount)
{ {
@ -143,7 +157,7 @@ static cell_t GetClientListening(IPluginContext *pContext, const cell_t *params)
return voiceserver->GetClientListening(params[1], params[2]) ? 1 : 0; return voiceserver->GetClientListening(params[1], params[2]) ? 1 : 0;
} }
sp_nativeinfo_t g_VoiceNatives[] = sp_nativeinfo_t g_VoiceNatives[] =
{ {
{"SetClientListeningFlags", SetClientListeningFlags}, {"SetClientListeningFlags", SetClientListeningFlags},
{"GetClientListeningFlags", GetClientListeningFlags}, {"GetClientListeningFlags", GetClientListeningFlags},

View File

@ -39,9 +39,11 @@
* @section voice flags. * @section voice flags.
*/ */
#define VOICE_NORMAL 0 /**< Allow the client to listen and speak normally. */ #define VOICE_NORMAL 0 /**< Allow the client to listen and speak normally. */
#define VOICE_MUTED 1 /**< Mutes the client from speaking to everyone. */ #define VOICE_MUTED 1 /**< Mutes the client from speaking to everyone. */
#define VOICE_SPEAKALL 2 /**< Allow the client to speak to everyone. */ #define VOICE_SPEAKALL 2 /**< Allow the client to speak to everyone. */
#define VOICE_LISTENALL 4 /**< Allow the client to listen to everyone. */ #define VOICE_LISTENALL 4 /**< Allow the client to listen to everyone. */
#define VOICE_TEAM 8 /**< Allow the client to always speak to team, even when dead. */
#define VOICE_LISTENTEAM 16 /**< Allow the client to always hear teammates, including dead ones. */
/** /**
* @endsection * @endsection