fnc_jammersPFH.sqf 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. params["_args", "_handle"];
  2. _args params["_player"];
  3. /*
  4. * _jammers = [
  5. * [_jammer, _radius, _strength],
  6. * ["bis_o1", 1000, 400]
  7. * ];
  8. */
  9. if(!alive _player) exitWith { systemChat format["Player dead for %1", _handle] };
  10. _jammers = missionNamespace getVariable ["rd501_jammers",[]];
  11. // Exit if jammer list is empty, remove PFH and rely on someone else calling it via jammer placement
  12. if(count _jammers == 0) exitWith {
  13. systemChat "Exiting Client PFH";
  14. [_handle] call CBA_fnc_removePerFrameHandler;
  15. _player setVariable ["rd501_jammers_pfh", -1];
  16. _player setVariable ["tf_receivingDistanceMultiplicator", 1];
  17. _player setVariable ["tf_transmittingDistanceMultiplicator", 1];
  18. };
  19. // Aggregate the mean interference (multiple jammers allowed)
  20. private _signalStrength = 1;
  21. {
  22. _x params["_jammer", "_radius"];
  23. private _distance = _player distance _jammer;
  24. if (_distance < _radius) then {
  25. //cubic bezier curve
  26. // private _t = 0;
  27. // private _m = 1 -_t;
  28. // private _x0 = 0;
  29. // private _x1 = 1.1;
  30. // private _x2 = 0.9;
  31. // private _x3 = 1;
  32. // private _y0 = 0.1;
  33. // private _y1 = 0.5;
  34. // private _y2 = 0.8;
  35. // private _y3 = 1;
  36. // private _xr = (_y0*_m*_m*_m) + (3*_t*_y1*_m*_m) + (3*_t*_t*_y2*_m) + (_t*_t*_t*_y3);
  37. // private _yr = (_x0*_m*_m*_m) + (3*_t*_x1*_m*_m) + (3*_t*_t*_x2*_m) + (_t*_t*_t*_x3);
  38. // _yr simplifies approx to y=1.6t³ - 3.9t² + 3.3t
  39. // or t(1.6t² - 3.9t + 3.3)
  40. private _t = _distance/_radius;
  41. private _specificInterference = _t * ((1.6*_t*_t) - (3.9 * _t) + 3.3);
  42. if(_signalStrength == 1) then {
  43. _signalStrength = _specificInterference;
  44. continue
  45. };
  46. _signalStrength = (_signalStrength + _specificInterference)/2; // Average of interference plus current
  47. if(_signalStrength < 0.01) then {
  48. _signalStrength = 0.01; //prevent 0 from being final value
  49. };
  50. if(_signalStrength > 1) then {
  51. _signalStrength = 1; // prevent tfar from being exposed to 1.6e^24 when distance is null
  52. }
  53. };
  54. } forEach _jammers;
  55. // Set interference locally
  56. _player setVariable ["tf_receivingDistanceMultiplicator", _signalStrength];
  57. _player setVariable ["tf_transmittingDistanceMultiplicator", _signalStrength];
  58. systemChat format["Signal Strength: %1", _signalStrength];