fnc_jammersPFH.sqf 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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 _interference = 1;
  21. {
  22. _x params["_jammer", "_radius", "_strength"];
  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 _specificSignal = (_t * ((1.6*_t*_t) - (3.9 * _t) + 3.3));
  42. private _specificInterference = _strength * (1 - _specificSignal);
  43. if(_interference == 1) then {
  44. _interference = _specificInterference;
  45. continue
  46. };
  47. _interference = _interference min _specificInterference; // Lowest value
  48. if(_interference < 1) then {
  49. _interference = 1; //prevent 0 from being final value
  50. };
  51. if(_interference > _strength) then {
  52. _interference = _strength; // prevent tfar from being exposed to 1.6e^24 when distance is null
  53. }
  54. };
  55. } forEach _jammers;
  56. // Set interference locally
  57. _player setVariable ["tf_receivingDistanceMultiplicator", _interference];
  58. _player setVariable ["tf_transmittingDistanceMultiplicator", _interference];
  59. systemChat format["Interference: %1", _interference];