Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ophthalmology - Add manual blinking and eye injuries #296

Open
wants to merge 54 commits into
base: dev-Tomcat
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
169f604
add: manual blinking
Katalam Apr 24, 2023
cc6eded
fix: style
Katalam Apr 24, 2023
eb972f2
fix: priority handler will now start at 1111
Katalam Apr 24, 2023
69a5c79
fix: disable manual blinking by default
Katalam Apr 24, 2023
bff90bc
add: dust injury
Katalam Apr 24, 2023
56eb58d
fix: tab in init
Katalam Apr 25, 2023
403d936
fix: stringtable
Katalam Apr 25, 2023
20537ed
fix: unit is better than player
Katalam Apr 25, 2023
53ba8be
fix: missing rename of displayname blink
Katalam Apr 25, 2023
25273bd
add: quoted getgvar
Katalam Apr 25, 2023
5d7b8ca
fix: _unit is better than _player
Katalam Apr 25, 2023
eb40d86
feat: eye washing
Katalam Apr 25, 2023
2640791
feat: eye washing is now written in activity log
Katalam Apr 25, 2023
c301a9b
feat: add eye washer as item
Katalam Apr 25, 2023
0db5464
fix: typo displayname eye wash item
Katalam Apr 25, 2023
3e73074
fix: pr comments
Katalam May 1, 2023
9c93c0e
feat: add treatment time to blink action
Katalam May 1, 2023
7c3b0f6
feat: add treatment time to eye wash action
Katalam May 1, 2023
b6d2bc1
feat: add medic required setting to eye wash
Katalam May 1, 2023
0f4a7f2
fix: pp effects should only initialize if used
Katalam May 1, 2023
10d70a7
fix: missing quote statements ace treatment actions
Katalam May 1, 2023
babe2a8
fix: cba setting missing a bracket
Katalam May 1, 2023
eccede9
fix(blink): wrong random weights
Katalam May 2, 2023
6af7176
style
Katalam May 2, 2023
3fe7f99
Merge branch 'dev-Tomcat' into feat/blink
YetheSamartaka Jun 24, 2023
a214b73
Merge branch 'dev-Tomcat' into feat/blink
MiszczuZPolski Mar 8, 2024
772b3ad
Merge branch 'dev-Tomcat' into pr/296
MiszczuZPolski Aug 10, 2024
99ff976
work work work
MiszczuZPolski Aug 10, 2024
ad317fa
Merge branch 'dev-Tomcat' into pr/296
MiszczuZPolski Sep 3, 2024
fba43a0
Merge branch 'dev-Tomcat' into pr/296
MiszczuZPolski Oct 9, 2024
9afa29b
Merge branch 'dev-Tomcat' into pr/296
MiszczuZPolski Dec 27, 2024
40cb8e9
update current
MiszczuZPolski Dec 27, 2024
2b20a9c
blindness effect
MiszczuZPolski Dec 27, 2024
6b52008
rework explosion EH plus re-add blinking effect
MiszczuZPolski Dec 28, 2024
ce522d1
Proper blink animation
mazinskihenry Dec 29, 2024
3dba5f7
Normal dust injury
mazinskihenry Dec 29, 2024
355dff7
Update
mazinskihenry Dec 29, 2024
38b88e4
Update fnc_fullHealLocal.sqf
mazinskihenry Dec 29, 2024
3bdd472
blurBlink
mazinskihenry Dec 29, 2024
afb1e38
clean up
MiszczuZPolski Dec 29, 2024
6cd792f
headers
MiszczuZPolski Dec 29, 2024
5d005c1
Update fnc_handleExplosion.sqf
MiszczuZPolski Dec 29, 2024
9b8de7e
Merge branch 'dev-Tomcat' into pr/296
MiszczuZPolski Jan 5, 2025
a77e556
add eyecovers
MiszczuZPolski Jan 5, 2025
619276e
Setting up eyeshield
mazinskihenry Jan 8, 2025
e4d0f09
Tabs and Stringtables
mazinskihenry Jan 8, 2025
045d247
Update fnc_treatmentAdvanced_eyeShield.sqf
mazinskihenry Jan 8, 2025
8045103
Icon
mazinskihenry Jan 8, 2025
ffe703e
Update CfgWeapons.hpp
mazinskihenry Jan 8, 2025
48801f0
Working response
mazinskihenry Jan 8, 2025
7ee2bee
Headers
mazinskihenry Jan 8, 2025
a5bd186
Update stringtable.xml
mazinskihenry Jan 8, 2025
aa31799
fix
MiszczuZPolski Jan 9, 2025
3555c26
move to event
MiszczuZPolski Jan 19, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion addons/feedback/XEH_PREP.hpp
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
PREP(effectBreathingWheeze);
PREP(effectCoughing);
PREP(effectEyeBlink);
PREP(effectEyeInjury);
PREP(effectHurtEye);
PREP(effectLowSpO2);
PREP(effectOpioid);
PREP(effectTearHaze);
PREP(handleEffects);
PREP(initEffects);
PREP(initEffects);
2 changes: 1 addition & 1 deletion addons/feedback/XEH_postInit.sqf
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@
params ["_unit", "_newCamera"];

