BIS fnc setPitchBank: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "<br />" to "<br>")
m (Text replacement - "= <code>([^<{]+)<\/code>" to "= <sqf>$1</sqf>")
 
(27 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{Function|Comments=
{{RV|type=function
____________________________________________________________________________________________


| arma2 |Game name=
|game1= arma2
|version1= 1.00


|1.00|Game version=
|game2= arma2oa
____________________________________________________________________________________________
|version2= 1.50


| Rotate an object, giving it the specified pitch and bank, in degrees.<br>
|game3= tkoh
|version3= 1.00
 
|game4= arma3
|version4= 0.50
 
|gr1= Object Manipulation
 
|descr= Rotate an object, giving it the specified pitch and bank, in degrees.<br>
'''Pitch''' is 0 when the object is level; 90 when pointing straight up; and -90 when pointing straight down.<br>
'''Pitch''' is 0 when the object is level; 90 when pointing straight up; and -90 when pointing straight 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>
'''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=
|s1= [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= bank: [[Number]]


| [[Nothing]] |Return value=
|r1= [[Nothing]]
____________________________________________________________________________________________


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


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


<h3 style="display:none">Notes</h3>
{{Note
<dl class="command_description">
|user= ffur2007slx2_5
<!-- Note Section BEGIN -->
|timestamp= 20140804133500
<dd class="notedate">Posted on Aug 4, 2014 – 13:35
|text= {{Feature|informative|See also [[BIS_fnc_setObjectRotation]].}}
<dt class="note">[[User:ffur2007slx2_5|ffur2007slx2_5]]<dd class="note">
 
(A3 1.24) [[attachTo]] limits [[BIS_fnc_setPitchBank]], here’s an alternative function to break that limitation (code originated from [[bapedibupa]]):
(A3 1.24) [[attachTo]] limits [[BIS_fnc_setPitchBank]], here’s an alternative function to break that limitation (code originated from [[bapedibupa]]):
<code>
<sqf>
_obj [[attachTo]] [_logic,[0,0,2]];
_obj attachTo [_logic,[0,0,2]];
[_obj,[120,-78,37]] [[call]] fnc_SetPitchBankYaw; // pitch: 120, bank: -78, yaw: 37</code>
[_obj,[120,-78,37]] call fnc_SetPitchBankYaw; // pitch: 120, bank: -78, yaw: 37
<code>
</sqf>
<sqf>
fnc_SetPitchBankYaw = {  
fnc_SetPitchBankYaw = {  
    [[private]] ["_object","_rotations","_aroundX","_aroundY","_aroundZ","_dirX","_dirY","_dirZ","_upX","_upY","_upZ","_dir","_up","_dirXTemp",
private ["_object","_rotations","_aroundX","_aroundY","_aroundZ","_dirX","_dirY","_dirZ","_upX","_upY","_upZ","_dir","_up","_dirXTemp",
    "_upXTemp"];
"_upXTemp"];
    _object = _this [[select]] 0;  
_object = _this select 0;
    _rotations = _this [[select]] 1;  
_rotations = _this select 1;
    _aroundX = _rotations [[select]] 0;  
_aroundX = _rotations select 0;
    _aroundY = _rotations [[select]] 1;  
_aroundY = _rotations select 1;
    _aroundZ = (360 - (_rotations [[select]] 2)) - 360;  
_aroundZ = (360 - (_rotations select 2)) - 360;
    _dirX = 0;  
_dirX = 0;
    _dirY = 1;  
_dirY = 1;
    _dirZ = 0;  
_dirZ = 0;
    _upX = 0;  
_upX = 0;
    _upY = 0;  
_upY = 0;
    _upZ = 1;  
_upZ = 1;
    [[if]] (_aroundX != 0) [[then]] {  
if (_aroundX != 0) then {  
        _dirY = [[cos]] _aroundX;  
_dirY = cos _aroundX;
        _dirZ = [[sin]] _aroundX;  
_dirZ = sin _aroundX;
        _upY = -[[sin]] _aroundX;  
_upY = -sin _aroundX;
        _upZ = [[cos]] _aroundX;  
_upZ = cos _aroundX;
    };  
};
    [[if]] (_aroundY != 0) [[then]] {  
if (_aroundY != 0) then {  
        _dirX = _dirZ * [[sin]] _aroundY;  
_dirX = _dirZ * sin _aroundY;
        _dirZ = _dirZ * [[cos]] _aroundY;  
_dirZ = _dirZ * cos _aroundY;
        _upX = _upZ * [[sin]] _aroundY;  
_upX = _upZ * sin _aroundY;
        _upZ = _upZ * [[cos]] _aroundY;  
_upZ = _upZ * cos _aroundY;
    };  
};
    [[if]] (_aroundZ != 0) [[then]] {  
if (_aroundZ != 0) then {  
        _dirXTemp = _dirX;  
_dirXTemp = _dirX;
        _dirX = (_dirXTemp* [[cos]] _aroundZ) - (_dirY * [[sin]] _aroundZ);  
_dirX = (_dirXTemp* cos _aroundZ) - (_dirY * sin _aroundZ);
        _dirY = (_dirY * [[cos]] _aroundZ) + (_dirXTemp * [[sin]] _aroundZ);      
_dirY = (_dirY * cos _aroundZ) + (_dirXTemp * sin _aroundZ);
        _upXTemp = _upX;  
_upXTemp = _upX;
        _upX = (_upXTemp * [[cos]] _aroundZ) - (_upY * [[sin]] _aroundZ);  
_upX = (_upXTemp * cos _aroundZ) - (_upY * sin _aroundZ);
        _upY = (_upY * [[cos]] _aroundZ) + (_upXTemp * [[sin]] _aroundZ);
_upY = (_upY * cos _aroundZ) + (_upXTemp * sin _aroundZ);
    };  
};
    _dir = [_dirX,_dirY,_dirZ];  
_dir = [_dirX,_dirY,_dirZ];
    _up = [_upX,_upY,_upZ];  
_up = [_upX,_upY,_upZ];
    _object [[setVectorDirAndUp]] [_dir,_up];  
_object setVectorDirAndUp [_dir,_up];
};
};
</code>
</sqf>
<!-- Note Section END -->
}}
</dl>
 
<h3 style="display:none">Bottom Section</h3>
[[Category:Functions|{{uc:setPitchBank}}]]
[[Category:Function Group: Objects|{{uc:setPitchBank}}]]
[[Category:{{Name|arma2}}: Functions|{{uc:setPitchBank}}]]
[[Category:{{Name|arma2oa}}: Functions|{{uc:setPitchBank}}]]
[[Category:{{Name|tkoh}}: Functions|{{uc:setPitchBank}}]]
[[Category:{{Name|arma3}}: Functions|{{uc:setPitchBank}}]]

Latest revision as of 17:00, 13 July 2022

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
bank: Number
Return Value:
Nothing

Examples

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

Additional Information

See also:
BIS_fnc_getPitchBank vectorDir vectorUp setVectorDirAndUp

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 Aug 04, 2014 - 13:35 (UTC)

(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]; };