playableUnits: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "<dd class="note">([^}]*)<code>([^<]*)<\/code>" to "<dd class="note">$1<sqf>$2</sqf>")
m (Some wiki formatting)
Line 17: Line 17:
|gr2= Object Detection
|gr2= Object Detection


|descr= Returns a list of playable units in a multiplayer game (occupied by both AI or players), created on the following sides [[east]]/[[opfor]], [[west]]/[[blufor]], [[resistance]]/[[independent]] and [[civilian]] only. Does not contain units of [[sideLogic]].<br>
|descr= Returns a list of playable units in a multiplayer game (occupied by both AI or players), created on the following sides [[east]]/[[opfor]], [[west]]/[[blufor]], [[resistance]]/[[independent]] and [[civilian]] only.
Does not contain units of [[sideLogic]].
{{Feature|Informative|This command returns an empty array in Singleplayer; use [[switchableUnits]] instead.}}
{{Feature|Informative|This command returns an empty array in Singleplayer; use [[switchableUnits]] instead.}}
{{Feature|important|This command does not include dead players awaiting for respawn.}}
{{Feature|important|This command does not include dead players awaiting for respawn.}}
Line 26: Line 27:


|x1= <sqf>{ _x groupChat "I'm a playable unit."; } forEach playableUnits;</sqf>
|x1= <sqf>{ _x groupChat "I'm a playable unit."; } forEach playableUnits;</sqf>
|x2= <sqf>_playableInGroup = units group player arrayIntersect playableUnits;</sqf>
|x2= <sqf>_playableInGroup = units group player arrayIntersect playableUnits;</sqf>
|x3= <sqf>_nonPlayableInGroup = units group player - playableUnits;</sqf>
|x3= <sqf>_nonPlayableInGroup = units group player - playableUnits;</sqf>


Line 32: Line 35:
}}
}}


 
{{Note
<dl class="command_description">
|user= DreadedEntity
 
|timestamp= 20141223231300
<dt></dt>
|text= To get a list of all player-controlled units:
<dd class="notedate">Posted on December 23, 2014 - 23:13 (UTC)</dd>
<sqf>
<dt class="note">[[User:DreadedEntity|DreadedEntity]]</dt>
_allPlayers = [];
<dd class="note">
To get a list of all player-controlled units:
<sqf>_allPlayers = [];
{
{
if (isPlayer _x) then
if (isPlayer _x) then
Line 46: Line 46:
_allPlayers pushBack _x;
_allPlayers pushBack _x;
};
};
} forEach playableUnits;</sqf>
} forEach playableUnits;
<dt><dt>
</sqf>
<dd class="notedate">Posted on August 16, 2015 - 10:05 (UTC)</dd>
}}
<dt class="note">[[User:FR Starfox64|FR Starfox64]]</dt>
 
<dd class="note">[[playableUnits]] will not return dead players, use [[allPlayers]] instead.
{{Note
<dt><dt>
|user= FR Starfox64
<dd class="notedate">Posted on February 14, 2017 - 22:05 (UTC)</dd>
|timestamp= 20150816100500
<dt class="note">[[User:Pierre MGI|Pierre MGI]]</dt>
|text= [[playableUnits]] will not return dead players, use [[allPlayers]] instead.
<dd class="note">Using the Editor (multiplayer attributes) for unchecking "enable AI", or disabling AI(s) in lobby, will make [[playableUnits]] as a public variable,  updated by each JIP on disabled slot.
}}
 
{{Note
|user= Pierre MGI
|timestamp= 20170214220500
|text= Using the Editor (multiplayer attributes) for unchecking "enable AI", or disabling AI(s) in lobby, will make [[playableUnits]] as a public variable,  updated by each JIP on disabled slot.
So, if all slots are disabled AI, playableUnits is same as allPlayers<br>
So, if all slots are disabled AI, playableUnits is same as allPlayers<br>
Furthermore, in this case, non-played slot (playable and disabled AI) units simply don't exist!<br>
Furthermore, in this case, non-played slot (playable and disabled AI) units simply don't exist!<br>
i.e. If you name 8 playable units: u1..u8, then 2 players in game: u3 & u6<br>
i.e. If you name 8 playable units: u1..u8, then 2 players in game: u3 & u6<br>
playableUnits will return [u3,u6], and true for  isNil "u1", isNil "u2"... until another player takes the slot.
playableUnits will return [u3,u6], and true for  isNil "u1", isNil "u2"... until another player takes the slot.
</dd>
}}
 
</dl>

Revision as of 03:02, 10 February 2023

Hover & click on the images for description

Description

Description:
Returns a list of playable units in a multiplayer game (occupied by both AI or players), created on the following sides east/opfor, west/blufor, resistance/independent and civilian only. Does not contain units of sideLogic.
This command returns an empty array in Singleplayer; use switchableUnits instead.
This command does not include dead players awaiting for respawn.
Groups:
MultiplayerObject Detection

Syntax

Syntax:
playableUnits
Return Value:
Array

Examples

Example 1:
{ _x groupChat "I'm a playable unit."; } forEach playableUnits;
Example 2:
_playableInGroup = units group player arrayIntersect playableUnits;
Example 3:
_nonPlayableInGroup = units group player - playableUnits;

Additional Information

See also:
playableSlotsNumber allPlayers allCurators allGroups allDead switchableUnits vehicles allUnitsUAV allDeadMen isPlayer playersNumber

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
DreadedEntity - c
Posted on Dec 23, 2014 - 23:13 (UTC)
To get a list of all player-controlled units:
_allPlayers = []; { if (isPlayer _x) then { _allPlayers pushBack _x; }; } forEach playableUnits;
FR Starfox64 - c
Posted on Aug 16, 2015 - 10:05 (UTC)
playableUnits will not return dead players, use allPlayers instead.
Pierre MGI - c
Posted on Feb 14, 2017 - 22:05 (UTC)
Using the Editor (multiplayer attributes) for unchecking "enable AI", or disabling AI(s) in lobby, will make playableUnits as a public variable, updated by each JIP on disabled slot. So, if all slots are disabled AI, playableUnits is same as allPlayers
Furthermore, in this case, non-played slot (playable and disabled AI) units simply don't exist!
i.e. If you name 8 playable units: u1..u8, then 2 players in game: u3 & u6
playableUnits will return [u3,u6], and true for isNil "u1", isNil "u2"... until another player takes the slot.