setVectorDir: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "\|seealso= *\[\[([^ ]+)\]\], \[\[([^ ]+)\]\]" to "|seealso= $1 $2")
m (Text replacement - "{{HashLink" to "{{Link")
 
(3 intermediate revisions by the same user not shown)
Line 26: Line 26:
|descr= Set object's direction vector. Up vector will remain unchanged.
|descr= Set object's direction vector. Up vector will remain unchanged.


|pr= The effect is {{Icon|localeffect|32}} when using [[setVectorDir]] on a mine. Use a position modification to broadcast [[setVectorDir]]'s change (see {{HashLink|#Example 2}}).
|pr= The effect is {{Icon|localeffect|32}} when using [[setVectorDir]] on a mine. Use a position modification to broadcast [[setVectorDir]]'s change (see {{Link|#Example 2}}).


|s1= object [[setVectorDir]] [x,y,z]
|s1= object [[setVectorDir]] vectorDir


|p1= object: [[Object]]
|p1= object: [[Object]]


|p2= [x,y,z]: [[Array]] format [[Vector3D]]
|p2= vectorDir: [[Array]] format [[Vector3D]]


|r1= [[Nothing]]
|r1= [[Nothing]]


|x1= <code>[[player]] [[setVectorDir]] [5,6,1];</code>
|x1= <sqf>player setVectorDir [5,6,1];</sqf>


|x2= <code>{{cc|provided _myMine is local}}
|x2= <sqf>
_myMine [[setVectorDir]] [0.3, 1, 0];
// provided _myMine is local
_myMine [[setPosWorld]] [[getPosWorld]] _myMine;</code>
_myMine setVectorDir [0.3, 1, 0];
_myMine setPosWorld getPosWorld _myMine; // synchronises the mine's direction over the network (special case)
</sqf>


|seealso= [[vectorDir]] [[vectorUp]] [[setVectorUp]] [[setVectorDirAndUp]] [[vectorDiff]] [[vectorAdd]] [[vectorMultiply]] [[vectorCrossProduct]] [[vectorDistance]] [[vectorMagnitudeSqr]] [[vectorDistanceSqr]] [[vectorCos]] [[vectorMagnitude]] [[vectorDotProduct]] [[vectorNormalized]] [[vectorFromTo]]
|seealso= [[vectorDir]] [[vectorUp]] [[setVectorUp]] [[setVectorDirAndUp]] [[vectorDiff]] [[vectorAdd]] [[vectorMultiply]] [[vectorCrossProduct]] [[vectorDistance]] [[vectorMagnitudeSqr]] [[vectorDistanceSqr]] [[vectorCos]] [[vectorMagnitude]] [[vectorDotProduct]] [[vectorNormalized]] [[vectorFromTo]]
Line 55: Line 57:
|timestamp= 20090303210600
|timestamp= 20090303210600
|text= [[setVectorDir]] can only influence an object's pitch. It can not influence bank. Example:
|text= [[setVectorDir]] can only influence an object's pitch. It can not influence bank. Example:
<code>player setVectorDir [0,0,1]</code>
<sqf>player setVectorDir [0,0,1];</sqf>
*If the player is facing 0 degrees (north), then this will do NOTHING.
*If the player is facing 0 degrees (north), then this will do NOTHING.
*If the player is facing 90 degrees (east), then this will make him pitch 90 degrees up.
*If the player is facing 90 degrees (east), then this will make him pitch 90 degrees up.
Line 67: Line 69:


examples:
examples:
<code>{{cc|0 degrees (north)}}
<sqf>
[[player]] [[setVectorDir]]
// 0 degrees (north)
player setVectorDir
[
[
[[sin]] 0, {{cc|equals 0}}
sin 0, // equals 0
[[cos]] 0, {{cc|equals 1}}
cos 0, // equals 1
1
1
];
];
{{cc|45 degrees (north-east)}}
// 45 degrees (north-east)
[[player]] [[setVectorDir]]
player setVectorDir
[
[
[[sin]] 45, {{cc|equals 0.707}}
sin 45, // equals 0.707
[[cos]] 45, {{cc|equals 0.707}}
cos 45, // equals 0.707
1
1
];</code>
];
</sqf>
If you are doing trigonometric calculations, it may be better to use [[setVectorDir]] rather than [[setDir]], since sine and cosine have already been calculated and will not need to be re-calculated
If you are doing trigonometric calculations, it may be better to use [[setVectorDir]] rather than [[setDir]], since sine and cosine have already been calculated and will not need to be re-calculated
(also, [[setDir]] probably uses [[setVectorDir]] anyway.)
(also, [[setDir]] probably uses [[setVectorDir]] anyway.)
}}
}}

Latest revision as of 17:43, 4 January 2023

Hover & click on the images for description

Description

Description:
Set object's direction vector. Up vector will remain unchanged.
Problems:
The effect is LELocal when using setVectorDir on a mine. Use a position modification to broadcast setVectorDir's change (see Example 2).
Groups:
Math - Vectors

Syntax

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

Examples

Example 1:
player setVectorDir [5,6,1];
Example 2:
// provided _myMine is local _myMine setVectorDir [0.3, 1, 0]; _myMine setPosWorld getPosWorld _myMine; // synchronises the mine's direction over the network (special case)

Additional Information

See also:
vectorDir vectorUp setVectorUp setVectorDirAndUp vectorDiff vectorAdd vectorMultiply vectorCrossProduct vectorDistance vectorMagnitudeSqr vectorDistanceSqr vectorCos vectorMagnitude vectorDotProduct vectorNormalized vectorFromTo

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
Str - c
Posted on Mar 16, 2008 - 09:50 (UTC)
Command can be also used to rotate camera in all three axis.
General Barron - c
Posted on Mar 03, 2009 - 21:06 (UTC)
setVectorDir can only influence an object's pitch. It can not influence bank. Example:
player setVectorDir [0,0,1];
  • If the player is facing 0 degrees (north), then this will do NOTHING.
  • If the player is facing 90 degrees (east), then this will make him pitch 90 degrees up.
You can't directly pitch an object beyond 90 degrees, because this would change its facing direction. You must first flip it is direction using setDir, then you must bank the object 180 degrees, THEN you pitch the object appropriately.
DreadedEntity - c
Posted on Aug 17, 2015 - 03:27 (UTC)
In Arma 3, setVectorDir does not control an object's pitch or bank, in fact, it is not possible to change either of those solely using setVectorDir. This command can only affect horizontal rotation along the x-plane, unless an object first has it is vectorUp changed to something other than [0,0,1]. Correct input to setVectorDir should be calculated using the trigonometric functions sin and cos. examples:
// 0 degrees (north) player setVectorDir [ sin 0, // equals 0 cos 0, // equals 1 1 ]; // 45 degrees (north-east) player setVectorDir [ sin 45, // equals 0.707 cos 45, // equals 0.707 1 ];
If you are doing trigonometric calculations, it may be better to use setVectorDir rather than setDir, since sine and cosine have already been calculated and will not need to be re-calculated (also, setDir probably uses setVectorDir anyway.)