vectorAdd: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - "<code>([^ ]*)\[\[([a-zA-Z][a-zA-Z0-9_]+)\]\]([^ ]*)<\/code>" to "<code>$1$2$3</code>")
m (Unify version info for vector commands)
 
(6 intermediate revisions by one other user not shown)
Line 6: Line 6:
|gr2= Math - Vectors
|gr2= Math - Vectors


|descr= Adds two 3D vectors. Replaces [[BIS_fnc_vectorAdd]].
|descr= Adds two arrays of numbers. Replaces [[BIS_fnc_vectorAdd]].<br>
{{Feature|GVI|arma3|2.14|Since {{GVI|arma3|2.14|size= 0.75}} any count of numbers is valid, if one array is larger than the other, the remaining elements are inserted without change.<br>
Before {{GVI|arma3|2.14|size= 0.75}}, the first argument had to be vector 3D, or {{GVI|arma3|2.00|size= 0.75}} 2D (Which still returned 3D result, with z coordinate defaulted to 0)}}


|s1= vector1 [[vectorAdd]] vector2
|s1= vector1 [[vectorAdd]] vector2


|p1= vector1: [[Array]] - vector 3D or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)
|p1= vector1: [[Array]] of [[Number]]s of any size


|p2= vector2: [[Array]] - vector 3D or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)
|p2= vector2: [[Array]] of [[Number]]s of any size


|r1= [[Array]]
|r1= [[Array]]


|x1= <code>hint str (velocity unit1 vectorAdd velocity unit2);</code>
|x1= <sqf>hint str (velocity unit1 vectorAdd velocity unit2);</sqf>


|x2= <code>[5,10,5] vectorAdd [5,5,10]; {{cc| returns [10,15,15]}}</code>
|x2= <sqf>[5, 10, 5] vectorAdd [5, 5, 10]; // returns [10, 15, 15]</sqf>


|x3= <code>[0,0] vectorAdd [1,-2]; {{cc| returns [1,-2,0]}}</code>
|x3= <sqf>[0, 0] vectorAdd [1, -2]; // returns [1, -2]</sqf>
 
|x4= <sqf>[1, 2, 3, 4, 5, 6] vectorAdd [10, 10, 10]; // returns [11, 12, 13, 4, 5, 6]</sqf>
 
|x5= <sqf>
[1, 2, 3] vectorAdd [1, 2, 3]; // [2, 4, 6]
[1, 2, 3] vectorAdd [1, 2]; // [2, 4, 3]
[1, 2] vectorAdd [1, 2, 3]; // [2, 4, 3]
[1, 2] vectorAdd [1, 2]; // [2, 4]
</sqf>


|seealso= [[vectorDiff]] [[vectorCrossProduct]] [[vectorDotProduct]] [[vectorCos]] [[vectorMagnitude]] [[vectorMagnitudeSqr]] [[vectorMultiply]] [[vectorDistance]] [[vectorDistanceSqr]] [[vectorDir]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[matrixMultiply]] [[matrixTranspose]]
|seealso= [[vectorDiff]] [[vectorCrossProduct]] [[vectorDotProduct]] [[vectorCos]] [[vectorMagnitude]] [[vectorMagnitudeSqr]] [[vectorMultiply]] [[vectorDistance]] [[vectorDistanceSqr]] [[vectorDir]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[matrixMultiply]] [[matrixTranspose]]
}}
{{Note
|user= Lou Montana
|timestamp= 20231102174030
|text= <sqf>
// between {{GVI|arma3|2.00|size= 0.75}} and {{GVI|arma3|2.14|size= 0.75}}:
[1, 2] vectorAdd [1, 2]; // [2, 4, 0]
</sqf>
}}
}}

Latest revision as of 16:28, 18 March 2025

Hover & click on the images for description

Description

Description:
Adds two arrays of numbers. Replaces BIS_fnc_vectorAdd.
Since Arma 3 logo black.png 2.14 any count of numbers is valid, if one array is larger than the other, the remaining elements are inserted without change.
Before Arma 3 logo black.png 2.14, the first argument had to be vector 3D, or Arma 3 logo black.png 2.00 2D (Which still returned 3D result, with z coordinate defaulted to 0)
Groups:
Math - Vectors

Syntax

Syntax:
vector1 vectorAdd vector2
Parameters:
vector1: Array of Numbers of any size
vector2: Array of Numbers of any size
Return Value:
Array

Examples

Example 1:
hint str (velocity unit1 vectorAdd velocity unit2);
Example 2:
[5, 10, 5] vectorAdd [5, 5, 10]; // returns [10, 15, 15]
Example 3:
[0, 0] vectorAdd [1, -2]; // returns [1, -2]
Example 4:
[1, 2, 3, 4, 5, 6] vectorAdd [10, 10, 10]; // returns [11, 12, 13, 4, 5, 6]
Example 5:
[1, 2, 3] vectorAdd [1, 2, 3]; // [2, 4, 6] [1, 2, 3] vectorAdd [1, 2]; // [2, 4, 3] [1, 2] vectorAdd [1, 2, 3]; // [2, 4, 3] [1, 2] vectorAdd [1, 2]; // [2, 4]

Additional Information

See also:
vectorDiff vectorCrossProduct vectorDotProduct vectorCos vectorMagnitude vectorMagnitudeSqr vectorMultiply vectorDistance vectorDistanceSqr vectorDir vectorUp setVectorDir setVectorUp setVectorDirAndUp matrixMultiply matrixTranspose

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 Nov 02, 2023 - 17:40 (UTC)
// between 2.00 and 2.14: [1, 2] vectorAdd [1, 2]; // [2, 4, 0]