2024-01-08 21:22:52 +00:00
|
|
|
#include "script_component.hpp"
|
2017-06-08 13:31:51 +00:00
|
|
|
/*
|
|
|
|
* Author: ACE-Team
|
|
|
|
* Dev things
|
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* call ace_frag_fnc_doSpall
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2024-01-08 21:22:52 +00:00
|
|
|
params ["_projectile", "_hitObj", "", "_lPosASL", "_lVel", "", "", "" ,"_surfaceType"];
|
2017-12-29 01:08:11 +00:00
|
|
|
|
2024-01-08 21:22:52 +00:00
|
|
|
if (!isNil "_hitObj" && {_hitObj isKindOf "man"}) exitWith {};
|
2016-05-30 16:37:03 +00:00
|
|
|
|
2024-01-08 21:22:52 +00:00
|
|
|
if ((isNil "_lPosASL") || {!(_lPosASL isEqualTypeArray [0,0,0])}) exitWith {WARNING_1("Problem with hitPart data - bad pos [%1]",_lPosASL);};
|
2016-10-26 22:16:31 +00:00
|
|
|
|
|
|
|
|
2024-01-08 21:22:52 +00:00
|
|
|
private _posASL = _lPosASL;
|
|
|
|
private _vel = [0, 0, 0];
|
|
|
|
private _lVelUnit = vectorNormalized _lVel;
|
|
|
|
private _velMod = 1;
|
|
|
|
if (alive _projectile) then {
|
2024-01-09 05:59:06 +00:00
|
|
|
_vel = velocity _projectile;
|
|
|
|
_posASL = getPosASL _projectile;
|
|
|
|
// Dot product math
|
2024-01-08 21:22:52 +00:00
|
|
|
private _diffAngle = acos (_lVelUnit vectorDotProduct vectorNormalized _vel);
|
|
|
|
|
|
|
|
if (abs _diffAngle > 45) then {
|
|
|
|
SUB(_velMod, (vectorMagnitude _vel) / (vectorMagnitude _lVel));
|
2016-10-26 22:16:31 +00:00
|
|
|
};
|
2024-01-09 05:59:06 +00:00
|
|
|
_projectile setVariable [QGVAR(lastSpallTime), diag_tickTime ];
|
2016-05-30 16:37:03 +00:00
|
|
|
};
|
2017-12-29 01:08:11 +00:00
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
|
2024-01-08 21:22:52 +00:00
|
|
|
//** start calculating where the spalling should come **//
|
|
|
|
private _unitStep = _lVelUnit vectorMultiply 0.05;
|
|
|
|
private _spallPos = +_lPosASL;
|
|
|
|
// exit if we hit the ground
|
|
|
|
if (terrainIntersectASL [_lPosASL vectorAdd _unitStep, _lPosASL]) exitWith {};
|
|
|
|
// step through
|
|
|
|
for "_i" from 1 to 20 do
|
|
|
|
{
|
2024-01-09 05:59:06 +00:00
|
|
|
private _nPos = _spallPos vectorAdd _unitStep;
|
|
|
|
if (!lineIntersects [_spallPos, _nPos]) then {break};
|
|
|
|
_spallPos = +_nPos;
|
2016-10-26 22:16:31 +00:00
|
|
|
};
|
2024-01-10 05:17:08 +00:00
|
|
|
#ifdef DEBUG_MODE_DRAW
|
2024-01-10 06:55:33 +00:00
|
|
|
if (GVAR(dbgSphere)) then {
|
|
|
|
[_spallPos, "orange"] call FUNC(dev_sphereDraw);
|
|
|
|
[_lPosASL, "orange"] call FUNC(dev_sphereDraw);
|
|
|
|
};
|
2024-01-08 21:22:52 +00:00
|
|
|
#endif
|
|
|
|
// find last intersect with the object
|
|
|
|
|
|
|
|
private _ammo = typeOf _projectile;
|
|
|
|
private _explosive = getNumber (configFile >> "CfgAmmo" >> _ammo >> "explosive");
|
|
|
|
|
|
|
|
#ifdef DEBUG_MODE_FULL
|
|
|
|
private _dv = vectorMagnitude _lVel - vectorMagnitude _vel;
|
|
|
|
private _caliber = getNumber (configFile >> "cfgAmmo" >> _ammo >> "caliber");
|
|
|
|
systemChat ("dV: " + str _dv + ", caliber: " + str _caliber + ", product: " + str (_caliber*_dv));
|
|
|
|
#endif
|
2016-10-26 22:16:31 +00:00
|
|
|
|
|
|
|
if (_explosive > 0) then {
|
2024-01-09 20:00:43 +00:00
|
|
|
private _fragMod = (_ammo call FUNC(getFragInfo))#1;
|
2024-01-09 05:59:06 +00:00
|
|
|
_velMod = _fragMod * _velMod;
|
2016-05-30 16:37:03 +00:00
|
|
|
};
|
|
|
|
|
2016-10-26 22:16:31 +00:00
|
|
|
// diag_log text format ["SPALL POWER: %1", _spallPolar select 0];
|
2024-01-08 21:22:52 +00:00
|
|
|
// range of spread 15-40
|
|
|
|
// N rounds 5-15
|
|
|
|
// speed from 0.75-1.5
|
|
|
|
// range of spread 5-10
|
|
|
|
// N rounds 3-8
|
|
|
|
// speed from 0.75-1.5
|
|
|
|
private _velScalar = 0.33 * _velMod;
|
|
|
|
|
|
|
|
private _fragSpawner = QGVAR(base) createVehicleLocal [0,0,12345];
|
|
|
|
_fragSpawner setPosASL _spallPos;
|
|
|
|
_fragSpawner setVectorDirandUp [vectorDir _projectile, vectorUp _projectile];
|
|
|
|
_fragSpawner setVelocity (_lVelUnit vectorMultiply _velScalar);
|
|
|
|
|
|
|
|
|
2024-01-10 05:17:08 +00:00
|
|
|
#ifdef DEBUG_MODE_DRAW
|
2024-01-08 21:22:52 +00:00
|
|
|
_fragSpawner addEventHandler [
|
|
|
|
"SubmunitionCreated",
|
|
|
|
{
|
|
|
|
params ["", "_subProj"];
|
|
|
|
[_subProj] call FUNC(dev_addRound);
|
|
|
|
}
|
|
|
|
];
|
|
|
|
#endif
|