nearestObjects: Difference between revisions
| m (Text replace - "{{uc:{{PAGENAME}}}}" to "{{uc:{{PAGENAME}}}} {{uc:{{PAGENAME}}}}") | No edit summary | ||
| Line 73: | Line 73: | ||
| <br> | <br> | ||
| <dd class="notedate">Posted on 11.09.2013 | |||
| <dt class="note">[[User:Katulobotomia|Katulobotomia]] | |||
| <dd class="note">If you want to detect a nearby grenades for the position of a unit, for example, using 'nearestObjects' won't work. You have to use | |||
| 'nearObjects' instead. | |||
| <code>count( nearestObjects [_unit, ["GrenadeHand"], 30]) // WON'T WORK</code> | |||
| Won't ever return anything but 0. | |||
| <code>count (_unit nearObjects ["GrenadeHand", 30]) // WORKS!</code> | |||
| Will work. | |||
| <br> | |||
| <!-- Note Section END --> | <!-- Note Section END --> | ||
Revision as of 14:54, 11 September 2013
Description
- Description:
- Returns a list of nearest objects of the given types to the given position or object, within the specified distance. position can use the format: [[x,y,z], ["ClassName",...], radius] or [object, ["ClassName",...], radius] To use it without any ClassName filter: [object or position, [], radius]. A list of ClassName types (Tanks eg) can be found in CfgVehicles If more than one object is found they will be ordered according to their distance (i.e. the closest one will be first in the array).
- Groups:
- Uncategorised
Syntax
- Syntax:
- objects = nearestObjects [position, types, radius];
- Parameters:
- position: Array or Object - Where to find objects, center position.
- types: Array - List of class name of the objects to search for.
- radius: Number - Range from center position to search for objects.
- Return Value:
- Array
Examples
- Example 1:
- nearestObjects [player, ["Car","Tank"], 200]
- Example 2:
- nearestObjects [player, ["house"], 200]
- Example 3:
- nearestObjects [[2716,2949,0], ["Car","Truck"], 100]
Additional Information
- See also:
- nearestObjectnearObjectsnearEntities
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
Notes
- Posted on unknown
- Vigilante
- 
To get a list with alive targets for various situations use this construct:
_nearestTargets = nearestObjects [_submunScanPos, ["VBS2_TANK","TANK"], _scanArea]; _validNearestTargets = []; {if (alive _x) then {_validNearestTargets set [(count _validNearestTargets),_x];};} foreach _nearestTargets;results in _validNearestTargets being filled with targets == alive .. (you could use other conditions there, of course!) -- Vigilante
 
- Posted on 10. Aug. 2010
- Rübe
- Passing an empty array to define the types will also return objects with no class at all (such as trees, bushes, stones, ...). 
Example:
_objects = nearestObjects [_position, [], _radius];Passing the array ["All"] is not the same and will only return objects that have some sort of class.
 
- Posted on 11.09.2013
- Katulobotomia
- If you want to detect a nearby grenades for the position of a unit, for example, using 'nearestObjects' won't work. You have to use
'nearObjects' instead.
count( nearestObjects [_unit, ["GrenadeHand"], 30]) // WON'T WORKWon't ever return anything but 0.count (_unit nearObjects ["GrenadeHand", 30]) // WORKS!Will work.
 
