BIS fnc setPitchBank: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "_{10,} " to "")
m (Text replacement - " *\| *([Cc]omments|COMMENTS|[Gg]ame [Nn]ame|Game [Vv]ersion|Game Version \(number surrounded by NO SPACES\)|Multiplayer Arguments \("local" or "global"\)|Multiplayer Effects \("local" or "global"\)|Multiplayer Execution \("server" o...)
Line 1: Line 1:
{{Function|Comments=
{{Function


| arma2 |Game name=
| arma2


|1.00|Game version=
|1.00


|gr1 = Object Manipulation |GROUP1=
|gr1 = Object Manipulation


| Rotate an object, giving it the specified pitch and bank, in degrees.<br>
| Rotate an object, giving it the specified pitch and bank, in degrees.<br>
Line 11: Line 11:
'''Bank''' is 0 when level; 90 when the object is rolled to the right, -90 when rolled to the left, and 180 when rolled upside down.<br>
'''Bank''' is 0 when level; 90 when the object is rolled to the right, -90 when rolled to the left, and 180 when rolled upside down.<br>
Note that the object's '''yaw''' can be set with the [[setDir]] command, which should be issued before using this function, if required.<br>
Note that the object's '''yaw''' can be set with the [[setDir]] command, which should be issued before using this function, if required.<br>
The pitch/bank can be leveled out (set to 0) by using the [[setDir]] command. |Description=
The pitch/bank can be leveled out (set to 0) by using the [[setDir]] command.


| [object, pitch, bank] call [[BIS_fnc_setPitchBank]] |Syntax=
| [object, pitch, bank] call [[BIS_fnc_setPitchBank]]


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


|p2= pitch: [[Number]] |Parameter 2=
|p2= pitch: [[Number]]


|p3= Number: [[Number]] |Parameter 3=
|p3= Number: [[Number]]


| [[Nothing]] |Return value=
| [[Nothing]]


|x1= <code><nowiki>[</nowiki>[[player]], 45, -45] [[call]] [[BIS_fnc_setPitchBank]];</code> |Example 1=
|x1= <code><nowiki>[</nowiki>[[player]], 45, -45] [[call]] [[BIS_fnc_setPitchBank]];</code>


| [[BIS_fnc_getPitchBank]], [[vectorDir]], [[vectorUp]], [[setVectorDirAndUp]] |See also=
| [[BIS_fnc_getPitchBank]], [[vectorDir]], [[vectorUp]], [[setVectorDirAndUp]]
}}
}}



Revision as of 23:45, 17 January 2021

Hover & click on the images for description

Description

Description:
Rotate an object, giving it the specified pitch and bank, in degrees.
Pitch is 0 when the object is level; 90 when pointing straight up; and -90 when pointing straight down.
Bank is 0 when level; 90 when the object is rolled to the right, -90 when rolled to the left, and 180 when rolled upside down.
Note that the object's yaw can be set with the setDir command, which should be issued before using this function, if required.
The pitch/bank can be leveled out (set to 0) by using the setDir command.
Execution:
call
Groups:
Object Manipulation

Syntax

Syntax:
[object, pitch, bank] call BIS_fnc_setPitchBank
Parameters:
object: Object
pitch: Number
Number: Number
Return Value:
Nothing

Examples

Example 1:
[player, 45, -45] call BIS_fnc_setPitchBank;

Additional Information

See also:
BIS_fnc_getPitchBankvectorDirvectorUpsetVectorDirAndUp

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

Notes

Posted on Aug 4, 2014 – 13:35
ffur2007slx2_5
(A3 1.24) attachTo limits BIS_fnc_setPitchBank, here’s an alternative function to break that limitation (code originated from bapedibupa): _obj attachTo [_logic,[0,0,2]]; [_obj,[120,-78,37]] call fnc_SetPitchBankYaw; // pitch: 120, bank: -78, yaw: 37 fnc_SetPitchBankYaw = { private ["_object","_rotations","_aroundX","_aroundY","_aroundZ","_dirX","_dirY","_dirZ","_upX","_upY","_upZ","_dir","_up","_dirXTemp", "_upXTemp"]; _object = _this select 0; _rotations = _this select 1; _aroundX = _rotations select 0; _aroundY = _rotations select 1; _aroundZ = (360 - (_rotations select 2)) - 360; _dirX = 0; _dirY = 1; _dirZ = 0; _upX = 0; _upY = 0; _upZ = 1; if (_aroundX != 0) then { _dirY = cos _aroundX; _dirZ = sin _aroundX; _upY = -sin _aroundX; _upZ = cos _aroundX; }; if (_aroundY != 0) then { _dirX = _dirZ * sin _aroundY; _dirZ = _dirZ * cos _aroundY; _upX = _upZ * sin _aroundY; _upZ = _upZ * cos _aroundY; }; if (_aroundZ != 0) then { _dirXTemp = _dirX; _dirX = (_dirXTemp* cos _aroundZ) - (_dirY * sin _aroundZ); _dirY = (_dirY * cos _aroundZ) + (_dirXTemp * sin _aroundZ); _upXTemp = _upX; _upX = (_upXTemp * cos _aroundZ) - (_upY * sin _aroundZ); _upY = (_upY * cos _aroundZ) + (_upXTemp * sin _aroundZ); }; _dir = [_dirX,_dirY,_dirZ]; _up = [_upX,_upY,_upZ]; _object setVectorDirAndUp [_dir,_up]; };

Bottom Section