[true] call FUNC(handleEffects);
}] call CBA_fnc_addPlayerEventHandler;
}] call CBA_fnc_addPlayerEventHandler;
Binary file added addons/feedback/data/BlindEffect.paa
Binary file not shown.
Binary file added addons/feedback/data/LeftEyeEffect.paa
Binary file not shown.
Binary file added addons/feedback/data/LowerBlink.paa
Binary file not shown.
Binary file added addons/feedback/data/RightEyeEffect.paa
Binary file not shown.
Binary file added addons/feedback/data/UpperBlink.paa
Binary file not shown.
75 changes: 75 additions & 0 deletions addons/feedback/functions/fnc_effectEyeBlink.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
#include "..\script_component.hpp"
/*
* Author: Mazinski
* Handles shock from explosions and covers eye injury transitions
*
* Arguments:
* 0: Time <NUMBER>
* 1: Shock <BOOL>
*
* Return Value:
* None
*
* Example:
* [1, false] call kat_feedback_fnc_effectEyeShock;
*
* Public: No
*/

params ["_time", "_shock"];
if (isNull findDisplay 46) exitWith {};

private _controls = uiNamespace getVariable [QGVAR(blinkControls), [controlNull, controlNull]];
_controls params ["_upperLid", "_lowerLid"];

// Initialize controls
if (isNull _upperLid) then {
TRACE_1("Creating Blink Controls",_controls);
_upperLid = findDisplay 46 ctrlCreate ["RscPicture", -1];
_lowerLid = findDisplay 46 ctrlCreate ["RscPicture", -1];

_upperLid ctrlSetText QPATHTOF(data\UpperBlink.paa);
_lowerLid ctrlSetText QPATHTOF(data\LowerBlink.paa);

_upperLid ctrlSetPosition [safeZoneXAbs, (safeZoneY - safeZoneH), safeZoneWAbs, safeZoneH];
_lowerLid ctrlSetPosition [safeZoneXAbs, (safeZoneY + safeZoneH), safeZoneWAbs, safeZoneH];

_upperLid ctrlSetFade 0;
_lowerLid ctrlSetFade 0;

_upperLid ctrlCommit 0;
_lowerLid ctrlCommit 0;

uiNamespace setVariable [QGVAR(blinkControls), [_upperLid, _lowerLid]];
};

_upperLid ctrlSetPosition [safeZoneXAbs, safeZoneY, safeZoneWAbs, safeZoneH];
_lowerLid ctrlSetPosition [safeZoneXAbs, safeZoneY, safeZoneWAbs, safeZoneH];

_upperLid ctrlCommit 0.04;
_lowerLid ctrlCommit 0.04;

if (_shock) then {
GVAR(ppBlurBlink) ppEffectEnable true;
GVAR(ppBlurBlink) ppEffectAdjust [0.4];
GVAR(ppBlurBlink) ppEffectCommit 0.04;
};

[{
params ["_upperLid", "_lowerLid", "_shock", "_time"];
_upperLid ctrlSetPosition [safeZoneXAbs, (safeZoneY - safeZoneH), safeZoneWAbs, safeZoneH];
_lowerLid ctrlSetPosition [safeZoneXAbs, (safeZoneY + safeZoneH), safeZoneWAbs, safeZoneH];

if (_shock) then {
_upperLid ctrlCommit 0.1;
_lowerLid ctrlCommit 0.1;

GVAR(ppBlurBlink) ppEffectAdjust [0];
GVAR(ppBlurBlink) ppEffectCommit (_time * 4);

[{ GVAR(ppBlurBlink) ppEffectEnable false; }, [], (_time * 4)] call CBA_fnc_waitAndExecute;
} else {
_upperLid ctrlCommit 0.04;
_lowerLid ctrlCommit 0.04;
};
}, [_upperLid, _lowerLid, _shock, _time], _time] call CBA_fnc_waitAndExecute;
59 changes: 59 additions & 0 deletions addons/feedback/functions/fnc_effectEyeInjury.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
#include "..\script_component.hpp"
/*
* Author: Mazinski
* Triggers eye injury effect from dust and rotor wash.
*
* Arguments:
* 0: Enable <BOOL>
* 1: Severity <NUMBER>
*
* Return Value:
* None
*
* Example:
* [true, 0.5] call kat_feedback_fnc_effectEyeInjury;
*
* Public: No
*/

