ACE3/addons/winddeflection/functions/fnc_updateTrajectoryPFH.sqf

57 lines
1.8 KiB
Plaintext
Raw Normal View History

/*
* Author: Glowbal, Ruthberg
* Handles wind deflection for projectiles.
*
* Arguments:
* 0: bullet - Object the event handler is assigned to <OBJECT>
* 1: airFriction - air friction of the bullet <NUMBER>
*
* Return Value:
* Nothing
*
* Example:
*
* Public: No
*/
2015-07-22 08:27:40 +00:00
// #define ENABLE_PERFORMANCE_COUNTERS
#include "script_component.hpp"
[{
2015-07-22 08:27:40 +00:00
// BEGIN_COUNTER(pfeh);
private["_accel", "_accelRef", "_bulletSpeed", "_bulletVelocity", "_deleted", "_deltaT", "_drag", "_dragRef", "_isWind", "_trueSpeed", "_trueVelocity"];
2015-07-22 08:04:54 +00:00
params ["_args"];
_args params ["_lastTime"];
2015-07-22 08:04:54 +00:00
_deltaT = ACE_time - _lastTime;
_args set [0, ACE_time];
2015-07-22 08:04:54 +00:00
_deleted = 0;
_isWind = (vectorMagnitude ACE_wind > 0);
{
_x params ["_bullet", "_airFriction"];
_bulletVelocity = velocity _bullet;
_bulletSpeed = vectorMagnitude _bulletVelocity;
if ((!alive _bullet) || {(_bullet isKindOf "BulletBase") && {_bulletSpeed < 100}}) then {
GVAR(trackedBullets) deleteAt (GVAR(trackedBullets) find _x);
2015-07-22 08:04:54 +00:00
} else {
if (_isWind) then {
_trueVelocity = _bulletVelocity vectorDiff ACE_wind;
_trueSpeed = vectorMagnitude _trueVelocity;
_dragRef = _deltaT * _airFriction * _bulletSpeed * _bulletSpeed;
_accelRef = (vectorNormalized _bulletVelocity) vectorMultiply (_dragRef);
_bulletVelocity = _bulletVelocity vectorDiff _accelRef;
_drag = _deltaT * _airFriction * _trueSpeed;
_accel = _trueVelocity vectorMultiply (_drag);
_bulletVelocity = _bulletVelocity vectorAdd _accel;
};
_bullet setVelocity _bulletVelocity;
};
nil
} count +GVAR(trackedBullets);
2015-07-22 08:27:40 +00:00
// END_COUNTER(pfeh);
2015-07-22 08:04:54 +00:00
}, GVAR(simulationInterval), [ACE_time]] call CBA_fnc_addPerFrameHandler;