mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
8483a4bcdc
* Fix severity of wound bleeding I'm simplifying the nastiness calculations so that the wound config specifies the worst wound and we scale it between 25% to 100% based on the wound damage and number of wounds recieved. Similarly I've updated the wound configs to more reasonable maximum bleeding values based on the fact that they're percentages of cardiac output being bled. * Limit variance of pain modifier This is to avoid unexpectedly high pain for small wounds or unexpectedly small pain for large wounds * Make more wounds increase chance for nastiness Rather than guarantee * Adjust worst damage scaling This handles torso wounds better as they're typically around 0.3-0.6 for 6.5mm shots which makes them roughly medium sized. * Fix cardiac output calculation Previously the calculation didn't make sense as it wasn't outputting a value in l/s. This method of calculation makes more logical sense and provides a point of reference for what the bleeding values actually represent (percentage of the blood being pumped that is lost - which now has an actual volumetric value). * Fix blood pressure after change to cardiac output * Fix heartrate skyrocketing between 5l and 4l blood Pretty sure someone accidnentally got these conditions the wrong way around. This way blood pressure will first drop and then heart rate will later go up to compensate. * Fix comment typo Co-Authored-By: PabstMirror <pabstmirror@gmail.com>
32 lines
932 B
Plaintext
32 lines
932 B
Plaintext
#include "script_component.hpp"
|
|
/*
|
|
* Author: Glowbal
|
|
* Calculate the blood pressure of a unit.
|
|
*
|
|
* Arguments:
|
|
* 0: The Unit <OBJECT>
|
|
*
|
|
* Return Value:
|
|
* 0: BloodPressure Low <NUMBER>
|
|
* 1: BloodPressure High <NUMBER>
|
|
*
|
|
* Example:
|
|
* [player] call ace_medical_status_fnc_getBloodPressure
|
|
*
|
|
* Public: No
|
|
*/
|
|
|
|
// Value is taken because with cardic output and resistance at default values, it will put blood pressure High at 120.
|
|
#define MODIFIER_BP_HIGH 9.4736842
|
|
|
|
// Value is taken because with cardic output and resistance at default values, it will put blood pressure Low at 80.
|
|
#define MODIFIER_BP_LOW 6.3157894
|
|
|
|
params ["_unit"];
|
|
|
|
private _cardiacOutput = [_unit] call FUNC(getCardiacOutput);
|
|
private _resistance = _unit getVariable [VAR_PERIPH_RES, DEFAULT_PERIPH_RES];
|
|
private _bloodPressure = _cardiacOutput * _resistance;
|
|
|
|
[round(_bloodPressure * MODIFIER_BP_LOW), round(_bloodPressure * MODIFIER_BP_HIGH)]
|