mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Add spectator text chat
Turns out custom radio channels are kind of a pain to work with. However this should work fine assuming the radioChannelAdd commands will work on client machines.
This commit is contained in:
parent
f07f06c843
commit
d2538c6ff2
@ -9,5 +9,11 @@
|
|||||||
GVAR(availableVisions) = [[-2,-1,0,1], [-2,-1], [-2,0,1], [-2]] select GVAR(restrictVisions);
|
GVAR(availableVisions) = [[-2,-1,0,1], [-2,-1], [-2,0,1], [-2]] select GVAR(restrictVisions);
|
||||||
}] call EFUNC(common,addEventHandler);
|
}] call EFUNC(common,addEventHandler);
|
||||||
|
|
||||||
|
// Create a radio channel for any spectators to text chat in
|
||||||
|
if (isServer) then {
|
||||||
|
GVAR(channel) = radioChannelCreate [[0.729,0.149,0.098,1],"Spectator","Spectator (%UNIT_NAME)",[]];
|
||||||
|
publicVariable QGVAR(channel);
|
||||||
|
};
|
||||||
|
|
||||||
// Should prevent unending spectator on mission end
|
// Should prevent unending spectator on mission end
|
||||||
addMissionEventHandler ["Ended",{ [false] call FUNC(setSpectator) }];
|
addMissionEventHandler ["Ended",{ [false] call FUNC(setSpectator) }];
|
||||||
|
@ -172,9 +172,12 @@ switch (toLower _mode) do {
|
|||||||
[QGVAR(zeus)] call FUNC(interrupt);
|
[QGVAR(zeus)] call FUNC(interrupt);
|
||||||
["zeus"] call FUNC(handleInterface);
|
["zeus"] call FUNC(handleInterface);
|
||||||
};
|
};
|
||||||
if ((isServer || {serverCommandAvailable "#kick"}) && {_dik in (actionKeys "Chat" + actionKeys "PrevChannel" + actionKeys "NextChannel")}) exitWith {
|
if (_dik in (actionKeys "Chat")) exitWith {
|
||||||
false
|
false
|
||||||
};
|
};
|
||||||
|
if (_dik in (actionKeys "PrevChannel" + actionKeys "NextChannel")) exitWith {
|
||||||
|
!(isServer || serverCommandAvailable "#kick")
|
||||||
|
};
|
||||||
|
|
||||||
// Handle held keys (prevent repeat calling)
|
// Handle held keys (prevent repeat calling)
|
||||||
if (GVAR(heldKeys) param [_dik,false]) exitwith {};
|
if (GVAR(heldKeys) param [_dik,false]) exitwith {};
|
||||||
|
@ -63,9 +63,17 @@ if (_set) then {
|
|||||||
GVAR(unitCamera) camCommit 0;
|
GVAR(unitCamera) camCommit 0;
|
||||||
[] call FUNC(transitionCamera);
|
[] call FUNC(transitionCamera);
|
||||||
|
|
||||||
// Close map and clear radio
|
// Cache current channel to switch back to on exit
|
||||||
|
GVAR(channelCache) = currentChannel;
|
||||||
|
|
||||||
|
// Channel index starts count after the 5 default channels
|
||||||
|
GVAR(channel) radioChannelAdd [player];
|
||||||
|
setCurrentChannel (5 + GVAR(channel));
|
||||||
|
|
||||||
|
// Close map and clear the chat
|
||||||
openMap [false,false];
|
openMap [false,false];
|
||||||
clearRadio;
|
clearRadio;
|
||||||
|
enableRadio false;
|
||||||
|
|
||||||
// Disable BI damage effects
|
// Disable BI damage effects
|
||||||
BIS_fnc_feedback_allowPP = false;
|
BIS_fnc_feedback_allowPP = false;
|
||||||
@ -111,7 +119,16 @@ if (_set) then {
|
|||||||
camDestroy GVAR(unitCamera);
|
camDestroy GVAR(unitCamera);
|
||||||
camDestroy GVAR(targetCamera);
|
camDestroy GVAR(targetCamera);
|
||||||
|
|
||||||
|
// Remove from spectator chat
|
||||||
|
GVAR(channel) radioChannelRemove [player];
|
||||||
|
|
||||||
|
// Restore cached channel and delete cache
|
||||||
|
setCurrentChannel GVAR(channelCache);
|
||||||
|
GVAR(channelCache) = nil;
|
||||||
|
|
||||||
|
// Clear any residual spectator chat
|
||||||
clearRadio;
|
clearRadio;
|
||||||
|
enableRadio true;
|
||||||
|
|
||||||
// Return to player view
|
// Return to player view
|
||||||
player switchCamera "internal";
|
player switchCamera "internal";
|
||||||
|
@ -61,7 +61,6 @@ if (_newMode == 0) then { // Free
|
|||||||
};
|
};
|
||||||
|
|
||||||
GVAR(camAgent) switchCamera "internal";
|
GVAR(camAgent) switchCamera "internal";
|
||||||
clearRadio;
|
|
||||||
} else {
|
} else {
|
||||||
_camera = GVAR(unitCamera);
|
_camera = GVAR(unitCamera);
|
||||||
|
|
||||||
@ -87,11 +86,6 @@ if (_newMode == 0) then { // Free
|
|||||||
_camera cameraEffect ["internal", "back"];
|
_camera cameraEffect ["internal", "back"];
|
||||||
};
|
};
|
||||||
|
|
||||||
// Clear radio if group changed
|
|
||||||
if (group _newUnit != group GVAR(camUnit)) then {
|
|
||||||
clearRadio;
|
|
||||||
};
|
|
||||||
|
|
||||||
GVAR(camUnit) = _newUnit;
|
GVAR(camUnit) = _newUnit;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user