lineIntersects: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "\[\[Category:[ _]?Scripting[ _]Commands[ _]Take[ _]On[ _]Helicopters(\|.*)?\]\]" to "{{GameCategory|tkoh|Scripting Commands}}")
(Add game version for alternative syntax to description. Minor typo corrections. Reordered see also commands to be grouped and consistent across lineIntersects pages)
 
(48 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Command|Comments=
{{RV|type=command
____________________________________________________________________________________________


| arma2oa |Game name=
|game1= arma2oa
|1.62|Game version=
|version1= 1.62
|arg= global|Multiplayer Arguments=


|gr1= Math - Geometry |GROUP1=
|game2= tkoh
____________________________________________________________________________________________
|version2= 1.00


| Checks for object intersection with a virtual line between two positions. Returns true if intersects with an object.
|game3= arma3
|version3= 0.50


<br><br>'''NOTE:''' Doesn't work under water. Max harcoded distance is 1000m.|DESCRIPTION=
|arg= global
____________________________________________________________________________________________


| '''lineIntersects''' [begPos, endPos, objIgnore1, objIgnore2] |SYNTAX=
|gr1= Math - Geometry
|p1=[begPos, endPos, objIgnore1, objIgnore2]: [[Array]] |PARAMETER1=
|p2= begPos: [[PositionASL]] |PARAMETER2=
|p3= endPos: [[PositionASL]] |PARAMETER3=
|p4= objIgnore1: (optional) [[Object]] - object to ignore. When testing intersection from an object/unit/vehicle, pass that object here to prevent intersection inside of the object.|PARAMETER4=
|p5= objIgnore2: (optional) [[Object]] - another object to ignore. When testing intersection of a line between two objects, pass the second object here to prevent intersection inside of it being reported|PARAMETER5=


| [[Boolean]] - true if intersection |RETURNVALUE=
|descr= Checks for object intersection with a virtual line between two positions. Since {{GVI|arma3|2.20|size= 0.75}}, there is an alternative syntax that does multiple checks at once, faster than multiple calls.
____________________________________________________________________________________________
{{Feature|informative|
 
* Does not work under water.
|x1= <code>[[lineIntersects]] [<nowiki/>[[eyePos]] [[player]], [[aimPos]] chopper, [[player]], chopper]</code> |EXAMPLE1=
* Max hardcoded distance is 1000m.
____________________________________________________________________________________________
}}
 
|s1= [[lineIntersects]] [begPos, endPos, objIgnore1, objIgnore2]
 
|p1= begPos: [[Array]] format [[Position#PositionASL|PositionASL]]
 
|p2= endPos: [[Array]] format [[Position#PositionASL|PositionASL]]


| [[lineIntersectsSurfaces]], [[intersect]], [[terrainIntersect]], [[terrainIntersectASL]], [[terrainIntersectAtASL]], [[lineIntersectsWith]], [[lineIntersectsObjs]], [[cursorObject]], [[cursorTarget]], [[checkVisibility]] |SEEALSO=
|p3= objIgnore1: [[Object]] - (Optional, default [[objNull]]) object to ignore. When testing intersections from an object/unit/vehicle, pass that object here to prevent intersections inside of the object


}}
|p4= objIgnore2: [[Object]] - (Optional, default [[objNull]]) another object to ignore. When testing intersections of a line between two objects, pass the second object here to prevent intersections inside of it being reported
 
|r1= [[Boolean]] - [[true]] if an intersection happens with an object (not with terrain)
 
|s2= [[lineIntersects]] [element1, element2, ...]
 
|s2since= arma3 2.20


<h3 style="display:none">Notes</h3>
|p21= elementN: [[Array]] format [begPos, endPos, objIgnore1, objIgnore2]:
<dl class="command_description">
* begPos: [[Array]] format [[Position#PositionASL|PositionASL]]
<!-- Note Section BEGIN -->
* endPos: [[Array]] format [[Position#PositionASL|PositionASL]]
* objIgnore1: [[Object]] - (Optional, default [[objNull]]) object to ignore. When testing intersections from an object/unit/vehicle, pass that object here to prevent intersections inside of the object
* objIgnore2: [[Object]] - (Optional, default [[objNull]]) another object to ignore. When testing intersections of a line between two objects, pass the second object here to prevent intersections inside of it being reported


<dd class="notedate">Posted on may 31, 2012 - 10:46 (CEST)
|r2= [[Array]] format [result1, result2, ...] - [[true]] if an intersection happens with an object (not with terrain) for the Nth element
<dt class="note">[[User:Lou Montana|Lou Montana]]
<dd class="note">Please note the difference :
*[[terrainIntersect]]
*[[terrainIntersectASL]]
*[[lineIntersects]]
*[[lineIntersectsWith]]
*[[lineIntersectsObjs]]
*[[intersect]]


<!-- Note Section END -->
|x1= <sqf>private _hasStraightLineToChopper = lineIntersects [eyePos player, aimPos chopper, player, chopper];</sqf>
</dl>


<h3 style="display:none">Bottom Section</h3>
|x2= Alternative syntax to check intersections in parallel:
<sqf>
private _enemies = units opfor;
private _enemyDataArray = _enemies apply { [eyePos player, aimPos _x, player, _x] };
private _result = lineIntersects _enemyDataArray;
</sqf>


[[Category:Arma 2: Operation Arrowhead: New Scripting Commands List|{{uc:{{PAGENAME}}}}]]
|seealso= [[lineIntersectsSurfaces]] [[lineIntersectsObjs]] [[lineIntersectsWith]] [[terrainIntersect]] [[terrainIntersectASL]] [[terrainIntersectAtASL]] [[intersect]] [[cursorObject]] [[cursorTarget]] [[checkVisibility]]
{{GameCategory|arma2|Scripting Commands}}
}}
{{GameCategory|arma3|Scripting Commands}}
 
{{GameCategory|tkoh|Scripting Commands}}
{{Note
[[Category:Scripting Commands|{{uc:{{PAGENAME}}}}]]
|user= Lou Montana
|timestamp= 20120531104600
|text= Please note the difference:
* [[terrainIntersect]]
* [[terrainIntersectASL]]
* [[lineIntersects]]
* [[lineIntersectsWith]]
* [[lineIntersectsObjs]]
* [[intersect]]
}}

Latest revision as of 02:03, 1 December 2024

Hover & click on the images for description

Description

Description:
Checks for object intersection with a virtual line between two positions. Since Arma 3 logo black.png2.20, there is an alternative syntax that does multiple checks at once, faster than multiple calls.
  • Does not work under water.
  • Max hardcoded distance is 1000m.
Groups:
Math - Geometry

Syntax

Syntax:
lineIntersects [begPos, endPos, objIgnore1, objIgnore2]
Parameters:
begPos: Array format PositionASL
endPos: Array format PositionASL
objIgnore1: Object - (Optional, default objNull) object to ignore. When testing intersections from an object/unit/vehicle, pass that object here to prevent intersections inside of the object
objIgnore2: Object - (Optional, default objNull) another object to ignore. When testing intersections of a line between two objects, pass the second object here to prevent intersections inside of it being reported
Return Value:
Boolean - true if an intersection happens with an object (not with terrain)

Alternative Syntax

Syntax:
lineIntersects [element1, element2, ...]
Parameters:
elementN: Array format [begPos, endPos, objIgnore1, objIgnore2]:
  • begPos: Array format PositionASL
  • endPos: Array format PositionASL
  • objIgnore1: Object - (Optional, default objNull) object to ignore. When testing intersections from an object/unit/vehicle, pass that object here to prevent intersections inside of the object
  • objIgnore2: Object - (Optional, default objNull) another object to ignore. When testing intersections of a line between two objects, pass the second object here to prevent intersections inside of it being reported
Return Value:
Array format [result1, result2, ...] - true if an intersection happens with an object (not with terrain) for the Nth element

Examples

Example 1:
private _hasStraightLineToChopper = lineIntersects [eyePos player, aimPos chopper, player, chopper];
Example 2:
Alternative syntax to check intersections in parallel:
private _enemies = units opfor; private _enemyDataArray = _enemies apply { [eyePos player, aimPos _x, player, _x] }; private _result = lineIntersects _enemyDataArray;

Additional Information

See also:
lineIntersectsSurfaces lineIntersectsObjs lineIntersectsWith terrainIntersect terrainIntersectASL terrainIntersectAtASL intersect cursorObject cursorTarget checkVisibility

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
Lou Montana - c
Posted on May 31, 2012 - 10:46 (UTC)
Please note the difference: