vectorDir: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - ">Posted on February ([0-9]{1})[ a-zA-Z]*, ([0-9]{4})" to ">Posted on $2-02-0$1")
(Added image, standardized description, syntax and example)
Line 23: Line 23:
|gr2= Math - Vectors
|gr2= Math - Vectors


|descr= Returns object direction vector in world space ({{hl|[x,y,z]}}).
|descr= [[Image:arma3_object-vectors.jpg|thumb|right|An object with its [[vectorDir]], [[vectorUp]] and [[vectorSide]] (vectors not to scale)]]
{{Feature|important|The vector is '''not necessarily [[vectorNormalized|normalized]]'''. The [[vectorMagnitude|magnitude]] of the vector will be the same as the [[getObjectScale|object scale]].}}
Returns an object's direction vector in world space.
* A unit facing North would return {{hl|[0,1,0]}}
 
* A unit facing East would return {{hl|[1,0,0]}}
{{Feature|important|The vector is '''not necessarily [[vectorNormalized|normalized]]'''. The [[vectorMagnitude|magnitude]] of the vector depends on the [[getObjectScale|object's scale]].}}
* A unit facing South would return {{hl|[0,-1,0]}}
 
* A unit facing West would return {{hl|[-1,0,0]}}
For an object facing one of the cardinal directions on perfectly flat ground (parallel to the XY-plane of the world space), [[vectorDir]] returns simple values:
* {{hl|[0, 1, 0]}} if the object is facing directly north
* {{hl|[1, 0, 0]}} if the object is facing directly east
* {{hl|[0, -1, 0]}} if the object is facing directly south
* {{hl|[-1, 0, 0]}} if the object is facing directly west


|s1= [[vectorDir]] object
|s1= [[vectorDir]] object
Line 34: Line 38:
|p1= object: [[Object]]
|p1= object: [[Object]]


|r1= [[Array]] - format [[Vector3D]]
|r1= [[Array]] format [[Vector3D]]


|x1= <sqf>_dirVector = vectorDir _unit;</sqf>
|x1= <sqf>_vecDir = vectorDir MyObject;</sqf>


|seealso= [[vectorModelToWorld]] [[vectorDirVisual]] [[vectorSide]] [[vectorSideVisual]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[vectorDiff]] [[vectorAdd]] [[vectorMultiply]] [[vectorCrossProduct]] [[vectorDistance]] [[vectorMagnitudeSqr]] [[vectorDistanceSqr]] [[vectorCos]] [[vectorMagnitude]] [[vectorDotProduct]] [[vectorNormalized]] [[vectorFromTo]] [[BIS_fnc_transformVectorDirAndUp]]
|seealso= [[vectorModelToWorld]] [[vectorDirVisual]] [[vectorSide]] [[vectorSideVisual]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[vectorDiff]] [[vectorAdd]] [[vectorMultiply]] [[vectorCrossProduct]] [[vectorDistance]] [[vectorMagnitudeSqr]] [[vectorDistanceSqr]] [[vectorCos]] [[vectorMagnitude]] [[vectorDotProduct]] [[vectorNormalized]] [[vectorFromTo]] [[BIS_fnc_transformVectorDirAndUp]]

Revision as of 11:02, 9 September 2023

Hover & click on the images for description

Description

Description:
An object with its vectorDir, vectorUp and vectorSide (vectors not to scale)

Returns an object's direction vector in world space.

The vector is not necessarily normalized. The magnitude of the vector depends on the object's scale.

For an object facing one of the cardinal directions on perfectly flat ground (parallel to the XY-plane of the world space), vectorDir returns simple values:

  • [0, 1, 0] if the object is facing directly north
  • [1, 0, 0] if the object is facing directly east
  • [0, -1, 0] if the object is facing directly south
  • [-1, 0, 0] if the object is facing directly west
Groups:
Math - Vectors

Syntax

Syntax:
vectorDir object
Parameters:
object: Object
Return Value:
Array format Vector3D

Examples

Example 1:
_vecDir = vectorDir MyObject;

Additional Information

See also:
vectorModelToWorld vectorDirVisual vectorSide vectorSideVisual vectorUp setVectorDir setVectorUp setVectorDirAndUp vectorDiff vectorAdd vectorMultiply vectorCrossProduct vectorDistance vectorMagnitudeSqr vectorDistanceSqr vectorCos vectorMagnitude vectorDotProduct vectorNormalized vectorFromTo BIS_fnc_transformVectorDirAndUp

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


Posted on 2019-02-02 - 01:03 (UTC)
killzone_kid
vectorDir 2D:
[sin _azimuth, cos _azimuth, 0]
vectorDir 3D:
[sin _azimuth * cos _altitude, cos _azimuth * cos _altitude, sin _altitude]