params ["_enable", "_injurySeverity"];

if (isNull findDisplay 46) exitWith {};

private _controls = uiNamespace getVariable [QGVAR(eyeInjuryControls), [controlNull, controlNull]];
_controls params ["_upperLidShutter", "_lowerLidShutter"];

// Initialize controls
if (isNull _upperLidShutter) then {
TRACE_1("Creating Eye Injury Controls",_controls);
_upperLidShutter = findDisplay 46 ctrlCreate ["RscPicture", -1];
_lowerLidShutter = findDisplay 46 ctrlCreate ["RscPicture", -1];

_upperLidShutter ctrlSetText QPATHTOF(data\UpperBlink.paa);
_lowerLidShutter ctrlSetText QPATHTOF(data\LowerBlink.paa);

_upperLidShutter ctrlSetPosition [safeZoneXAbs, (safeZoneY - safeZoneH), safeZoneWAbs, safeZoneH];
_lowerLidShutter ctrlSetPosition [safeZoneXAbs, (safeZoneY + safeZoneH), safeZoneWAbs, safeZoneH];

_upperLidShutter ctrlSetFade 0;
_lowerLidShutter ctrlSetFade 0;

_upperLidShutter ctrlCommit 0;
_lowerLidShutter ctrlCommit 0;

uiNamespace setVariable [QGVAR(eyeInjuryControls), [_upperLidShutter, _lowerLidShutter]];
};

if (_enable) then {
_upperLidShutter ctrlSetPosition [safeZoneXAbs, ((safeZoneY - safeZoneH) + ((safeZoneH / 5) * _injurySeverity)), safeZoneWAbs, safeZoneH];
_lowerLidShutter ctrlSetPosition [safeZoneXAbs, ((safeZoneY + safeZoneH) - ((safeZoneH / 5) * _injurySeverity)), safeZoneWAbs, safeZoneH];

_upperLidShutter ctrlCommit 0.05;
_lowerLidShutter ctrlCommit 0.05;
} else {
_upperLidShutter ctrlSetPosition [safeZoneXAbs, (safeZoneY - safeZoneH), safeZoneWAbs, safeZoneH];
_lowerLidShutter ctrlSetPosition [safeZoneXAbs, (safeZoneY + safeZoneH), safeZoneWAbs, safeZoneH];

_upperLidShutter ctrlCommit 0;
_lowerLidShutter ctrlCommit 0;
};
80 changes: 80 additions & 0 deletions addons/feedback/functions/fnc_effectHurtEye.sqf
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
#include "..\script_component.hpp"
/*
* Author: MiszczuZPolski
* Handles the hurted eyes effect from explosions.
*
* Arguments:
* 0: Enable effect <BOOL>
* 1: Eyes state <ARRAY>
* 2: Instant change (optional, default false) <BOOL>
*
* Return Value:
* None
*
* Example:
* [false, 0.5] call kat_feedback_fnc_effectHurtEye
* Public: No
*/

params ["_enable", "_eyeArray", ["_instant", false]];
if (isNull findDisplay 46) exitWith {};

private _controls = uiNamespace getVariable [QGVAR(eyeControls), [controlNull, controlNull, controlNull]];
_controls params ["_eye1", "_eye2", "_wholeInjury"];

if (!_enable) exitWith {
_eye1 ctrlSetFade 1;
_eye2 ctrlSetFade 1;

_eye1 ctrlCommit 0;
_eye2 ctrlCommit 0;

_wholeInjury ctrlSetFade 1;
_wholeInjury ctrlCommit 0;
};

