vectorAdd: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - "_{10,} " to "")
m (Unify version info for vector commands)
 
(44 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{Command|Comments=
{{RV|type=command


| arma3 |Game name=
|game1= arma3
|version1= 1.22


|1.22|Game version=
|gr2= Math - Vectors


|gr2= Math - Vectors |GROUP2=
|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)}}


| Adds two 3D vectors. Replaces [[BIS_fnc_vectorAdd]]. |Description=
|s1= vector1 [[vectorAdd]] vector2


| vector1 [[vectorAdd]] vector2 |Syntax=
|p1= vector1: [[Array]] of [[Number]]s of any size


|p1= vector1: [[Array]] - vector 3D or 2D (since Arma 3 v1.99.146539, z coordinate is defaulted to 0) |Parameter 1=
|p2= vector2: [[Array]] of [[Number]]s of any size


|p2= vector2: [[Array]] - vector 3D or 2D (since Arma 3 v1.99.146539, z coordinate is defaulted to 0) |Parameter 2=
|r1= [[Array]]


| [[Array]] |Return value=
|x1= <sqf>hint str (velocity unit1 vectorAdd velocity unit2);</sqf>
 
|x1= <code>[[hint]] [[str]] ([[velocity]] unit1 [[vectorAdd]] [[velocity]] unit2);</code> |Example 1=


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


|x3= <code>[0,0] [[vectorAdd]] [1,-2]; {{codecomment|// returns [1,-2,0]}}</code> |Example 3=
|x3= <sqf>[0, 0] vectorAdd [1, -2]; // returns [1, -2]</sqf>


| [[vectorDiff]], [[vectorCrossProduct]], [[vectorDotProduct]], [[vectorCos]], [[vectorMagnitude]], [[vectorMagnitudeSqr]], [[vectorMultiply]], [[vectorDistance]], [[vectorDistanceSqr]], [[vectorDir]], [[vectorUp]], [[setVectorDir]], [[setVectorUp]], [[setVectorDirAndUp]], [[matrixMultiply]], [[matrixTranspose]] |See also=
|x4= <sqf>[1, 2, 3, 4, 5, 6] vectorAdd [10, 10, 10]; // returns [11, 12, 13, 4, 5, 6]</sqf>
}}


<h3 style="display:none">Notes</h3>
|x5= <sqf>
<dl class="command_description">
[1, 2, 3] vectorAdd [1, 2, 3]; // [2, 4, 6]
<!-- Note Section BEGIN -->
[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>


<!-- Note Section END -->
|seealso= [[vectorDiff]] [[vectorCrossProduct]] [[vectorDotProduct]] [[vectorCos]] [[vectorMagnitude]] [[vectorMagnitudeSqr]] [[vectorMultiply]] [[vectorDistance]] [[vectorDistanceSqr]] [[vectorDir]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[matrixMultiply]] [[matrixTranspose]]
</dl>
}}


<h3 style="display:none">Bottom Section</h3>
{{Note
 
|user= Lou Montana
 
|timestamp= 20231102174030
{{GameCategory|arma3|New Scripting Commands}}
|text= <sqf>
{{GameCategory|arma3|Scripting Commands}}
// between {{GVI|arma3|2.00|size= 0.75}} and {{GVI|arma3|2.14|size= 0.75}}:
[[Category:Scripting Commands|{{uc:{{PAGENAME}}}}]]
[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]