vectorCrossProduct: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "_{10,} " to "")
m (Text replacement - "<sqf>([^↵][^\/]*↵[^\/]*)<\/sqf>" to "<sqf> $1 </sqf>")
 
(49 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= Cross product of two 3D vectors.
<br>In layman's terms, if you have a polygon (surface) defined by 3 points, you can find a normal to it (just like terrain [[surfaceNormal]]). To invert direction of the normal, swap arguments around.


| Cross product of two 3D vectors.
|s1= vector1 [[vectorCrossProduct]] vector2
<br>In layman's terms, if you have a polygon (surface) defined by 3 points, you can find a normal to it (just like terrain [[surfaceNormal]]). To invert direction of the normal, swap arguments around. |DESCRIPTION=


| vector1 [[vectorCrossProduct]] vector2 |SYNTAX=
|p1= vector1[[Array]] - in form [x, y, z] or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)


|p1= vector1:  [[Array]] - in form [x, y, z] or 2D (since Arma 3 v1.99.146539, z coordinate is defaulted to 0)|PARAMETER1=
|p2= vector2:  [[Array]] - in form [x, y, z] or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)


|p2= vector2:  [[Array]] - in form [x, y, z] or 2D (since Arma 3 v1.99.146539, z coordinate is defaulted to 0)|PARAMETER2=
|r1= [[Array]] -  vector [x, y, z]
 
| [[Array]] -  vector [x, y, z]  
<br><br>
<br><br>
[[Image:crossProduct.jpg|300px]]|RETURNVALUE=
[[File:crossProduct.jpg|300px]]


|x1= <sqf>_vector = [1,1,1] vectorCrossProduct [2,2,2];</sqf>


 
|x2= <sqf>_vectorUp = [0,1,0] vectorCrossProduct [-1,0,0]; //[0,-0,1]</sqf>
|x1= <code>_vector = [1,1,1] [[vectorCrossProduct]] [2,2,2];</code> |EXAMPLE1=


|x2= <code>_vectorUp = [0,1,0] [[vectorCrossProduct]] [-1,0,0]; //[0,-0,1]</code> |EXAMPLE2=
|x3= <sqf>_vectorSide = (vectorDir player) vectorCrossProduct (vectorUp player);</sqf>
 
|x3= <code>_vectorSide = ([[vectorDir]] [[player]]) [[vectorCrossProduct]] ([[vectorUp]] [[player]]);</code> |EXAMPLE3=
 
| [[vectorAdd]], [[vectorDiff]], [[vectorDotProduct]], [[vectorCos]], [[vectorMagnitude]], [[vectorMagnitudeSqr]], [[vectorMultiply]], [[vectorDistance]], [[vectorDistanceSqr]], [[vectorDir]], [[vectorUp]], [[setVectorDir]], [[setVectorUp]], [[setVectorDirAndUp]], [[vectorNormalized]], [[vectorFromTo]], [[matrixMultiply]], [[matrixTranspose]]  |SEEALSO=


|seealso= [[vectorAdd]] [[vectorDiff]] [[vectorDotProduct]] [[vectorCos]] [[vectorMagnitude]] [[vectorMagnitudeSqr]] [[vectorMultiply]] [[vectorDistance]] [[vectorDistanceSqr]] [[vectorDir]] [[vectorUp]] [[setVectorDir]] [[setVectorUp]] [[setVectorDirAndUp]] [[vectorNormalized]] [[vectorFromTo]] [[matrixMultiply]] [[matrixTranspose]]
}}
}}


<h3 style="display:none">Notes</h3>
{{Note
<dl class="command_description">
|user= ffur2007slx2_5
<!-- Note Section BEGIN -->
|timestamp= 20140628091200
<dd class="notedate">Posted on 28 Jun, 2014
|text= {{GVI|arma3|1.22}}Algorithm:
<dt class="note">[[User:ffur2007slx2_5| ffur2007slx2_5]]
<sqf>
<dd class="note">
Vector1 = [x1,y1,z1]; Vector2 = [x2,y2,z2];
(ArmA3 1.22)Algorithm:
Result = [(y1 * z2) - (z1 * y2),(z1 * x2) - (x1 * z2),(x1 * y2) - (y1 * x2)];
<code>Vector1 = [x1,y1,z1]; Vector2 = [x2,y2,z2];
</sqf>
Result = [(y1 * z2) (z1 * y2),(z1 * x2) (x1 * z2),(x1 * y2) (y1 * x2)];</code>
It is recommended to use [[vectorCrossProduct]] instead of [[BIS_fnc_crossProduct]].
It is recommended to use [[vectorCrossProduct]] instead of [[BIS_fnc_crossProduct]].
<!-- Note Section END -->
}}
</dl>
 
<h3 style="display:none">Bottom Section</h3>

Latest revision as of 11:34, 3 September 2024

Hover & click on the images for description

Description

Description:
Cross product of two 3D vectors.
In layman's terms, if you have a polygon (surface) defined by 3 points, you can find a normal to it (just like terrain surfaceNormal). To invert direction of the normal, swap arguments around.
Groups:
Math - Vectors

Syntax

Syntax:
vector1 vectorCrossProduct vector2
Parameters:
vector1: Array - in form [x, y, z] or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)
vector2: Array - in form [x, y, z] or 2D (since Arma 3 v2.00, z coordinate is defaulted to 0)
Return Value:
Array - vector [x, y, z]

crossProduct.jpg

Examples

Example 1:
_vector = [1,1,1] vectorCrossProduct [2,2,2];
Example 2:
_vectorUp = [0,1,0] vectorCrossProduct [-1,0,0]; //[0,-0,1]
Example 3:
_vectorSide = (vectorDir player) vectorCrossProduct (vectorUp player);

Additional Information

See also:
vectorAdd vectorDiff vectorDotProduct vectorCos vectorMagnitude vectorMagnitudeSqr vectorMultiply vectorDistance vectorDistanceSqr vectorDir vectorUp setVectorDir setVectorUp setVectorDirAndUp vectorNormalized vectorFromTo 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
ffur2007slx2_5 - c
Posted on Jun 28, 2014 - 09:12 (UTC)
Arma 3 logo black.png1.22Algorithm:
Vector1 = [x1,y1,z1]; Vector2 = [x2,y2,z2]; Result = [(y1 * z2) - (z1 * y2),(z1 * x2) - (x1 * z2),(x1 * y2) - (y1 * x2)];
It is recommended to use vectorCrossProduct instead of BIS_fnc_crossProduct.