// Initialize controls
if (isNull _eye1) then {
TRACE_1("Creating Eye Controls",_controls);
_eye1 = findDisplay 46 ctrlCreate ["RscPicture", -1];
_eye2 = findDisplay 46 ctrlCreate ["RscPicture", -1];
_wholeInjury = findDisplay 46 ctrlCreate ["RscPicture", -1];

_eye1 ctrlSetText QPATHTOF(data\RightEyeEffect.paa);
_eye2 ctrlSetText QPATHTOF(data\LeftEyeEffect.paa);
_wholeInjury ctrlSetText QPATHTOF(data\BlindEffect.paa);

private _pos = [safeZoneXAbs, safeZoneY, safeZoneWAbs, safeZoneH];
_eye1 ctrlSetPosition _pos;
_eye2 ctrlSetPosition _pos;
_wholeInjury ctrlSetPosition _pos;

_eye1 ctrlSetFade 1;
_eye2 ctrlSetFade 1;
_wholeInjury ctrlSetFade 1;

_eye1 ctrlCommit 0;
_eye2 ctrlCommit 0;
_wholeInjury ctrlCommit 0;

uiNamespace setVariable [QGVAR(eyeControls), [_eye1, _eye2, _wholeInjury]];
};

_eyeArray params ["_rightEye", "_leftEye"];
_eye1 ctrlSetFade _rightEye;
_eye2 ctrlSetFade _leftEye;

_eye1 ctrlCommit 0;
_eye2 ctrlCommit 0;

if (_rightEye == 0 && _leftEye == 0) then {
_eye1 ctrlSetFade 1;
_eye2 ctrlSetFade 1;
_eye1 ctrlCommit 0;
_eye2 ctrlCommit 0;
_wholeInjury ctrlSetFade 0;
_wholeInjury ctrlCommit 0;
} else {
_wholeInjury ctrlSetFade 1;
_wholeInjury ctrlCommit 0;
};
6 changes: 6 additions & 0 deletions addons/feedback/functions/fnc_handleEffects.sqf
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ params [["_manualUpdate", false]];
if (ACEGVAR(common,OldIsCamera) || {!alive ACE_player}) exitWith {
[false] call FUNC(effectOpioid);
[false] call FUNC(effectLowSpO2);
[false] call FUNC(effectHurtEye);
[false] call FUNC(effectEyeInjury);
};

BEGIN_COUNTER(handleEffects);
Expand All @@ -30,6 +32,8 @@ private _unconscious = IS_UNCONSCIOUS(ACE_player);
private _poisoned = IS_AIRPOISONED(ACE_player);
private _tear = IN_TEARGAS(ACE_player);
private _wheeze = ((ACE_player getVariable [QGVAR(pneumothorax), 0] > 0) || ACE_player getVariable [QGVAR(hemopneumothorax), false] || ACE_player getVariable [QGVAR(tensionpneumothorax), false] || ACE_player getVariable [QEGVAR(chemical,airPoisoning), false]);
private _eyeInjurySeverity = GET_DUST_INJURY(ACE_player);
private _eyeInjuries = GET_EYE_INJURIES(ACE_player);

// - Visual effects -----------------------------------------------------------

Expand All @@ -43,5 +47,7 @@ private _wheeze = ((ACE_player getVariable [QGVAR(pneumothorax), 0] > 0) || ACE_
[!_unconscious, _poisoned, ACE_player] call FUNC(effectCoughing);
[!_unconscious, _tear] call FUNC(effectTearHaze);
[!_unconscious, _wheeze, ACE_player] call (effectBreathingWheeze);
[!_unconscious, _eyeInjurySeverity] call FUNC(effectEyeInjury);
[!_unconscious, _eyeInjuries, _manualUpdate] call FUNC(effectHurtEye);

END_COUNTER(handleEffects);
7 changes: 7 additions & 0 deletions addons/feedback/functions/fnc_initEffects.sqf
Original file line number Diff line number Diff line change
Expand Up @@ -61,3 +61,10 @@ GVAR(tearHaze) = [
0.0054, 0.0041, 0.0090, 0.0070,
0.5, 0.3, 10.0, 6.0]
] call _fnc_createEffect;

// - Eye Injury -----------------------------------------------------------
GVAR(ppBlurBlink) = [
"DynamicBlur",
213706,
[1]
] call _fnc_createEffect;
6 changes: 6 additions & 0 deletions addons/main/script_macros.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@
#define GETGVAR(var1,var2) GETMVAR(GVAR(var1),var2)
#define GETEGVAR(var1,var2,var3) GETMVAR(EGVAR(var1,var2),var3)

#define QGETGVAR(var1,var2) QUOTE(GETMVAR(QGVAR(var1),var2))
Katalam marked this conversation as resolved.
Show resolved Hide resolved

#define ARR_SELECT(ARRAY,INDEX,DEFAULT) (if (count ARRAY > INDEX) then {ARRAY select INDEX} else {DEFAULT})
#define ANY_OF(ARRAY,CONDITION) (ARRAY findIf {CONDITION} != -1)

Expand Down Expand Up @@ -343,3 +345,7 @@

#define IS_AIRPOISONED(unit) (unit getVariable [QEGVAR(chemical,airPoisoning), false])
#define IN_TEARGAS(unit) (unit getVariable [QEGVAR(chemical,CSGas), 0])

//Ophthalmology
#define GET_DUST_INJURY(unit) ((unit getVariable [QEGVAR(ophthalmology,dustInjuryLight), 0]) + (unit getVariable [QEGVAR(ophthalmology,dustInjuryHeavy), 0]))
#define GET_EYE_INJURIES(unit) (unit getVariable [QEGVAR(ophthalmology,eyeInjuries), [1,1]])
1 change: 1 addition & 0 deletions addons/ophthalmology/$PBOPREFIX$
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
x\kat\addons\ophthalmology
57 changes: 57 additions & 0 deletions addons/ophthalmology/ACE_Medical_Treatment_Actions.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
class ACE_Medical_Treatment_Actions {
class EyeWash {
displayName = CSTRING(eyewash_display);
displayNameProgress = CSTRING(eyewash_action);
category = "bandage";
treatmentLocations = 0;
allowedSelections[] = {"Head"};
allowSelfTreatment = 1;
medicRequired = QGVAR(eyewash_medic_required);
treatmentTime = QGVAR(eyewash_treatment_time);
items[] = {
"ACE_salineIV",
Katalam marked this conversation as resolved.
Show resolved Hide resolved
"ACE_salineIV_500",
"ACE_salineIV_250"
};
condition = QGETGVAR(enable,true);
callbackSuccess = QFUNC(treatmentAdvanced_eyewash);
callbackFailure = "";
callbackProgress = "";
consumeItem = 1;
animationPatient = "";
animationPatientUnconscious = "AinjPpneMstpSnonWrflDnon_rolltoback";
animationPatientUnconsciousExcludeOn[] = {"ainjppnemstpsnonwrfldnon"};
animationMedic = "AinvPknlMstpSlayWrflDnon_medicOther";
animationMedicProne = "AinvPpneMstpSlayW[wpn]Dnon_medicOther";
animationMedicSelf = "AinvPknlMstpSlayW[wpn]Dnon_medic";
animationMedicSelfProne = "AinvPpneMstpSlayW[wpn]Dnon_medic";
litter[] = {};
};

class EyeWashWater: EyeWash {
displayName = CSTRING(eyewash_display_water);
items[] = {
"ACE_Canteen",
"ACE_Canteen_Half",
"ACE_WaterBottle",
"ACE_WaterBottle_Half"
};
};

class EyeWasher: EyeWash {
displayName = CSTRING(eyewasher_display_item);
items[] = {"KAT_Eyewasher"};
};

class EyeShield: EyeWash {
displayName = CSTRING(eyeshield_display);
displayNameProgress = CSTRING(eyeshield_action);
medicRequired = QGVAR(eyeshield_medic_required);
treatmentTime = QGVAR(eyeshield_treatment_time);
items[] = {
"kat_eyecovers"
};
condition = QFUNC(eyeShieldCondition);
callbackSuccess = QFUNC(treatmentAdvanced_eyeShield);
};
};
20 changes: 20 additions & 0 deletions addons/ophthalmology/CfgEventHandlers.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
class Extended_PreInit_EventHandlers {
class ADDON {
init = QUOTE(call COMPILE_FILE(XEH_preInit));
disableModuload = "true";
};
};

class Extended_Init_EventHandlers {
class CAManBase {
class ADDON {
init = QUOTE([ARR_2((_this select 0),false)] call FUNC(init));
};
};
};

class Extended_PostInit_EventHandlers {
class ADDON {
init = QUOTE(call COMPILE_FILE(XEH_postInit));
};
};
22 changes: 22 additions & 0 deletions addons/ophthalmology/CfgMagazines.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
class CfgMagazines {
class CA_Magazine;

class KAT_Eyewasher: CA_Magazine {
author = "Katalam";
scope = 2;

displayName = CSTRING(eyewasher_display);
descriptionShort = CSTRING(eyewasher_desc);
picture = QPATHTOF(ui\icon_eyewasher.paa);

ammo = "";
count = 30;
initSpeed = 0;
tracersEvery = 0;
lastRoundsTracer = 0;
mass = 1;

ACE_isMedicalItem = 1;
ACE_asItem = 1;
};
};
Loading
Loading