From 1695837e0ce1a8abf578b08dcd72db97b5972677 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 13:10:55 -0500 Subject: [PATCH 01/28] 1.42 Inventory Config --- addons/inventory/RscDisplayInventory.hpp | 142 +++++++++++++---------- 1 file changed, 80 insertions(+), 62 deletions(-) diff --git a/addons/inventory/RscDisplayInventory.hpp b/addons/inventory/RscDisplayInventory.hpp index c8c93ab142..f845f50a35 100644 --- a/addons/inventory/RscDisplayInventory.hpp +++ b/addons/inventory/RscDisplayInventory.hpp @@ -39,14 +39,14 @@ class RscDisplayInventory { x = X_PART(1); y = Y_PART(1); w = W_PART(12); - h = H_PART(22.5); + h = H_PART(22.5); //default 23 }; class CA_PlayerBackground: RscText { //center player's container: decrease height because of progressbar height decrease x = X_PART(14.6); y = Y_PART(2); w = W_PART(24.4); - h = H_PART(21.5); + h = H_PART(21.5); //default 22 }; class TitleBackground: RscText { x = X_PART(14.6); @@ -87,25 +87,31 @@ class RscDisplayInventory { class BackgroundSlotPrimaryMuzzle: BackgroundSlotPrimary { x = X_PART(26.6); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); + h = H_PART(2); + }; + class BackgroundSlotPrimaryUnderBarrel: BackgroundSlotPrimary { + x = X_PART(29); + y = Y_PART(9.1); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotPrimaryFlashlight: BackgroundSlotPrimary { - x = X_PART(29.6); - y = Y_PART(9.1); - w = W_PART(2.9); + x = X_PART(31.4); + y = Y_PART(9.2); //not sure why different (double check release) + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotPrimaryOptics: BackgroundSlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotPrimaryMagazine: BackgroundSlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotSecondary: BackgroundSlotPrimary { @@ -117,25 +123,31 @@ class RscDisplayInventory { class BackgroundSlotSecondaryMuzzle: BackgroundSlotPrimary { x = X_PART(26.6); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); + h = H_PART(2); + }; + class BackgroundSlotSecondaryUnderBarrel: BackgroundSlotPrimary { + x = X_PART(29); + y = Y_PART(14.6); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotSecondaryFlashlight: BackgroundSlotPrimary { - x = X_PART(29.6); + x = X_PART(31.4); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotSecondaryOptics: BackgroundSlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotSecondaryMagazine: BackgroundSlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotHandgun: BackgroundSlotPrimary { @@ -147,25 +159,31 @@ class RscDisplayInventory { class BackgroundSlotHandgunMuzzle: BackgroundSlotPrimary { x = X_PART(26.6); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); + h = H_PART(2); + }; + class BackgroundSlotHandgunUnderBarrel: BackgroundSlotPrimary { + x = X_PART(29); + y = Y_PART(20.1); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotHandgunFlashlight: BackgroundSlotPrimary { - x = X_PART(29.6); + x = X_PART(31.4); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotHandgunOptics: BackgroundSlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotHandgunMagazine: BackgroundSlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class BackgroundSlotHeadgear: BackgroundSlotPrimary { @@ -263,7 +281,7 @@ class RscDisplayInventory { x = X_PART(1.5); y = Y_PART(22.5); w = W_PART(11); - h = H_PART(0.5); + h = H_PART(0.5); //Default 1 }; class SlotPrimary: GroundTab { x = X_PART(26.6); @@ -274,31 +292,31 @@ class RscDisplayInventory { class SlotPrimaryMuzzle: SlotPrimary { x = X_PART(26.6); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; - class SlotPrimaryGrip: SlotPrimary { - w = 0; - h = 0; - x = X_PART(39); - y = Y_PART(9); + class SlotPrimaryUnderBarrel: SlotPrimary { + x = X_PART(29); + y = Y_PART(9.1); + w = W_PART(2.3); + h = H_PART(2); }; class SlotPrimaryFlashlight: SlotPrimary { - x = X_PART(29.6); + x = X_PART(31.4); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotPrimaryOptics: SlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotPrimaryMagazine: SlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(9.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotSecondary: SlotPrimary { @@ -310,31 +328,31 @@ class RscDisplayInventory { class SlotSecondaryMuzzle: SlotPrimary { x = X_PART(26.6); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; - class SlotSecondaryGrip: SlotPrimary { - w = 0; - h = 0; - x = X_PART(39); - y = Y_PART(14.5); + class SlotSecondaryUnderBarrel: SlotPrimary { + x = X_PART(29); + y = Y_PART(14.59); //Why is this different? (check release) + w = W_PART(2.3); + h = H_PART(2); }; class SlotSecondaryFlashlight: SlotPrimary { - x = X_PART(29.6); + x = X_PART(31.4); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotSecondaryOptics: SlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotSecondaryMagazine: SlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(14.6); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotHandgun: SlotPrimary { @@ -346,31 +364,31 @@ class RscDisplayInventory { class SlotHandgunMuzzle: SlotPrimary { x = X_PART(26.6); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; - class SlotHandgunGrip: SlotPrimary { - w = 0; - h = 0; - x = X_PART(39); - y = Y_PART(20); + class SlotHandgunUnderBarrel: SlotPrimary { + x = X_PART(29); + y = Y_PART(20.1); + W = W_PART(2.3); + H = H_PART(2); }; class SlotHandgunFlashlight: SlotPrimary { - x = X_PART(29.6); + x = X_PART(31.4); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotHandgunOptics: SlotPrimary { - x = X_PART(32.6); + x = X_PART(33.8); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotHandgunMagazine: SlotPrimary { - x = X_PART(35.6); + x = X_PART(36.2); y = Y_PART(20.1); - w = W_PART(2.9); + w = W_PART(2.3); h = H_PART(2); }; class SlotHeadgear: SlotPrimary { @@ -492,7 +510,7 @@ class RscDisplayInventory { x = X_PART(15.1); y = Y_PART(22.5); w = W_PART(23.4); - h = H_PART(0.5); + h = H_PART(0.5); //Default 1 }; class ContainerMarker: GroundTab { x = X_PART(0); From 63b7f0a755640b4d490ce3311eadc9b7386ccb35 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 19:22:49 -0500 Subject: [PATCH 02/28] Marker Fixes for 1.42 WIP --- addons/markers/InsertMarker.hpp | 127 +++--------------- addons/markers/XEH_preInit.sqf | 30 +---- .../functions/fnc_initInsertMarker.sqf | 89 +++++------- 3 files changed, 59 insertions(+), 187 deletions(-) diff --git a/addons/markers/InsertMarker.hpp b/addons/markers/InsertMarker.hpp index 3cf32943c4..82712fa8f1 100644 --- a/addons/markers/InsertMarker.hpp +++ b/addons/markers/InsertMarker.hpp @@ -1,4 +1,3 @@ - class RscPicture; class RscText; class RscStructuredText; @@ -13,91 +12,34 @@ class RscXSliderH; class RscDisplayInsertMarker { onLoad = QUOTE(_this call DFUNC(initInsertMarker);); onUnload = QUOTE(_this call DFUNC(placeMarker);); - idd = 54; + // idd = 54; movingEnable = 1; class controlsBackground { - class RscText_1000: RscText { - idc = 1000; - /*x = "0 * GUI_GRID_INSERTMARKER_W + GUI_GRID_INSERTMARKER_X"; - y = "0 * GUI_GRID_INSERTMARKER_H + GUI_GRID_INSERTMARKER_Y"; - w = "8 * GUI_GRID_INSERTMARKER_W"; - h = "2.5 * GUI_GRID_INSERTMARKER_H"; - colorBackground[] = {0,0,0,0.5};*/ - }; - class Description: RscStructuredText { - colorBackground[] = {0,0,0,0.7}; - idc = 1100; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "9.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; + // class RscText_1000: RscText {idc = 1000;}; }; class controls { - //delete ButtonOK; - class ButtonMenuOK: RscButtonMenuOK { - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "8.9 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - // size = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - // sizeEx = "0.85 * ( ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) * 1)"; - text = ""; + // class ButtonMenuOK: RscButtonMenuOK {idc = 1;}; + // class ButtonMenuCancel: RscButtonMenuCancel {idc = 2;}; + // class Title: RscText {idc = 1001;}; + // class Description: RscStructuredText {idc = 1100;}; + // class DescriptionChannel: RscStructuredText {idc = 1101;}; + // class MarkerPicture: RscPicture {idc = 102;}; + // class MarkerText: RscEdit {idc = 101;}; + // class MarkerChannel: RscCombo {idc = 103;}; + + class MarkerShape: RscCombo { + idc = 1210; }; - class ButtonMenuCancel: RscButtonMenuCancel { - x = "23 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "15.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "1.1 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - - text = "X"; - colorBackground[] = {0.75,0,0,0.5}; - colorBackgroundFocused[] = {0.75,0,0,0.5}; - colorBackground2[] = {1,0,0,0.5}; + class MarkerColor: RscCombo { + idc = 1211; }; - /*class ButtonMenuInfo: RscButtonMenu { - idc = 2400; - text = "$STR_A3_RscDisplayInsertMarker_ButtonMenuInfo"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - };*/ - delete ButtonMenuInfo; - class Title: RscText { - moving = 1; - colorBackground[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.69])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.75])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.5])","(profilenamespace getvariable ['GUI_BCG_RGB_A',0.8])"}; - idc = 1001; - text = "$STR_A3_RscDisplayInsertMarker_Title"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "8.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + class MarkerAngle: RscXSliderH { + idc = 1220; }; - delete Description; - /*class Info: RscStructuredText { - colorBackground[] = {0,0,0,0.7}; - idc = 1101; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - };*/ - delete Info; - class Picture: RscPicture { - idc = 102; - x = 0.259984; - y = 0.4; - w = 0.05; - h = 0.0666667; - }; - class Text: RscEdit { - idc = 101; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "10.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; + class MarkerAngleText: RscText { + idc = 1221; }; + /*class SizeX: RscEdit { idc = 1200; text = "10"; @@ -114,34 +56,5 @@ class RscDisplayInsertMarker { w = "5 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; };*/ - class MarkerShape: RscCombo { - idc = 1210; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "11.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerColor: RscCombo { - idc = 1211; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "12.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerAngle: RscXSliderH { - idc = 1220; - text = "10"; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "13.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; - class MarkerAngleText: RscText { - idc = 1221; - x = "14 * ( ((safezoneW / safezoneH) min 1.2) / 40) + (safezoneX)"; - y = "14.5 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + (safezoneY + safezoneH - ( ((safezoneW / safezoneH) min 1.2) / 1.2))"; - w = "10 * ( ((safezoneW / safezoneH) min 1.2) / 40)"; - h = "1 * ( ( ((safezoneW / safezoneH) min 1.2) / 1.2) / 25)"; - }; }; }; diff --git a/addons/markers/XEH_preInit.sqf b/addons/markers/XEH_preInit.sqf index 8e07056da4..53fdc70b41 100644 --- a/addons/markers/XEH_preInit.sqf +++ b/addons/markers/XEH_preInit.sqf @@ -14,25 +14,15 @@ PREP(setMarkerNetwork); // init marker types if (isNil QGVAR(MarkersCache)) then { _config = configfile >> "CfgMarkers"; - _index = 0; - GVAR(MarkersCache) = []; for "_a" from 0 to (count _config - 1) do { _marker = _config select _a; - _scope = getNumber (_marker >> "scope"); - _name = getText (_marker >> "name"); - _icon = getText (_marker >> "icon"); - if (_scope == 2) then { - _shape lbAdd _name; - _shape lbSetValue [_index, _a]; - _shape lbSetPicture [_index, _icon]; - + _name = getText (_marker >> "name"); + _icon = getText (_marker >> "icon"); GVAR(MarkersCache) pushBack [_name, _a, _icon]; - - _index = _index + 1; }; }; }; @@ -40,39 +30,27 @@ if (isNil QGVAR(MarkersCache)) then { // init marker colors if (isNil QGVAR(MarkerColorsCache)) then { _config = configfile >> "CfgMarkerColors"; - _index = 0; - GVAR(MarkerColorsCache) = []; for "_a" from 0 to (count _config - 1) do { _marker = _config select _a; - _scope = getNumber (_marker >> "scope"); - _name = getText (_marker >> "name"); - if (_scope == 2) then { - _color lbAdd _name; - _color lbSetValue [_index, _a]; - + _name = getText (_marker >> "name"); _rgba = getArray (_marker >> "color"); - { if (typeName _x != "SCALAR") then { _rgba set [_forEachIndex, call compile _x]; }; } forEach _rgba; - _icon = format ["#(argb,8,8,3)color(%1,%2,%3,%4)", _rgba select 0, _rgba select 1, _rgba select 2, _rgba select 3]; - _color lbSetPicture [_index, _icon]; - GVAR(MarkerColorsCache) pushBack [_name, _a, _icon]; - - _index = _index + 1; }; }; }; +//Server Sync JIP markers: [QGVAR(sendMarkersJIP), FUNC(sendMarkersJIP)] call EFUNC(common,addEventHandler); ADDON = true; diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index e5328a7470..979d754959 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -15,14 +15,19 @@ // prevent vanilla key input _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; + //BIS Controlls: _text = _display displayctrl 101; _picture = _display displayctrl 102; + _channel = _display displayctrl 103; _buttonOK = _display displayctrl 1; _buttonCancel = _display displayctrl 2; _description = _display displayctrl 1100; _title = _display displayctrl 1001; - _sizeX = _display displayctrl 1200; - _sizeY = _display displayctrl 1201; + _descriptionChannel = _display displayctrl 1101; + + //ACE Controlls: + // _sizeX = _display displayctrl 1200; + // _sizeY = _display displayctrl 1201; _shape = _display displayctrl 1210; _color = _display displayctrl 1211; _angle = _display displayctrl 1220; @@ -30,51 +35,6 @@ ctrlSetFocus _text; - //Change ok button's text based on current channel - [{ - EXPLODE_2_PVT(_this,_params,_pfhId); - EXPLODE_1_PVT(_params,_buttonOK); - - if (isNull _buttonOK) exitWith { - [_pfhId] call CBA_fnc_removePerFrameHandler; - }; - - _channel = ""; - _textColor = [1,1,1,1]; - switch (call EFUNC(common,currentChannel)) do { - case ("global"): { - _channel = localize "str_channel_global"; - _textColor = [(216/255),(216/255),(216/255),1]; - }; - case ("side"): { - _channel = localize "str_channel_side"; - _textColor = [(70/255),(211/255),(252/255),1]; - }; - case ("group"): { - _channel = localize "str_channel_group"; - _textColor = [(181/255),(248/255),(98/255),1]; - }; - case ("vehicle"): { - _channel = localize "str_channel_vehicle"; - _textColor = [(255/255),(208/255),(0/255),1]; - }; - case ("direct"): { - _channel = localize "str_channel_direct"; - _textColor = [(255/255),(255/255),(255/255),1]; - }; - case ("command"): { - _channel = localize "str_channel_command"; - _textColor = [(255/255),(255/255),(70/255),1]; - }; - }; - - //If localization not found, then don't touch anything (default is RscButtonMenuOK's localized text) - if (_channel != "") then { - _buttonOK ctrlSetTextColor _textColor; - _buttonOK ctrlSetText format [localize "STR_ACE_Markers_PlaceIn", _channel]; - }; - }, 0, [_buttonOK]] call CBA_fnc_addPerFrameHandler; - //--- Background _pos = ctrlposition _text; _posX = (_pos select 0) + 0.01; @@ -96,12 +56,11 @@ //--- Description _pos set [1,_posY - 1*_posH]; _pos set [3,6*_posH + 6 * BORDER]; + _description ctrlenable false; _description ctrlsetposition _pos; - _description ctrlsetstructuredtext parsetext format ["%1","Description:"]; //--- ToDo: Localze + _description ctrlsetstructuredtext parsetext format ["%1", (localize "str_lib_label_description")]; _description ctrlcommit 0; - _activeColor = (["IGUI","WARNING_RGB"] call bis_fnc_displaycolorget) call bis_fnc_colorRGBtoHTML; - //--- Shape _pos set [1,_posY + 1 * _posH + 2 * BORDER]; _pos set [2,_posW]; @@ -127,15 +86,37 @@ _angleText ctrlsetposition _pos; _angleText ctrlcommit 0; + _offsetButtons = 0; + if (ismultiplayer) then { + _pos set [1,_posY + 5 * _posH + 7 * BORDER]; + _pos set [3,_posH]; + _descriptionChannel ctrlsetstructuredtext parsetext format ["%1", (localize "str_a3_cfgvehicles_modulerespawnposition_f_arguments_marker_0") + ":"]; + _descriptionChannel ctrlsetposition _pos; + _descriptionChannel ctrlcommit 0; + + _pos set [1,_posY + 6 * _posH + 7 * BORDER]; + _pos set [3,_posH]; + _channel ctrlsetposition _pos; + _channel ctrlcommit 0; + _offsetButtons = 7 * _posH + 8 * BORDER; + } else { + _descriptionChannel ctrlshow false; + _channel ctrlshow false; + _offsetButtons = 5 * _posH + 7 * BORDER; + }; + //--- ButtonOK - _pos set [1,_posY + 5 * _posH + 7 * BORDER]; - _pos set [2,_posW * (8.9/10) - BORDER]; + _pos set [1,_posY + _offsetButtons]; + _pos set [2,_posW / 2 - BORDER]; + _pos set [3,_posH]; _buttonOk ctrlsetposition _pos; _buttonOk ctrlcommit 0; //--- ButtonCancel - _pos set [0,_posX + _posW * (8.9 / 10)]; - _pos set [2,_posW * (1.1 / 10)]; + _pos set [0,_posX + _posW / 2]; + _pos set [1,_posY + _offsetButtons]; + _pos set [2,_posW / 2]; + _pos set [3,_posH]; _buttonCancel ctrlsetposition _pos; _buttonCancel ctrlcommit 0; From 24bba5dea626432cf72646fea74e89d9a74236f9 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 20:51:30 -0500 Subject: [PATCH 03/28] Headers --- addons/markers/CfgEventHandlers.hpp | 1 - .../functions/fnc_initInsertMarker.sqf | 118 +++++++++--------- .../functions/fnc_onLBSelChangedColor.sqf | 26 +++- .../functions/fnc_onLBSelChangedShape.sqf | 25 +++- .../functions/fnc_onSliderPosChangedAngle.sqf | 24 +++- addons/markers/functions/fnc_placeMarker.sqf | 57 +++++---- .../markers/functions/fnc_sendMarkersJIP.sqf | 30 +++-- addons/markers/functions/fnc_setMarkerJIP.sqf | 62 +++++---- .../functions/fnc_setMarkerNetwork.sqf | 66 ++++++---- addons/markers/stringtable.xml | 8 -- 10 files changed, 254 insertions(+), 163 deletions(-) diff --git a/addons/markers/CfgEventHandlers.hpp b/addons/markers/CfgEventHandlers.hpp index 0cd959a047..e75956f440 100644 --- a/addons/markers/CfgEventHandlers.hpp +++ b/addons/markers/CfgEventHandlers.hpp @@ -1,4 +1,3 @@ - class Extended_PreInit_EventHandlers { class ADDON { init = QUOTE(call COMPILE_FILE(XEH_preInit)); diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index 979d754959..b98c2d8b72 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -1,4 +1,19 @@ -// stuff taken from bohemia, edited by commy2 +/* + * Author: BIS, commy2 + * Sets up the marker placement + * Replaces \a3\ui_f\scripts\GUI\RscDisplayInsertMarker.sqf + * + * Arguments: + * 0: RscDisplayInsertMarker + * + * Return Value: + * Nothing + * + * Example: + * [onLoad] call ace_markers_fnc_initInsertMarker; + * + * Public: No + */ #include "script_component.hpp" #define BORDER 0.005 @@ -7,15 +22,15 @@ disableserialization; _display = _this select 0; - //Prevent Captive Players from placing markers - /*if (ACE_player getVariable ["ACE_isCaptive", false]) exitWith { + //Can't place markers when can't interact + if (!([ACE_player, objNull, ["notOnMap", "isNotInside"]] call EFUNC(common,canInteractWith))) exitWith { _display closeDisplay 2; //emulate "Cancel" button - };*/ + }; // prevent vanilla key input _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; - //BIS Controlls: + //BIS Controls: _text = _display displayctrl 101; _picture = _display displayctrl 102; _channel = _display displayctrl 103; @@ -25,13 +40,13 @@ _title = _display displayctrl 1001; _descriptionChannel = _display displayctrl 1101; - //ACE Controlls: + //ACE Controls: // _sizeX = _display displayctrl 1200; // _sizeY = _display displayctrl 1201; - _shape = _display displayctrl 1210; - _color = _display displayctrl 1211; - _angle = _display displayctrl 1220; - _angleText = _display displayctrl 1221; + _aceShapeLB = _display displayctrl 1210; + _aceColorLB = _display displayctrl 1211; + _aceAngleSlider = _display displayctrl 1220; + _aceAngleSliderText = _display displayctrl 1221; ctrlSetFocus _text; @@ -41,7 +56,7 @@ _posY = _pos select 1; _posW = _pos select 2; _posH = _pos select 3; - _posY = _posY min ((safeZoneH + safeZoneY) - (6 * _posH + 8 * BORDER)); //prevent buttons being placed below bottom edge of screen + _posY = _posY min ((safeZoneH + safeZoneY) - (8 * _posH + 8 * BORDER)); //prevent buttons being placed below bottom edge of screen _pos set [0,_posX]; _pos set [1,_posY]; _text ctrlsetposition _pos; @@ -65,29 +80,29 @@ _pos set [1,_posY + 1 * _posH + 2 * BORDER]; _pos set [2,_posW]; _pos set [3,_posH]; - _shape ctrlsetposition _pos; - _shape ctrlcommit 0; + _aceShapeLB ctrlsetposition _pos; + _aceShapeLB ctrlcommit 0; //--- Color _pos set [1,_posY + 2 * _posH + 3 * BORDER]; _pos set [2,_posW]; - _color ctrlsetposition _pos; - _color ctrlcommit 0; + _aceColorLB ctrlsetposition _pos; + _aceColorLB ctrlcommit 0; //--- Angle _pos set [1,_posY + 3 * _posH + 4 * BORDER]; _pos set [2,_posW]; - _angle ctrlsetposition _pos; - _angle ctrlcommit 0; + _aceAngleSlider ctrlsetposition _pos; + _aceAngleSlider ctrlcommit 0; //--- Angle Text _pos set [1,_posY + 4 * _posH + 5 * BORDER]; _pos set [2,_posW]; - _angleText ctrlsetposition _pos; - _angleText ctrlcommit 0; + _aceAngleSliderText ctrlsetposition _pos; + _aceAngleSliderText ctrlcommit 0; _offsetButtons = 0; - if (ismultiplayer) then { + if (isMultiplayer) then { _pos set [1,_posY + 5 * _posH + 7 * BORDER]; _pos set [3,_posH]; _descriptionChannel ctrlsetstructuredtext parsetext format ["%1", (localize "str_a3_cfgvehicles_modulerespawnposition_f_arguments_marker_0") + ":"]; @@ -132,56 +147,41 @@ // init marker shape lb + lbClear _aceShapeLB; { - _shape lbAdd (_x select 0); - _shape lbSetValue [_forEachIndex, _x select 1]; - _shape lbSetPicture [_forEachIndex, _x select 2]; + _aceShapeLB lbAdd (_x select 0); + _aceShapeLB lbSetValue [_forEachIndex, _x select 1]; + _aceShapeLB lbSetPicture [_forEachIndex, _x select 2]; } forEach GVAR(MarkersCache); - - _shape ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedShape)}]; - _curSelShape = GETGVAR(curSelMarkerShape,0); - _shape lbSetCurSel _curSelShape; - _data = _shape lbValue _curSelShape; - _config = (configfile >> "CfgMarkers") select _data; - _icon = getText (_config >> "icon"); - _picture ctrlSetText _icon; + _aceShapeLB lbSetCurSel _curSelShape; + + //Update now and add eventHandler: + [_aceShapeLB, _curSelShape] call FUNC(onLBSelChangedShape); + _aceShapeLB ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedShape)}]; // init marker color lb + lbClear _aceColorLB; { - _color lbAdd (_x select 0); - _color lbSetValue [_forEachIndex, _x select 1]; - _color lbSetPicture [_forEachIndex, _x select 2]; + _aceColorLB lbAdd (_x select 0); + _aceColorLB lbSetValue [_forEachIndex, _x select 1]; + _aceColorLB lbSetPicture [_forEachIndex, _x select 2]; } forEach GVAR(MarkerColorsCache); - - _color ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedColor)}]; - _curSelColor = GETGVAR(curSelMarkerColor,0); - _color lbSetCurSel _curSelColor; - _data = _color lbValue _curSelColor; - _config = (configfile >> "CfgMarkerColors") select _data; - _rgba = getArray (_config >> "color"); - { - if (typeName _x != "SCALAR") then { - _rgba set [_forEachIndex, call compile _x]; - }; - } forEach _rgba; - _picture ctrlSetTextColor _rgba; + _aceColorLB lbSetCurSel _curSelColor; + + //Update now and add eventHandler: + [_aceColorLB, _curSelColor] call FUNC(onLBSelChangedColor); + _aceColorLB ctrlAddEventHandler ["LBSelChanged", {_this call FUNC(onLBSelChangedColor)}]; // init marker angle slider - _angle sliderSetRange [-180, 180]; - _angle ctrlAddEventHandler ["SliderPosChanged", {_this call FUNC(onSliderPosChangedAngle)}]; - - _curSelAngle = GETGVAR(curSelMarkerAngle,0); - _angle sliderSetPosition _curSelAngle; - - _curSelAngle = round _curSelAngle; - if (_curSelAngle < 0) then { - _curSelAngle = _curSelAngle + 360; - }; - - _angleText ctrlSetText format [localize "STR_ACE_Markers_MarkerDirection", _curSelAngle]; + _aceAngleSlider sliderSetRange [-180, 180]; + _curSelAngle = GETGVAR(currentMarkerAngle,0); + _aceAngleSlider sliderSetPosition _curSelAngle; + //Update now and add eventHandler: + [_aceAngleSlider, _curSelAngle] call FUNC(onSliderPosChangedAngle); + _aceAngleSlider ctrlAddEventHandler ["SliderPosChanged", {_this call FUNC(onSliderPosChangedAngle)}]; }, _this] call EFUNC(common,execNextFrame); diff --git a/addons/markers/functions/fnc_onLBSelChangedColor.sqf b/addons/markers/functions/fnc_onLBSelChangedColor.sqf index a79495d442..9ea3ffce35 100644 --- a/addons/markers/functions/fnc_onLBSelChangedColor.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedColor.sqf @@ -1,17 +1,33 @@ -// by commy2 +/* + * Author: commy2 + * When the color list box is changed. + * + * Arguments: + * 0: Color ListBox (idc 1211) + * 1: Selected Index + * + * Return Value: + * Nothing + * + * Example: + * [ColorLB, 5] call ace_markers_fnc_onLBSelChangedColor; + * + * Public: No + */ #include "script_component.hpp" -private ["_ctrl", "_data", "_config", "_color"]; +private ["_data", "_config", "_color"]; -_ctrl = _this select 0; -_data = _ctrl lbValue (_this select 1); +PARAMS_2(_ctrl,_index); +_data = _ctrl lbValue _index; -GVAR(curSelMarkerColor) = _this select 1; +GVAR(curSelMarkerColor) = _index; _config = (configfile >> "CfgMarkerColors") select _data; _color = getArray (_config >> "color"); +//Array could be strings of code that need to be converted: { if (typeName _x != "SCALAR") then { _color set [_forEachIndex, call compile _x]; diff --git a/addons/markers/functions/fnc_onLBSelChangedShape.sqf b/addons/markers/functions/fnc_onLBSelChangedShape.sqf index 57caba8680..145beb4f2a 100644 --- a/addons/markers/functions/fnc_onLBSelChangedShape.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedShape.sqf @@ -1,12 +1,27 @@ -// by commy2 +/* + * Author: commy2 + * When the shape list box is changed. + * + * Arguments: + * 0: Shape ListBox (idc 1210) + * 1: Selected Index + * + * Return Value: + * Nothing + * + * Example: + * [ColorLB, 5] call ace_markers_fnc_onLBSelChangedShape; + * + * Public: No + */ #include "script_component.hpp" -private ["_ctrl", "_data", "_config", "_icon"]; +private ["_data", "_config", "_icon"]; -_ctrl = _this select 0; -_data = _ctrl lbValue (_this select 1); +PARAMS_2(_ctrl,_index); +_data = _ctrl lbValue _index; -GVAR(curSelMarkerShape) = _this select 1; +GVAR(curSelMarkerShape) = _index; _config = (configfile >> "CfgMarkers") select _data; diff --git a/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf b/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf index 354fb909e1..747c0d4bbb 100644 --- a/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf +++ b/addons/markers/functions/fnc_onSliderPosChangedAngle.sqf @@ -1,12 +1,24 @@ -// by commy2 +/* + * Author: commy2 + * Angle Slider Pos changed + * + * Arguments: + * 0: Slider (idc 1210) + * 1: Slider Data (angle: -180..180) + * + * Return Value: + * Nothing + * + * Example: + * [Slider, 2] call ace_markers_fnc_onSliderPosChangedAngle; + * + * Public: No + */ #include "script_component.hpp" -private ["_ctrl", "_data", "_direction"]; +private ["_direction"]; -_ctrl = _this select 0; -_data = _this select 1; - -GVAR(curSelMarkerAngle) = _data; +PARAMS_2(_ctrl,_data); _direction = round _data; if (_direction < 0) then { diff --git a/addons/markers/functions/fnc_placeMarker.sqf b/addons/markers/functions/fnc_placeMarker.sqf index 124e797e31..592de5577f 100644 --- a/addons/markers/functions/fnc_placeMarker.sqf +++ b/addons/markers/functions/fnc_placeMarker.sqf @@ -1,46 +1,61 @@ -// by commy2 +/* + * Author: commy2 + * MarkerPlacement closed + * + * Arguments: + * 0: RscDisplayInsertMarker + * 1: CloseNumber (1 = ButtonOk) + * + * Return Value: + * Nothing + * + * Example: + * [onUnloadEvent] call ace_markers_fnc_placeMarker; + * + * Public: No + */ #include "script_component.hpp" -if (_this select 1 == 1) then { +PARAMS_2(_display,_closeNum); + +if (_closeNum == 1) then { disableserialization; - _display = _this select 0; _pos = ctrlPosition (_display displayCtrl 102); _pos = [ - (_pos select 0) + (_pos select 2) / 2, - (_pos select 1) + (_pos select 3) / 2 + (_pos select 0) + (_pos select 2) / 2, + (_pos select 1) + (_pos select 3) / 2 ]; switch (true) do { - case (!isNull findDisplay 12): { + case (!isNull findDisplay 12): { _pos = (findDisplay 12 displayCtrl 51) ctrlMapScreenToWorld _pos; }; - case (!isNull findDisplay 37): { + case (!isNull findDisplay 37): { _pos = (findDisplay 37 displayCtrl 51) ctrlMapScreenToWorld _pos; }; - case (!isNull findDisplay 52): { + case (!isNull findDisplay 52): { _pos = (findDisplay 52 displayCtrl 51) ctrlMapScreenToWorld _pos; }; - case (!isNull findDisplay 53): { + case (!isNull findDisplay 53): { _pos = (findDisplay 53 displayCtrl 51) ctrlMapScreenToWorld _pos; }; }; // set and send marker data the next frame. the actual marker isn't created yet [ - { + { - [QGVAR(setMarkerNetwork), [ - allMapMarkers select (count allMapMarkers - 1), [ - GETGVAR(currentMarkerConfigName,""), - GETGVAR(currentMarkerColorConfigName,""), - _this, - GETGVAR(currentMarkerAngle,0) - ] - ]] call EFUNC(common,globalEvent); + [QGVAR(setMarkerNetwork), [ + allMapMarkers select (count allMapMarkers - 1), [ + GETGVAR(currentMarkerConfigName,""), + GETGVAR(currentMarkerColorConfigName,""), + _this, + GETGVAR(currentMarkerAngle,0) + ] + ]] call EFUNC(common,globalEvent); - }, - _pos + }, + _pos ] call EFUNC(common,execNextFrame); - }; diff --git a/addons/markers/functions/fnc_sendMarkersJIP.sqf b/addons/markers/functions/fnc_sendMarkersJIP.sqf index 9915820d72..99eea2f2d9 100644 --- a/addons/markers/functions/fnc_sendMarkersJIP.sqf +++ b/addons/markers/functions/fnc_sendMarkersJIP.sqf @@ -1,13 +1,25 @@ -// by commy2 +/* + * Author: commy2 + * Server: Recives a dummy logic, sends marker data back to the owner. + * + * Arguments: + * 0: Logic + * + * Return Value: + * Nothing + * + * Example: + * [onUnloadEvent] call ace_markers_fnc_sendMarkerJIP; + * + * Public: No + */ #include "script_component.hpp" -private "_logic"; +PARAMS_1(_logic); -_logic = _this; - -[QGVAR(setMarkerJIP), _logic, [ - GETGVAR(allMapMarkers,[]), - GETGVAR(allMapMarkersProperties,[]), - _logic - ] +[QGVAR(setMarkerJIP), [_logic], [ +GETGVAR(allMapMarkers,[]), +GETGVAR(allMapMarkersProperties,[]), +_logic +] ] call EFUNC(common,targetEvent); diff --git a/addons/markers/functions/fnc_setMarkerJIP.sqf b/addons/markers/functions/fnc_setMarkerJIP.sqf index 74bd4f97f7..0760cc6fe5 100644 --- a/addons/markers/functions/fnc_setMarkerJIP.sqf +++ b/addons/markers/functions/fnc_setMarkerJIP.sqf @@ -1,35 +1,49 @@ -// by commy2 +/* + * Author: commy2 + * Client: Recives a marker data from server. + * + * Arguments: + * 0: Array of map marker names + * 1: Array of map marker data + * 2: Logic + * + * Return Value: + * Nothing + * + * Example: + * [[],[],dummyLogic] call ace_markers_fnc_setMarkerJIP; + * + * Public: No + */ #include "script_component.hpp" -private ["_allMapMarkers", "_allMapMarkersProperties", "_index", "_data", "_config"]; +private ["_index", "_data", "_config"]; -_allMapMarkers = _this select 0; -_allMapMarkersProperties = _this select 1; -_logic = _this select 2; +PARAMS_3(_allMapMarkers,_allMapMarkersProperties,_logic); { - _index = _allMapMarkers find _x; + _index = _allMapMarkers find _x; - if (_index != -1) then { - _data = _allMapMarkersProperties select _index; + if (_index != -1) then { + _data = _allMapMarkersProperties select _index; - _config = (configfile >> "CfgMarkers") >> (_data select 0); - if (!isClass _config) then { - WARNING("CfgMarker not found, changed to milDot"); - _config == (configFile >> "CfgMarkers" >> "MilDot"); + _config = (configfile >> "CfgMarkers") >> (_data select 0); + if (!isClass _config) then { + WARNING("CfgMarker not found, changed to milDot"); + _config == (configFile >> "CfgMarkers" >> "MilDot"); + }; + _x setMarkerTypeLocal (configName _config); + + _config = (configfile >> "CfgMarkerColors") >> (_data select 1); + if (!isClass _config) then { + WARNING("CfgMarkerColors not found, changed to Default"); + _config == (configFile >> "CfgMarkerColors" >> "Default"); + }; + _x setMarkerColorLocal (configName _config); + + _x setMarkerPosLocal (_data select 2); + _x setMarkerDirLocal (_data select 3); }; - _x setMarkerTypeLocal (configName _config); - - _config = (configfile >> "CfgMarkerColors") >> (_data select 1); - if (!isClass _config) then { - WARNING("CfgMarkerColors not found, changed to Default"); - _config == (configFile >> "CfgMarkerColors" >> "Default"); - }; - _x setMarkerColorLocal (configName _config); - - _x setMarkerPosLocal (_data select 2); - _x setMarkerDirLocal (_data select 3); - }; } forEach allMapMarkers; deleteVehicle _logic; diff --git a/addons/markers/functions/fnc_setMarkerNetwork.sqf b/addons/markers/functions/fnc_setMarkerNetwork.sqf index 194d169f24..1dc450270a 100644 --- a/addons/markers/functions/fnc_setMarkerNetwork.sqf +++ b/addons/markers/functions/fnc_setMarkerNetwork.sqf @@ -1,45 +1,61 @@ -// by commy2 +/* + * Author: commy2 + * Sets newly placed marker + * Handles the QGVAR(setMarkerNetwork) event. + * + * Arguments: + * 0: Markername + * 1: Marker Data + * + * Return Value: + * Nothing + * + * Example: + * [[],[],dummyLogic] call ace_markers_fnc_setMarkerJIP; + * + * Public: No + */ #include "script_component.hpp" -private ["_marker", "_data", "_config"]; +private ["_config"]; -_marker = _this select 0; -_data = _this select 1; +PARAMS_2(_marker,_data); +EXPLODE_4_PVT(_data,_markerClassname,_colorClassname,_markerPos,_markerDir); -_config = (configfile >> "CfgMarkers") >> (_data select 0); +_config = (configfile >> "CfgMarkers") >> _markerClassname; if (!isClass _config) then { - WARNING("CfgMarker not found, changed to milDot"); - _config == (configFile >> "CfgMarkers" >> "MilDot"); + WARNING("CfgMarker not found, changed to milDot"); + _config == (configFile >> "CfgMarkers" >> "MilDot"); }; _marker setMarkerTypeLocal (configName _config); -_config = (configfile >> "CfgMarkerColors") >> (_data select 1); +_config = (configfile >> "CfgMarkerColors") >> _colorClassname; if (!isClass _config) then { - WARNING("CfgMarkerColors not found, changed to Default"); - _config == (configFile >> "CfgMarkerColors" >> "Default"); + WARNING("CfgMarkerColors not found, changed to Default"); + _config == (configFile >> "CfgMarkerColors" >> "Default"); }; _marker setMarkerColorLocal configName _config; -_marker setMarkerPosLocal (_data select 2); -_marker setMarkerDirLocal (_data select 3); +_marker setMarkerPosLocal _markerPos; +_marker setMarkerDirLocal _markerDir; // save properties on server machine for JIP, marker editing ready if (isMultiplayer && {isServer}) then { - private ["_allMapMarkers", "_allMapMarkersProperties", "_index"]; + private ["_allMapMarkers", "_allMapMarkersProperties", "_index"]; - _allMapMarkers = GETMVAR(allMapMarkers,[]); - _allMapMarkersProperties = GETMVAR(allMapMarkersProperties,[]); + _allMapMarkers = GETMVAR(allMapMarkers,[]); + _allMapMarkersProperties = GETMVAR(allMapMarkersProperties,[]); - _index = _allMapMarkers find _marker; + _index = _allMapMarkers find _marker; - if (_index == -1) then { - _allMapMarkers pushBack _marker; - _allMapMarkersProperties pushBack _data; - } else { - _allMapMarkers set [_index, _marker]; - _allMapMarkersProperties set [_index, _data]; - }; + if (_index == -1) then { + _allMapMarkers pushBack _marker; + _allMapMarkersProperties pushBack _data; + } else { + _allMapMarkers set [_index, _marker]; + _allMapMarkersProperties set [_index, _data]; + }; - GVAR(allMapMarkers) = _allMapMarkers; - GVAR(allMapMarkersProperties) = _allMapMarkersProperties; + GVAR(allMapMarkers) = _allMapMarkers; + GVAR(allMapMarkersProperties) = _allMapMarkersProperties; }; diff --git a/addons/markers/stringtable.xml b/addons/markers/stringtable.xml index 0d2619ae40..ea6d72990a 100644 --- a/addons/markers/stringtable.xml +++ b/addons/markers/stringtable.xml @@ -11,13 +11,5 @@ Dirección: %1° Направление: %1 - - Place in: %1 - Platz in: %1 - Colocar en: %1 - Umieść na: %1 - Umístit do: %1 - Место в: %1 - \ No newline at end of file From e5cbca02e44479f4d39e9ae6ffe5309daf6de658 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 22:55:19 -0500 Subject: [PATCH 04/28] Show placement angle in preview --- addons/markers/XEH_postInit.sqf | 7 +++ addons/markers/XEH_preInit.sqf | 1 + .../functions/fnc_initInsertMarker.sqf | 32 +++++++++++-- addons/markers/functions/fnc_mapDrawEH.sqf | 45 +++++++++++++++++++ .../functions/fnc_onLBSelChangedColor.sqf | 11 ----- .../functions/fnc_onLBSelChangedShape.sqf | 4 -- addons/markers/functions/fnc_placeMarker.sqf | 35 +++------------ 7 files changed, 86 insertions(+), 49 deletions(-) create mode 100644 addons/markers/functions/fnc_mapDrawEH.sqf diff --git a/addons/markers/XEH_postInit.sqf b/addons/markers/XEH_postInit.sqf index eea149f294..27d14e92b2 100644 --- a/addons/markers/XEH_postInit.sqf +++ b/addons/markers/XEH_postInit.sqf @@ -14,3 +14,10 @@ if (isMultiplayer && {!isServer} && {hasInterface}) then { [QGVAR(sendMarkersJIP), _logic] call EFUNC(common,serverEvent); }; + + +GVAR(mapDisplaysWithDrawEHs) = []; +GVAR(currentMarkerPosition) = []; +GVAR(currentMarkerAngle) = 0; +GVAR(currentMarkerColorConfigName) = ""; +GVAR(currentMarkerConfigName) = ""; \ No newline at end of file diff --git a/addons/markers/XEH_preInit.sqf b/addons/markers/XEH_preInit.sqf index 53fdc70b41..fd97aeda0c 100644 --- a/addons/markers/XEH_preInit.sqf +++ b/addons/markers/XEH_preInit.sqf @@ -3,6 +3,7 @@ ADDON = false; PREP(initInsertMarker); +PREP(mapDrawEH); PREP(onLBSelChangedColor); PREP(onLBSelChangedShape); PREP(onSliderPosChangedAngle); diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index b98c2d8b72..17e9d0d9ed 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -20,16 +20,13 @@ [{ disableserialization; - _display = _this select 0; + PARAMS_1(_display); //Can't place markers when can't interact if (!([ACE_player, objNull, ["notOnMap", "isNotInside"]] call EFUNC(common,canInteractWith))) exitWith { _display closeDisplay 2; //emulate "Cancel" button }; - // prevent vanilla key input - _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; - //BIS Controls: _text = _display displayctrl 101; _picture = _display displayctrl 102; @@ -48,6 +45,33 @@ _aceAngleSlider = _display displayctrl 1220; _aceAngleSliderText = _display displayctrl 1221; + + //Install MapDrawEH on current map + _mapIDD = -1; + { + if (!isNull (findDisplay _x)) exitWith {_mapIDD = _x}; + } forEach [12, 37, 52, 53]; + if (_mapIDD == -1) exitWith {ERROR("No Map?");}; + if (!(_mapIDD in GVAR(mapDisplaysWithDrawEHs))) then { + GVAR(mapDisplaysWithDrawEHs) pushBack _mapIDD; + systemChat str _mapIDD; + systemChat str ((finddisplay _mapIDD) displayctrl 51); + ((finddisplay _mapIDD) displayctrl 51) ctrlAddEventHandler ["Draw", {_this call FUNC(mapDrawEH)}]; + }; + + //Calculate center position of the marker placement ctrl + _pos = ctrlPosition _picture; + _pos = [(_pos select 0) + (_pos select 2) / 2, (_pos select 1) + (_pos select 3) / 2]; + GVAR(currentMarkerPosition) = ((findDisplay _mapIDD) displayCtrl 51) ctrlMapScreenToWorld _pos; + + //Hide the bis picture: + _picture ctrlShow false; + + // prevent vanilla key input + _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; + + + //Focus on the text input ctrlSetFocus _text; //--- Background diff --git a/addons/markers/functions/fnc_mapDrawEH.sqf b/addons/markers/functions/fnc_mapDrawEH.sqf new file mode 100644 index 0000000000..2b3f7688dd --- /dev/null +++ b/addons/markers/functions/fnc_mapDrawEH.sqf @@ -0,0 +1,45 @@ +/* + * Author: PabstMirror + * Draws the current temp marker. Allows rotation. + * + * Arguments: + * 0: TheMap + * + * Return Value: + * Nothing + * + * Example: + * [theMapControl] call ace_markers_fnc_mapDrawEH; + * + * Public: No + */ +#include "script_component.hpp" + +private ["_theMap", "_sizeX", "_sizeY", "_textureConfig", "_texture", "_markerSize", "_markerShadow", "_colorConfig", "_drawColor"]; + +PARAMS_1(_theMap); + +//Only show if marker place is open: +if (isNull (findDisplay 54)) exitWith {}; +//Error checking: +if ((GVAR(currentMarkerConfigName) == "") || {GVAR(currentMarkerColorConfigName) == ""} || {GVAR(currentMarkerPosition) isEqualTo []}) exitWith {ERROR("Bad Data");}; + +_sizeX = 1; +_sizeY = 1; + +_textureConfig = configFile >> "CfgMarkers" >> GVAR(currentMarkerConfigName); +_texture = getText (_textureConfig >> "icon"); +_markerSize = getNumber (_textureConfig >> "size"); +_markerShadow = getNumber (_textureConfig >> "shadow"); +_colorConfig = (configFile >> "CfgMarkerColors" >> GVAR(currentMarkerColorConfigName)); +_drawColor = getArray (_colorConfig >> "color"); + +//Convert possible code into numbers +{ + if (typeName _x == "STRING") then { + _drawColor set [_forEachIndex, (call compile _x)]; + }; +} forEach _drawColor; +_drawColor set [3, ((_drawColor select 3) * 0.875)]; //Arma adds a slight transparency + +_theMap drawIcon [_texture, _drawColor, GVAR(currentMarkerPosition), (_sizeX * _markerSize), (_sizeY * _markerSize), GVAR(currentMarkerAngle), "", _markerShadow]; diff --git a/addons/markers/functions/fnc_onLBSelChangedColor.sqf b/addons/markers/functions/fnc_onLBSelChangedColor.sqf index 9ea3ffce35..b081653eef 100644 --- a/addons/markers/functions/fnc_onLBSelChangedColor.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedColor.sqf @@ -25,15 +25,4 @@ GVAR(curSelMarkerColor) = _index; _config = (configfile >> "CfgMarkerColors") select _data; -_color = getArray (_config >> "color"); - -//Array could be strings of code that need to be converted: -{ - if (typeName _x != "SCALAR") then { - _color set [_forEachIndex, call compile _x]; - }; -} forEach _color; - -((ctrlParent _ctrl) displayCtrl 102) ctrlSetTextColor _color; - GVAR(currentMarkerColorConfigName) = (configName _config); diff --git a/addons/markers/functions/fnc_onLBSelChangedShape.sqf b/addons/markers/functions/fnc_onLBSelChangedShape.sqf index 145beb4f2a..e7f9a31e05 100644 --- a/addons/markers/functions/fnc_onLBSelChangedShape.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedShape.sqf @@ -25,8 +25,4 @@ GVAR(curSelMarkerShape) = _index; _config = (configfile >> "CfgMarkers") select _data; -_icon = getText (_config >> "icon"); - -((ctrlParent _ctrl) displayCtrl 102) ctrlSetText _icon; - GVAR(currentMarkerConfigName) = (configName _config); diff --git a/addons/markers/functions/fnc_placeMarker.sqf b/addons/markers/functions/fnc_placeMarker.sqf index 592de5577f..44c6b081f1 100644 --- a/addons/markers/functions/fnc_placeMarker.sqf +++ b/addons/markers/functions/fnc_placeMarker.sqf @@ -16,46 +16,21 @@ */ #include "script_component.hpp" +disableserialization; PARAMS_2(_display,_closeNum); if (_closeNum == 1) then { - disableserialization; - - _pos = ctrlPosition (_display displayCtrl 102); - _pos = [ - (_pos select 0) + (_pos select 2) / 2, - (_pos select 1) + (_pos select 3) / 2 - ]; - - switch (true) do { - case (!isNull findDisplay 12): { - _pos = (findDisplay 12 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 37): { - _pos = (findDisplay 37 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 52): { - _pos = (findDisplay 52 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - case (!isNull findDisplay 53): { - _pos = (findDisplay 53 displayCtrl 51) ctrlMapScreenToWorld _pos; - }; - }; // set and send marker data the next frame. the actual marker isn't created yet - [ - { - + [{ [QGVAR(setMarkerNetwork), [ allMapMarkers select (count allMapMarkers - 1), [ GETGVAR(currentMarkerConfigName,""), GETGVAR(currentMarkerColorConfigName,""), - _this, + GETGVAR(currentMarkerPosition,[]), GETGVAR(currentMarkerAngle,0) ] ]] call EFUNC(common,globalEvent); - - }, - _pos - ] call EFUNC(common,execNextFrame); + + }, []] call EFUNC(common,execNextFrame); }; From 909f53753a0e638f2902d2be37de148ff5111ecd Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 23:19:03 -0500 Subject: [PATCH 05/28] Fix JIP Marker SYnc --- addons/markers/XEH_postInit.sqf | 4 ++-- addons/markers/functions/fnc_initInsertMarker.sqf | 2 +- addons/markers/functions/fnc_setMarkerNetwork.sqf | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/addons/markers/XEH_postInit.sqf b/addons/markers/XEH_postInit.sqf index 27d14e92b2..786b93a233 100644 --- a/addons/markers/XEH_postInit.sqf +++ b/addons/markers/XEH_postInit.sqf @@ -11,8 +11,8 @@ if (isMultiplayer && {!isServer} && {hasInterface}) then { private "_logic"; _logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"]; - - [QGVAR(sendMarkersJIP), _logic] call EFUNC(common,serverEvent); + systemChat "requesting markers"; + [QGVAR(sendMarkersJIP), [_logic]] call EFUNC(common,serverEvent); }; diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index 17e9d0d9ed..e9a12dafc8 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -1,7 +1,7 @@ /* * Author: BIS, commy2 * Sets up the marker placement - * Replaces \a3\ui_f\scripts\GUI\RscDisplayInsertMarker.sqf + * Run instead of \a3\ui_f\scripts\GUI\RscDisplayInsertMarker.sqf * * Arguments: * 0: RscDisplayInsertMarker diff --git a/addons/markers/functions/fnc_setMarkerNetwork.sqf b/addons/markers/functions/fnc_setMarkerNetwork.sqf index 1dc450270a..457d5dac37 100644 --- a/addons/markers/functions/fnc_setMarkerNetwork.sqf +++ b/addons/markers/functions/fnc_setMarkerNetwork.sqf @@ -43,8 +43,8 @@ _marker setMarkerDirLocal _markerDir; if (isMultiplayer && {isServer}) then { private ["_allMapMarkers", "_allMapMarkersProperties", "_index"]; - _allMapMarkers = GETMVAR(allMapMarkers,[]); - _allMapMarkersProperties = GETMVAR(allMapMarkersProperties,[]); + _allMapMarkers = GETGVAR(allMapMarkers,[]); + _allMapMarkersProperties = GETGVAR(allMapMarkersProperties,[]); _index = _allMapMarkers find _marker; From aa5a58064565f02b4cbd3ac5198f0eb6a6828a6f Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 23:24:11 -0500 Subject: [PATCH 06/28] Cleanup --- addons/markers/functions/fnc_initInsertMarker.sqf | 2 +- addons/markers/functions/fnc_mapDrawEH.sqf | 2 +- addons/markers/functions/fnc_onLBSelChangedColor.sqf | 2 +- addons/markers/functions/fnc_onLBSelChangedShape.sqf | 2 +- addons/markers/functions/fnc_placeMarker.sqf | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index e9a12dafc8..ce5944bc8c 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -66,7 +66,7 @@ //Hide the bis picture: _picture ctrlShow false; - + // prevent vanilla key input _display displayAddEventHandler ["KeyDown", {(_this select 1) in [200, 208]}]; diff --git a/addons/markers/functions/fnc_mapDrawEH.sqf b/addons/markers/functions/fnc_mapDrawEH.sqf index 2b3f7688dd..2e23dacec8 100644 --- a/addons/markers/functions/fnc_mapDrawEH.sqf +++ b/addons/markers/functions/fnc_mapDrawEH.sqf @@ -1,6 +1,6 @@ /* * Author: PabstMirror - * Draws the current temp marker. Allows rotation. + * Draws the current temp marker. Allows rotation. * * Arguments: * 0: TheMap diff --git a/addons/markers/functions/fnc_onLBSelChangedColor.sqf b/addons/markers/functions/fnc_onLBSelChangedColor.sqf index b081653eef..e089569761 100644 --- a/addons/markers/functions/fnc_onLBSelChangedColor.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedColor.sqf @@ -16,7 +16,7 @@ */ #include "script_component.hpp" -private ["_data", "_config", "_color"]; +private ["_data", "_config"]; PARAMS_2(_ctrl,_index); _data = _ctrl lbValue _index; diff --git a/addons/markers/functions/fnc_onLBSelChangedShape.sqf b/addons/markers/functions/fnc_onLBSelChangedShape.sqf index e7f9a31e05..ff067a467b 100644 --- a/addons/markers/functions/fnc_onLBSelChangedShape.sqf +++ b/addons/markers/functions/fnc_onLBSelChangedShape.sqf @@ -16,7 +16,7 @@ */ #include "script_component.hpp" -private ["_data", "_config", "_icon"]; +private ["_data", "_config"]; PARAMS_2(_ctrl,_index); _data = _ctrl lbValue _index; diff --git a/addons/markers/functions/fnc_placeMarker.sqf b/addons/markers/functions/fnc_placeMarker.sqf index 44c6b081f1..fd584c1c99 100644 --- a/addons/markers/functions/fnc_placeMarker.sqf +++ b/addons/markers/functions/fnc_placeMarker.sqf @@ -31,6 +31,6 @@ if (_closeNum == 1) then { GETGVAR(currentMarkerAngle,0) ] ]] call EFUNC(common,globalEvent); - + }, []] call EFUNC(common,execNextFrame); }; From 4e4834974a2962b09c8b1ce32f3722ecb9a137b9 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Fri, 27 Mar 2015 23:26:41 -0500 Subject: [PATCH 07/28] cleanup debug --- addons/markers/XEH_postInit.sqf | 1 - addons/markers/functions/fnc_initInsertMarker.sqf | 2 -- 2 files changed, 3 deletions(-) diff --git a/addons/markers/XEH_postInit.sqf b/addons/markers/XEH_postInit.sqf index 786b93a233..ecb4d579fe 100644 --- a/addons/markers/XEH_postInit.sqf +++ b/addons/markers/XEH_postInit.sqf @@ -11,7 +11,6 @@ if (isMultiplayer && {!isServer} && {hasInterface}) then { private "_logic"; _logic = createGroup sideLogic createUnit ["Logic", [0,0,0], [], 0, "NONE"]; - systemChat "requesting markers"; [QGVAR(sendMarkersJIP), [_logic]] call EFUNC(common,serverEvent); }; diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index ce5944bc8c..9b77134b56 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -54,8 +54,6 @@ if (_mapIDD == -1) exitWith {ERROR("No Map?");}; if (!(_mapIDD in GVAR(mapDisplaysWithDrawEHs))) then { GVAR(mapDisplaysWithDrawEHs) pushBack _mapIDD; - systemChat str _mapIDD; - systemChat str ((finddisplay _mapIDD) displayctrl 51); ((finddisplay _mapIDD) displayctrl 51) ctrlAddEventHandler ["Draw", {_this call FUNC(mapDrawEH)}]; }; From 6c8064097fb3515d9bbae67f928a76d5a96cc665 Mon Sep 17 00:00:00 2001 From: commy2 Date: Sat, 28 Mar 2015 11:19:39 +0100 Subject: [PATCH 08/28] delete old resting, farewell --- addons/resting/$PBOPREFIX$ | 1 - addons/resting/CfgEventHandlers.hpp | 12 - addons/resting/CfgMoves.hpp | 1389 ----------------- addons/resting/CfgSounds.hpp | 14 - addons/resting/CfgWeapons.hpp | 22 - addons/resting/README.md | 12 - addons/resting/XEH_postInit.sqf | 23 - addons/resting/XEH_preInit.sqf | 11 - addons/resting/config.cpp | 21 - addons/resting/data/icons/icon_bipod.paa | Bin 5625 -> 0 bytes .../resting/functions/fnc_getIntersection.sqf | 70 - addons/resting/functions/fnc_hasBipod.sqf | 22 - addons/resting/functions/fnc_pfhCheckRest.sqf | 41 - addons/resting/functions/fnc_restWeapon.sqf | 66 - addons/resting/functions/fnc_unRestWeapon.sqf | 53 - addons/resting/functions/script_component.hpp | 1 - addons/resting/script_component.hpp | 19 - addons/resting/sounds/weaponrest_rest.wav | Bin 19866 -> 0 bytes addons/resting/sounds/weaponrest_unrest.wav | Bin 77354 -> 0 bytes addons/resting/stringtable.xml | 69 - 20 files changed, 1846 deletions(-) delete mode 100644 addons/resting/$PBOPREFIX$ delete mode 100644 addons/resting/CfgEventHandlers.hpp delete mode 100644 addons/resting/CfgMoves.hpp delete mode 100644 addons/resting/CfgSounds.hpp delete mode 100644 addons/resting/CfgWeapons.hpp delete mode 100644 addons/resting/README.md delete mode 100644 addons/resting/XEH_postInit.sqf delete mode 100644 addons/resting/XEH_preInit.sqf delete mode 100644 addons/resting/config.cpp delete mode 100644 addons/resting/data/icons/icon_bipod.paa delete mode 100644 addons/resting/functions/fnc_getIntersection.sqf delete mode 100644 addons/resting/functions/fnc_hasBipod.sqf delete mode 100644 addons/resting/functions/fnc_pfhCheckRest.sqf delete mode 100644 addons/resting/functions/fnc_restWeapon.sqf delete mode 100644 addons/resting/functions/fnc_unRestWeapon.sqf delete mode 100644 addons/resting/functions/script_component.hpp delete mode 100644 addons/resting/script_component.hpp delete mode 100644 addons/resting/sounds/weaponrest_rest.wav delete mode 100644 addons/resting/sounds/weaponrest_unrest.wav delete mode 100644 addons/resting/stringtable.xml diff --git a/addons/resting/$PBOPREFIX$ b/addons/resting/$PBOPREFIX$ deleted file mode 100644 index 94f2a89f81..0000000000 --- a/addons/resting/$PBOPREFIX$ +++ /dev/null @@ -1 +0,0 @@ -z\ace\addons\resting \ No newline at end of file diff --git a/addons/resting/CfgEventHandlers.hpp b/addons/resting/CfgEventHandlers.hpp deleted file mode 100644 index beb3c4d419..0000000000 --- a/addons/resting/CfgEventHandlers.hpp +++ /dev/null @@ -1,12 +0,0 @@ - -class Extended_PreInit_EventHandlers { - class ADDON { - init = QUOTE(call COMPILE_FILE(XEH_preInit)); - }; -}; - -class Extended_PostInit_EventHandlers { - class ADDON { - init = QUOTE( call COMPILE_FILE(XEH_postInit) ); - }; -}; diff --git a/addons/resting/CfgMoves.hpp b/addons/resting/CfgMoves.hpp deleted file mode 100644 index 3c4ab85a5c..0000000000 --- a/addons/resting/CfgMoves.hpp +++ /dev/null @@ -1,1389 +0,0 @@ -// CODE BELOW TAKEN FROM TMR, PREFIXES EDITED FOR COMPATABILITY - -#define ACE_SWAY_DEPLOY 0.02 -#define ACE_SWAY_DEPLOYPRONE 0.01 -#define ACE_SWAY_RESTED 0.04 //0.08 -#define ACE_SWAY_RESTEDPRONE 0.02 //0.04 -#define ACE_DEPLOY_TURNSPEED 0.1 - -// Arma 3 doesn't respect turnSpeed. - -class CfgMovesBasic { - class Default; - - class Actions { - class RifleStandActions; - class RifleStandActions_ace_deploy : RifleStandActions { - stop = "AmovPercMstpSrasWrflDnon_ace_deploy"; - default = "AmovPercMstpSrasWrflDnon_ace_deploy"; - turnL = "AmovPercMstpSrasWrflDnon_ace_deploy"; - turnR = "AmovPercMstpSrasWrflDnon_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLStandActions; - class RifleAdjustLStandActions_ace_deploy : RifleAdjustLStandActions { - stop = "AadjPercMstpSrasWrflDleft_ace_deploy"; - default = "AadjPercMstpSrasWrflDleft_ace_deploy"; - AdjustL = "AadjPercMstpSrasWrflDleft_ace_deploy"; - turnL = "AadjPercMstpSrasWrflDleft_ace_deploy"; - turnR = "AadjPercMstpSrasWrflDleft_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRStandActions; - class RifleAdjustRStandActions_ace_deploy : RifleAdjustRStandActions { - stop = "AadjPercMstpSrasWrflDright_ace_deploy"; - default = "AadjPercMstpSrasWrflDright_ace_deploy"; - AdjustRight = "AadjPercMstpSrasWrflDright_ace_deploy"; - turnL = "AadjPercMstpSrasWrflDright_ace_deploy"; - turnR = "AadjPercMstpSrasWrflDright_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFStandActions; - class RifleAdjustFStandActions_ace_deploy : RifleAdjustFStandActions { - stop = "AadjPercMstpSrasWrflDup_ace_deploy"; - default = "AadjPercMstpSrasWrflDup_ace_deploy"; - AdjustF = "AadjPercMstpSrasWrflDup_ace_deploy"; - turnL = "AadjPercMstpSrasWrflDup_ace_deploy"; - turnR = "AadjPercMstpSrasWrflDup_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBStandActions; - class RifleAdjustBStandActions_ace_deploy : RifleAdjustBStandActions { - stop = "AadjPercMstpSrasWrflDdown_ace_deploy"; - default = "AadjPercMstpSrasWrflDdown_ace_deploy"; - AdjustB = "AadjPercMstpSrasWrflDdown_ace_deploy"; - turnR = "AadjPercMstpSrasWrflDdown_ace_deploy"; - turnL = "AadjPercMstpSrasWrflDdown_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleKneelActions; - class RifleKneelActions_ace_deploy : RifleKneelActions { - stop = "AmovPknlMstpSrasWrflDnon_ace_deploy"; - default = "AmovPknlMstpSrasWrflDnon_ace_deploy"; - crouch = "AmovPknlMstpSrasWrflDnon_ace_deploy"; // TODO: this might cause issues - turnL = "AmovPknlMstpSrasWrflDnon_ace_deploy"; - turnR = "AmovPknlMstpSrasWrflDnon_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLKneelActions; - class RifleAdjustLKneelActions_ace_deploy : RifleAdjustLKneelActions { - stop = "AadjPknlMstpSrasWrflDleft_ace_deploy"; - default = "AadjPknlMstpSrasWrflDleft_ace_deploy"; - turnL = "AadjPknlMstpSrasWrflDleft_ace_deploy"; - turnR = "AadjPknlMstpSrasWrflDleft_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRKneelActions; - class RifleAdjustRKneelActions_ace_deploy : RifleAdjustRKneelActions { - stop = "AadjPknlMstpSrasWrflDright_ace_deploy"; - default = "AadjPknlMstpSrasWrflDright_ace_deploy"; - turnL = "AadjPknlMstpSrasWrflDright_ace_deploy"; - turnR = "AadjPknlMstpSrasWrflDright_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFKneelActions; - class RifleAdjustFKneelActions_ace_deploy : RifleAdjustFKneelActions { - stop = "AadjPknlMstpSrasWrflDup_ace_deploy"; - default = "AadjPknlMstpSrasWrflDup_ace_deploy"; - turnL = "AadjPknlMstpSrasWrflDup_ace_deploy"; - turnR = "AadjPknlMstpSrasWrflDup_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBKneelActions; - class RifleAdjustBKneelActions_ace_deploy : RifleAdjustBKneelActions { - stop = "AadjPknlMstpSrasWrflDdown_ace_deploy"; - default = "AadjPknlMstpSrasWrflDdown_ace_deploy"; - turnL = "AadjPknlMstpSrasWrflDdown_ace_deploy"; - turnR = "AadjPknlMstpSrasWrflDdown_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleProneActions; - class RifleProneActions_ace_deploy : RifleProneActions { - stop = "AmovPpneMstpSrasWrflDnon_ace_deploy"; - default = "AmovPpneMstpSrasWrflDnon_ace_deploy"; - turnL = "AmovPpneMstpSrasWrflDnon_ace_deploy"; - turnR = "AmovPpneMstpSrasWrflDnon_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLProneActions; - class RifleAdjustLProneActions_ace_deploy : RifleAdjustLProneActions { - stop = "AadjPpneMstpSrasWrflDleft_ace_deploy"; - default = "AadjPpneMstpSrasWrflDleft_ace_deploy"; - turnL = "AadjPpneMstpSrasWrflDleft_ace_deploy"; - turnR = "AadjPpneMstpSrasWrflDleft_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRProneActions; - class RifleAdjustRProneActions_ace_deploy : RifleAdjustRProneActions { - stop = "AadjPpneMstpSrasWrflDright_ace_deploy"; - default = "AadjPpneMstpSrasWrflDright_ace_deploy"; - turnL = "AadjPpneMstpSrasWrflDright_ace_deploy"; - turnR = "AadjPpneMstpSrasWrflDright_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFProneActions; - class RifleAdjustFProneActions_ace_deploy : RifleAdjustFProneActions { - stop = "aadjppnemstpsraswrfldup_ace_deploy"; - default = "aadjppnemstpsraswrfldup_ace_deploy"; - turnL = "aadjppnemstpsraswrfldup_ace_deploy"; - turnR = "aadjppnemstpsraswrfldup_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBProneActions; - class RifleAdjustBProneActions_ace_deploy : RifleAdjustBProneActions { - stop = "AadjPpneMstpSrasWrflDdown_ace_deploy"; - default = "AadjPpneMstpSrasWrflDdown_ace_deploy"; - turnL = "AadjPpneMstpSrasWrflDdown_ace_deploy"; - turnR = "AadjPpneMstpSrasWrflDdown_ace_deploy"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - ////////////////////////////////////////////////////////////////////// - - class RifleStandActions_ace_rested : RifleStandActions { - stop = "AmovPercMstpSrasWrflDnon_ace_rested"; - default = "AmovPercMstpSrasWrflDnon_ace_rested"; - turnL = "AmovPercMstpSrasWrflDnon_ace_rested"; - turnR = "AmovPercMstpSrasWrflDnon_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLStandActions_ace_rested : RifleAdjustLStandActions { - stop = "AadjPercMstpSrasWrflDleft_ace_rested"; - default = "AadjPercMstpSrasWrflDleft_ace_rested"; - AdjustL = "AadjPercMstpSrasWrflDleft_ace_rested"; - turnL = "AadjPercMstpSrasWrflDleft_ace_rested"; - turnR = "AadjPercMstpSrasWrflDleft_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRStandActions_ace_rested : RifleAdjustRStandActions { - stop = "AadjPercMstpSrasWrflDright_ace_rested"; - default = "AadjPercMstpSrasWrflDright_ace_rested"; - AdjustRight = "AadjPercMstpSrasWrflDright_ace_rested"; - turnL = "AadjPercMstpSrasWrflDright_ace_rested"; - turnR = "AadjPercMstpSrasWrflDright_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFStandActions_ace_rested : RifleAdjustFStandActions { - stop = "AadjPercMstpSrasWrflDup_ace_rested"; - default = "AadjPercMstpSrasWrflDup_ace_rested"; - AdjustF = "AadjPercMstpSrasWrflDup_ace_rested"; - turnL = "AadjPercMstpSrasWrflDup_ace_rested"; - turnR = "AadjPercMstpSrasWrflDup_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBStandActions_ace_rested : RifleAdjustBStandActions { - stop = "AadjPercMstpSrasWrflDdown_ace_rested"; - default = "AadjPercMstpSrasWrflDdown_ace_rested"; - AdjustB = "AadjPercMstpSrasWrflDdown_ace_rested"; - turnR = "AadjPercMstpSrasWrflDdown_ace_rested"; - turnL = "AadjPercMstpSrasWrflDdown_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleKneelActions_ace_rested : RifleKneelActions { - stop = "AmovPknlMstpSrasWrflDnon_ace_rested"; - default = "AmovPknlMstpSrasWrflDnon_ace_rested"; - crouch = "AmovPknlMstpSrasWrflDnon_ace_rested"; - turnL = "AmovPknlMstpSrasWrflDnon_ace_rested"; - turnR = "AmovPknlMstpSrasWrflDnon_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLKneelActions_ace_rested : RifleAdjustLKneelActions { - stop = "AadjPknlMstpSrasWrflDleft_ace_rested"; - default = "AadjPknlMstpSrasWrflDleft_ace_rested"; - turnL = "AadjPknlMstpSrasWrflDleft_ace_rested"; - turnR = "AadjPknlMstpSrasWrflDleft_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRKneelActions_ace_rested : RifleAdjustRKneelActions { - stop = "AadjPknlMstpSrasWrflDright_ace_rested"; - default = "AadjPknlMstpSrasWrflDright_ace_rested"; - turnL = "AadjPknlMstpSrasWrflDright_ace_rested"; - turnR = "AadjPknlMstpSrasWrflDright_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFKneelActions_ace_rested : RifleAdjustFKneelActions { - stop = "AadjPknlMstpSrasWrflDup_ace_rested"; - default = "AadjPknlMstpSrasWrflDup_ace_rested"; - turnL = "AadjPknlMstpSrasWrflDup_ace_rested"; - turnR = "AadjPknlMstpSrasWrflDup_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBKneelActions_ace_rested : RifleAdjustBKneelActions { - stop = "AadjPknlMstpSrasWrflDdown_ace_rested"; - default = "AadjPknlMstpSrasWrflDdown_ace_rested"; - turnL = "AadjPknlMstpSrasWrflDdown_ace_rested"; - turnR = "AadjPknlMstpSrasWrflDdown_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleProneActions_ace_rested : RifleProneActions { - stop = "AmovPpneMstpSrasWrflDnon_ace_rested"; - default = "AmovPpneMstpSrasWrflDnon_ace_rested"; - turnL = "AmovPpneMstpSrasWrflDnon_ace_rested"; - turnR = "AmovPpneMstpSrasWrflDnon_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustLProneActions_ace_rested : RifleAdjustLProneActions { - stop = "AadjPpneMstpSrasWrflDleft_ace_rested"; - default = "AadjPpneMstpSrasWrflDleft_ace_rested"; - turnL = "AadjPpneMstpSrasWrflDleft_ace_rested"; - turnR = "AadjPpneMstpSrasWrflDleft_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustRProneActions_ace_rested : RifleAdjustRProneActions { - stop = "AadjPpneMstpSrasWrflDright_ace_rested"; - default = "AadjPpneMstpSrasWrflDright_ace_rested"; - turnL = "AadjPpneMstpSrasWrflDright_ace_rested"; - turnR = "AadjPpneMstpSrasWrflDright_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustFProneActions_ace_rested : RifleAdjustFProneActions { - stop = "aadjppnemstpsraswrfldup_ace_rested"; - default = "aadjppnemstpsraswrfldup_ace_rested"; - turnL = "aadjppnemstpsraswrfldup_ace_rested"; - turnR = "aadjppnemstpsraswrfldup_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class RifleAdjustBProneActions_ace_rested : RifleAdjustBProneActions { - stop = "AadjPpneMstpSrasWrflDdown_ace_rested"; - default = "AadjPpneMstpSrasWrflDdown_ace_rested"; - turnL = "AadjPpneMstpSrasWrflDdown_ace_rested"; - turnR = "AadjPpneMstpSrasWrflDdown_ace_rested"; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - ////////////////////////////////////////////////////////////////////// - // FFV - ////////////////////////////////////////////////////////////////////// - - class passenger_inside_1Actions; - class passenger_inside_1Actions_ace_deploy : passenger_inside_1Actions { - stop = "passenger_inside_1_Aim_ace_deploy"; - default = "passenger_inside_1_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_2Actions; - class passenger_inside_2Actions_ace_deploy : passenger_inside_2Actions { - stop = "passenger_inside_2_Aim_ace_deploy"; - default = "passenger_inside_2_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_3Actions; - class passenger_inside_3Actions_ace_deploy : passenger_inside_3Actions { - stop = "passenger_inside_3_Aim_ace_deploy"; - default = "passenger_inside_3_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_4Actions; - class passenger_inside_4Actions_ace_deploy : passenger_inside_4Actions { - stop = "passenger_inside_4_Aim_ace_deploy"; - default = "passenger_inside_4_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_bench_1Actions; - class passenger_bench_1Actions_ace_deploy : passenger_bench_1Actions { - stop = "passenger_bench_1_Aim_ace_deploy"; - default = "passenger_bench_1_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_1Actions; - class passenger_boat_1Actions_ace_deploy : passenger_boat_1Actions { - stop = "passenger_boat_1_Aim_ace_deploy"; - default = "passenger_boat_1_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_2Actions; - class passenger_boat_2Actions_ace_deploy : passenger_boat_2Actions { - stop = "passenger_boat_2_Aim_ace_deploy"; - default = "passenger_boat_2_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_3Actions; - class passenger_boat_3Actions_ace_deploy : passenger_boat_3Actions { - stop = "passenger_boat_3_Aim_ace_deploy"; - default = "passenger_boat_3_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_4Actions; - class passenger_boat_4Actions_ace_deploy : passenger_boat_4Actions { - stop = "passenger_boat_4_Aim_ace_deploy"; - default = "passenger_boat_4_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_1Actions; - class passenger_flatground_1Actions_ace_deploy : passenger_flatground_1Actions { - stop = "passenger_flatground_1_Aim_ace_deploy"; - default = "passenger_flatground_1_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_2Actions; - class passenger_flatground_2Actions_ace_deploy : passenger_flatground_2Actions { - stop = "passenger_flatground_2_Aim_ace_deploy"; - default = "passenger_flatground_2_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_3Actions; - class passenger_flatground_3Actions_ace_deploy : passenger_flatground_3Actions { - stop = "passenger_flatground_3_Aim_ace_deploy"; - default = "passenger_flatground_3_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_4Actions; - class passenger_flatground_4Actions_ace_deploy : passenger_flatground_4Actions { - stop = "passenger_flatground_4_Aim_ace_deploy"; - default = "passenger_flatground_4_Aim_ace_deploy"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - ////////////////////////////////////////////////////////////////////// - - class passenger_inside_1Actions_ace_rested : passenger_inside_1Actions { - stop = "passenger_inside_1_Aim_ace_rested"; - default = "passenger_inside_1_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_2Actions_ace_rested : passenger_inside_2Actions { - stop = "passenger_inside_2_Aim_ace_rested"; - default = "passenger_inside_2_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_3Actions_ace_rested : passenger_inside_3Actions { - stop = "passenger_inside_3_Aim_ace_rested"; - default = "passenger_inside_3_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_inside_4Actions_ace_rested : passenger_inside_4Actions { - stop = "passenger_inside_4_Aim_ace_rested"; - default = "passenger_inside_4_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_bench_1Actions_ace_rested : passenger_bench_1Actions { - stop = "passenger_bench_1_Aim_ace_rested"; - default = "passenger_bench_1_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_1Actions_ace_rested : passenger_boat_1Actions { - stop = "passenger_boat_1_Aim_ace_rested"; - default = "passenger_boat_1_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_2Actions_ace_rested : passenger_boat_2Actions { - stop = "passenger_boat_2_Aim_ace_rested"; - default = "passenger_boat_2_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_3Actions_ace_rested : passenger_boat_3Actions { - stop = "passenger_boat_3_Aim_ace_rested"; - default = "passenger_boat_3_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_boat_4Actions_ace_rested : passenger_boat_4Actions { - stop = "passenger_boat_4_Aim_ace_rested"; - default = "passenger_boat_4_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_1Actions_ace_rested : passenger_flatground_1Actions { - stop = "passenger_flatground_1_Aim_ace_rested"; - default = "passenger_flatground_1_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_2Actions_ace_rested : passenger_flatground_2Actions { - stop = "passenger_flatground_2_Aim_ace_rested"; - default = "passenger_flatground_2_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_3Actions_ace_rested : passenger_flatground_3Actions { - stop = "passenger_flatground_3_Aim_ace_rested"; - default = "passenger_flatground_3_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - - class passenger_flatground_4Actions_ace_rested : passenger_flatground_4Actions { - stop = "passenger_flatground_4_Aim_ace_rested"; - default = "passenger_flatground_4_Aim_ace_rested"; - turnL = ""; - turnR = ""; - turnSpeed = ACE_DEPLOY_TURNSPEED; - limitFast = 1; - }; - }; -}; - -class CfgMovesMaleSdr : CfgMovesBasic { - class States { - class AmovPercMstpSrasWrflDnon; - class AmovPercMstpSrasWrflDnon_ace_deploy : AmovPercMstpSrasWrflDnon { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleStandActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"AmovPercMstpSrasWrflDnon_ace_deploy", 0.02}; - ConnectFrom[] = {"AmovPercMstpSrasWrflDnon_ace_deploy", 0.02}; - InterpolateFrom[] = {"AmovPercMstpSrasWrflDnon", 0.02}; - InterpolateTo[] = {"AmovPercMstpSrasWrflDnon", 0.02}; - }; - - class aadjpercmstpsraswrfldup; - class aadjpercmstpsraswrfldup_ace_deploy : aadjpercmstpsraswrfldup { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustFStandActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldup_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldup_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldup", 0.02}; - }; - - class aadjpercmstpsraswrflddown; - class aadjpercmstpsraswrflddown_ace_deploy : aadjpercmstpsraswrflddown { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustBStandActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrflddown_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrflddown_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrflddown", 0.02}; - }; - - class aadjpercmstpsraswrfldright; - class aadjpercmstpsraswrfldright_ace_deploy : aadjpercmstpsraswrfldright { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustRStandActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldright_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldright_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldright", 0.02}; - }; - - class aadjpercmstpsraswrfldleft; - class aadjpercmstpsraswrfldleft_ace_deploy : aadjpercmstpsraswrfldleft { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustLStandActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldleft_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldleft_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldleft", 0.02}; - }; - - class aadjpknlmstpsraswrfldup; - class aadjpknlmstpsraswrfldup_ace_deploy : aadjpknlmstpsraswrfldup { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustFKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldup_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldup_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldup", 0.02}; - }; - - class amovpknlmstpsraswrfldnon; - class amovpknlmstpsraswrfldnon_ace_deploy : amovpknlmstpsraswrfldnon { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"amovpknlmstpsraswrfldnon_ace_deploy", 0.02}; - ConnectFrom[] = {"amovpknlmstpsraswrfldnon_ace_deploy", 0.02}; - InterpolateFrom[] = {"amovpknlmstpsraswrfldnon", 0.02}; - InterpolateTo[] = {"amovpknlmstpsraswrfldnon", 0.02}; - }; - - class aadjpknlmstpsraswrflddown; - class aadjpknlmstpsraswrflddown_ace_deploy : aadjpknlmstpsraswrflddown { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustBKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrflddown_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrflddown_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrflddown", 0.02}; - }; - - class aadjpknlmstpsraswrfldleft; - class aadjpknlmstpsraswrfldleft_ace_deploy : aadjpknlmstpsraswrfldleft { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustLKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldleft_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldleft_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldleft", 0.02}; - }; - - class aadjpknlmstpsraswrfldright; - class aadjpknlmstpsraswrfldright_ace_deploy : aadjpknlmstpsraswrfldright { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "RifleAdjustRKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldright_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldright_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldright", 0.02}; - }; - - class aadjppnemstpsraswrfldup; - class aadjppnemstpsraswrfldup_ace_deploy : aadjppnemstpsraswrfldup { - aimPrecision = ACE_SWAY_DEPLOYPRONE; - actions = "RifleAdjustFProneActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldup_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldup_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldup", 0.02}; - }; - - class amovppnemstpsraswrfldnon; - class amovppnemstpsraswrfldnon_ace_deploy : amovppnemstpsraswrfldnon { - aimPrecision = ACE_SWAY_DEPLOYPRONE; - actions = "RifleProneActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"amovppnemstpsraswrfldnon_ace_deploy", 0.02}; - ConnectFrom[] = {"amovppnemstpsraswrfldnon_ace_deploy", 0.02}; - InterpolateFrom[] = {"amovppnemstpsraswrfldnon", 0.02}; - InterpolateTo[] = {"amovppnemstpsraswrfldnon", 0.02}; - }; - - class aadjppnemstpsraswrflddown; - class aadjppnemstpsraswrflddown_ace_deploy : aadjppnemstpsraswrflddown { - aimPrecision = ACE_SWAY_DEPLOYPRONE; - actions = "RifleAdjustBKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrflddown_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrflddown_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrflddown", 0.02}; - }; - - class aadjppnemstpsraswrfldleft; - class aadjppnemstpsraswrfldleft_ace_deploy : aadjppnemstpsraswrfldleft { - aimPrecision = ACE_SWAY_DEPLOYPRONE; - actions = "RifleAdjustLKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldleft_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldleft_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldleft", 0.02}; - }; - - class aadjppnemstpsraswrfldright; - class aadjppnemstpsraswrfldright_ace_deploy : aadjppnemstpsraswrfldright { - aimPrecision = ACE_SWAY_DEPLOYPRONE; - actions = "RifleAdjustRKneelActions_ace_deploy"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldright_ace_deploy", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldright_ace_deploy", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldright", 0.02}; - }; - - ///////////////////////////////////////////////////////////////////////////// - - class AmovPercMstpSrasWrflDnon_ace_rested : AmovPercMstpSrasWrflDnon { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleStandActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"AmovPercMstpSrasWrflDnon_ace_rested", 0.02}; - ConnectFrom[] = {"AmovPercMstpSrasWrflDnon_ace_rested", 0.02}; - InterpolateFrom[] = {"AmovPercMstpSrasWrflDnon", 0.02}; - InterpolateTo[] = {"AmovPercMstpSrasWrflDnon", 0.02}; - }; - - class aadjpercmstpsraswrfldup_ace_rested : aadjpercmstpsraswrfldup { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustFStandActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldup_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldup_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldup", 0.02}; - }; - - class aadjpercmstpsraswrflddown_ace_rested : aadjpercmstpsraswrflddown { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustBStandActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrflddown_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrflddown_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrflddown", 0.02}; - }; - - class aadjpercmstpsraswrfldright_ace_rested : aadjpercmstpsraswrfldright { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustRStandActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldright_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldright_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldright", 0.02}; - }; - - class aadjpercmstpsraswrfldleft_ace_rested : aadjpercmstpsraswrfldleft { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustLStandActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpercmstpsraswrfldleft_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpercmstpsraswrfldleft_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpercmstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjpercmstpsraswrfldleft", 0.02}; - }; - - class aadjpknlmstpsraswrfldup_ace_rested : aadjpknlmstpsraswrfldup { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustFKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldup_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldup_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldup", 0.02}; - }; - - class amovpknlmstpsraswrfldnon_ace_rested : amovpknlmstpsraswrfldnon { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"amovpknlmstpsraswrfldnon_ace_rested", 0.02}; - ConnectFrom[] = {"amovpknlmstpsraswrfldnon_ace_rested", 0.02}; - InterpolateFrom[] = {"amovpknlmstpsraswrfldnon", 0.02}; - InterpolateTo[] = {"amovpknlmstpsraswrfldnon", 0.02}; - }; - - class aadjpknlmstpsraswrflddown_ace_rested : aadjpknlmstpsraswrflddown { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustBKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrflddown_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrflddown_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrflddown", 0.02}; - }; - - class aadjpknlmstpsraswrfldleft_ace_rested : aadjpknlmstpsraswrfldleft { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustLKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldleft_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldleft_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldleft", 0.02}; - }; - - class aadjpknlmstpsraswrfldright_ace_rested : aadjpknlmstpsraswrfldright { - aimPrecision = ACE_SWAY_RESTED; - actions = "RifleAdjustRKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjpknlmstpsraswrfldright_ace_rested", 0.02}; - ConnectFrom[] = {"aadjpknlmstpsraswrfldright_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjpknlmstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjpknlmstpsraswrfldright", 0.02}; - }; - - class aadjppnemstpsraswrfldup_ace_rested : aadjppnemstpsraswrfldup { - aimPrecision = ACE_SWAY_RESTEDPRONE; - actions = "RifleAdjustFProneActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldup_ace_rested", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldup_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldup", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldup", 0.02}; - }; - - class amovppnemstpsraswrfldnon_ace_rested : amovppnemstpsraswrfldnon { - aimPrecision = ACE_SWAY_RESTEDPRONE; - actions = "RifleProneActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"amovppnemstpsraswrfldnon_ace_rested", 0.02}; - ConnectFrom[] = {"amovppnemstpsraswrfldnon_ace_rested", 0.02}; - InterpolateFrom[] = {"amovppnemstpsraswrfldnon", 0.02}; - InterpolateTo[] = {"amovppnemstpsraswrfldnon", 0.02}; - }; - - class aadjppnemstpsraswrflddown_ace_rested : aadjppnemstpsraswrflddown { - aimPrecision = ACE_SWAY_RESTEDPRONE; - actions = "RifleAdjustBKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrflddown_ace_rested", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrflddown_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrflddown", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrflddown", 0.02}; - }; - - class aadjppnemstpsraswrfldleft_ace_rested : aadjppnemstpsraswrfldleft { - aimPrecision = ACE_SWAY_RESTEDPRONE; - actions = "RifleAdjustLKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldleft_ace_rested", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldleft_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldleft", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldleft", 0.02}; - }; - - class aadjppnemstpsraswrfldright_ace_rested : aadjppnemstpsraswrfldright { - aimPrecision = ACE_SWAY_RESTEDPRONE; - actions = "RifleAdjustRKneelActions_ace_rested"; - aiming = "aimingLying"; - speed = 0.01; - onLandEnd = true; - onLandBeg = true; - - ConnectTo[] = {"aadjppnemstpsraswrfldright_ace_rested", 0.02}; - ConnectFrom[] = {"aadjppnemstpsraswrfldright_ace_rested", 0.02}; - InterpolateFrom[] = {"aadjppnemstpsraswrfldright", 0.02}; - InterpolateTo[] = {"aadjppnemstpsraswrfldright", 0.02}; - }; - - ////////////////////////////////////////////////////////////////////// - // FFV - ////////////////////////////////////////////////////////////////////// - - class passenger_bench_1_Aim; - class passenger_bench_1_Aim_ace_deploy : passenger_bench_1_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_bench_1Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_bench_1_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_bench_1_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_bench_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_bench_1_Aim", 0.02}; - }; - - class passenger_inside_1_Aim; - class passenger_inside_1_Aim_ace_deploy : passenger_inside_1_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_inside_1Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_1_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_inside_1_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_inside_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_1_Aim", 0.02}; - }; - - class passenger_inside_2_Aim; - class passenger_inside_2_Aim_ace_deploy : passenger_inside_2_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_inside_2Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_2_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_inside_2_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_inside_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_2_Aim", 0.02}; - }; - - class passenger_inside_3_Aim; - class passenger_inside_3_Aim_ace_deploy : passenger_inside_3_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_inside_3Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_3_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_inside_3_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_inside_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_3_Aim", 0.02}; - }; - - class passenger_inside_4_Aim; - class passenger_inside_4_Aim_ace_deploy : passenger_inside_4_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_inside_4Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_4_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_inside_4_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_inside_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_4_Aim", 0.02}; - }; - - class passenger_boat_1_Aim; - class passenger_boat_1_Aim_ace_deploy : passenger_boat_1_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_boat_1Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_1_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_boat_1_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_boat_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_1_Aim", 0.02}; - }; - - class passenger_boat_2_Aim; - class passenger_boat_2_Aim_ace_deploy : passenger_boat_2_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_boat_2Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_2_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_boat_2_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_boat_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_2_Aim", 0.02}; - }; - - class passenger_boat_3_Aim; - class passenger_boat_3_Aim_ace_deploy : passenger_boat_3_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_boat_3Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_3_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_boat_3_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_boat_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_3_Aim", 0.02}; - }; - - class passenger_boat_4_Aim; - class passenger_boat_4_Aim_ace_deploy : passenger_boat_4_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_boat_4Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_4_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_boat_4_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_boat_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_4_Aim", 0.02}; - }; - - class passenger_flatground_1_Aim; - class passenger_flatground_1_Aim_ace_deploy : passenger_flatground_1_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_flatground_1Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_1_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_flatground_1_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_flatground_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_1_Aim", 0.02}; - }; - - class passenger_flatground_2_Aim; - class passenger_flatground_2_Aim_ace_deploy : passenger_flatground_2_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_flatground_2Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_2_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_flatground_2_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_flatground_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_2_Aim", 0.02}; - }; - - class passenger_flatground_3_Aim; - class passenger_flatground_3_Aim_ace_deploy : passenger_flatground_3_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_flatground_3Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_3_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_flatground_3_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_flatground_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_3_Aim", 0.02}; - }; - - class passenger_flatground_4_Aim; - class passenger_flatground_4_Aim_ace_deploy : passenger_flatground_4_Aim { - aimPrecision = ACE_SWAY_DEPLOY; - actions = "passenger_flatground_4Actions_ace_deploy"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_4_Aim_ace_deploy", 0.02}; - ConnectFrom[] = {"passenger_flatground_4_Aim_ace_deploy", 0.02}; - InterpolateFrom[] = {"passenger_flatground_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_4_Aim", 0.02}; - }; - - ////////////////////////////////////////////////////////////////////// - - class passenger_bench_1_Aim_ace_rested : passenger_bench_1_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_bench_1Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_bench_1_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_bench_1_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_bench_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_bench_1_Aim", 0.02}; - }; - - class passenger_inside_1_Aim_ace_rested : passenger_inside_1_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_inside_1Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_1_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_inside_1_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_inside_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_1_Aim", 0.02}; - }; - - class passenger_inside_2_Aim_ace_rested : passenger_inside_2_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_inside_2Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_2_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_inside_2_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_inside_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_2_Aim", 0.02}; - }; - - class passenger_inside_3_Aim_ace_rested : passenger_inside_3_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_inside_3Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_3_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_inside_3_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_inside_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_3_Aim", 0.02}; - }; - - class passenger_inside_4_Aim_ace_rested : passenger_inside_4_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_inside_4Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_inside_4_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_inside_4_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_inside_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_inside_4_Aim", 0.02}; - }; - - class passenger_boat_1_Aim_ace_rested : passenger_boat_1_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_boat_1Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_1_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_boat_1_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_boat_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_1_Aim", 0.02}; - }; - - class passenger_boat_2_Aim_ace_rested : passenger_boat_2_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_boat_2Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_2_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_boat_2_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_boat_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_2_Aim", 0.02}; - }; - - class passenger_boat_3_Aim_ace_rested : passenger_boat_3_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_boat_3Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_3_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_boat_3_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_boat_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_3_Aim", 0.02}; - }; - - class passenger_boat_4_Aim_ace_rested : passenger_boat_4_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_boat_4Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_boat_4_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_boat_4_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_boat_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_boat_4_Aim", 0.02}; - }; - - class passenger_flatground_1_Aim_ace_rested : passenger_flatground_1_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_flatground_1Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_1_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_flatground_1_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_flatground_1_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_1_Aim", 0.02}; - }; - - class passenger_flatground_2_Aim_ace_rested : passenger_flatground_2_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_flatground_2Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_2_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_flatground_2_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_flatground_2_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_2_Aim", 0.02}; - }; - - class passenger_flatground_3_Aim_ace_rested : passenger_flatground_3_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_flatground_3Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_3_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_flatground_3_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_flatground_3_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_3_Aim", 0.02}; - }; - - class passenger_flatground_4_Aim_ace_rested : passenger_flatground_4_Aim { - aimPrecision = ACE_SWAY_RESTED; - actions = "passenger_flatground_4Actions_ace_rested"; - aiming = "aimingDefault"; - speed = 0.01; - onLandEnd = false; - onLandBeg = false; - - ConnectTo[] = {"passenger_flatground_4_Aim_ace_rested", 0.02}; - ConnectFrom[] = {"passenger_flatground_4_Aim_ace_rested", 0.02}; - InterpolateFrom[] = {"passenger_flatground_4_Aim", 0.02}; - InterpolateTo[] = {"passenger_flatground_4_Aim", 0.02}; - }; - }; -}; diff --git a/addons/resting/CfgSounds.hpp b/addons/resting/CfgSounds.hpp deleted file mode 100644 index b55d4d9ae8..0000000000 --- a/addons/resting/CfgSounds.hpp +++ /dev/null @@ -1,14 +0,0 @@ -class CfgSounds { - class GVAR(rest) - { - name=QGVAR(rest); - sound[]={QUOTE(PATHTOF(sounds\weaponrest_rest.wav)),1,1}; - titles[]={}; - }; - class GVAR(unrest) - { - name=QGVAR(unrest); - sound[]={QUOTE(PATHTOF(sounds\weaponrest_unrest.wav)),1,1}; - titles[]={}; - }; -}; \ No newline at end of file diff --git a/addons/resting/CfgWeapons.hpp b/addons/resting/CfgWeapons.hpp deleted file mode 100644 index 56bef2c033..0000000000 --- a/addons/resting/CfgWeapons.hpp +++ /dev/null @@ -1,22 +0,0 @@ -class CfgWeapons { - class Rifle_Long_Base_F; - class arifle_MX_Base_F; - - class arifle_MX_SW_F : arifle_MX_Base_F { - ACE_Bipod = 1; - }; - - class LMG_Mk200_F : Rifle_Long_Base_F { - ACE_Bipod = 1; - }; - class LMG_Zafir_F: Rifle_Long_Base_F { - ACE_Bipod = 1; - }; - - class LRR_base_F : Rifle_Long_Base_F { - ACE_Bipod = 1; - }; - class GM6_base_F : Rifle_Long_Base_F { - ACE_Bipod = 1; - }; -}; diff --git a/addons/resting/README.md b/addons/resting/README.md deleted file mode 100644 index 477ced17b5..0000000000 --- a/addons/resting/README.md +++ /dev/null @@ -1,12 +0,0 @@ -ace_resting -=========== - -Introduces weapon resting and bipod deployment, allowing the player to increase the stability of his weapon. - - -## Maintainers - -The people responsible for merging changes to this component or answering potential questions. - -- [KoffeinFlummi](https://github.com/KoffeinFlummi) -- [commy2](https://github.com/commy2) diff --git a/addons/resting/XEH_postInit.sqf b/addons/resting/XEH_postInit.sqf deleted file mode 100644 index bd78ae0044..0000000000 --- a/addons/resting/XEH_postInit.sqf +++ /dev/null @@ -1,23 +0,0 @@ -// by esteldunedain -#include "script_component.hpp" - -if !(hasInterface) exitWith {}; - -// Add keybinds -["ACE3", QGVAR(RestWeapon), localize "STR_ACE_Resting_RestWeapon", -{ - // Conditions: canInteract - if !([ACE_player, objNull, []] call EFUNC(common,canInteractWith)) exitWith {false}; - // Conditions: specific - if !([ACE_player] call EFUNC(common,canUseWeapon) && - {inputAction 'reloadMagazine' == 0} && - {!weaponLowered ACE_player} && - {speed ACE_player < 1}) exitWith {false}; - - // Statement - [ACE_player, vehicle ACE_player, currentWeapon ACE_player] call FUNC(restWeapon); - // Return false so it doesn't block other actions - false -}, -{false}, -[15, [false, false, false]], false] call cba_fnc_addKeybind; diff --git a/addons/resting/XEH_preInit.sqf b/addons/resting/XEH_preInit.sqf deleted file mode 100644 index 6a2a2040b7..0000000000 --- a/addons/resting/XEH_preInit.sqf +++ /dev/null @@ -1,11 +0,0 @@ -#include "script_component.hpp" - -ADDON = false; - -PREP(getIntersection); -PREP(hasBipod); -PREP(pfhCheckRest); -PREP(restWeapon); -PREP(unRestWeapon); - -ADDON = true; diff --git a/addons/resting/config.cpp b/addons/resting/config.cpp deleted file mode 100644 index f1cc20c6e2..0000000000 --- a/addons/resting/config.cpp +++ /dev/null @@ -1,21 +0,0 @@ -#include "script_component.hpp" - -class CfgPatches { - class ADDON { - units[] = {}; - weapons[] = {}; - requiredVersion = REQUIRED_VERSION; - requiredAddons[] = {"ace_common"}; - author[] = {"KoffeinFlummi", "TaoSensai", "esteldunedain"}; - authorUrl = "https://github.com/KoffeinFlummi/"; - VERSION_CONFIG; - }; -}; - -#include "CfgEventHandlers.hpp" - -#include "CfgWeapons.hpp" - -#include "CfgMoves.hpp" - -#include "CfgSounds.hpp" \ No newline at end of file diff --git a/addons/resting/data/icons/icon_bipod.paa b/addons/resting/data/icons/icon_bipod.paa deleted file mode 100644 index c2b6a2fb3e1b92e0b33034dbd7dbffc855baa9e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5625 zcmeGg3s6*5^gebU5tF-+Y)U{bilpV3&g7<{?%R~lIx0KGBd0CC*hd+t5= z-1EQZKAuKLTjHif$6K_7kmly*Q4F7DnSnS3Ks?$qJqmFS9>m{>ii#EB|1x;8{0PYo zAY_Aqkkjz=4g?|)0vsMNj3CzBFl(-sQbI&gG-xhLsZR3uK?N5;hQ}L5RhU-hz4}8N z>WfaC(G+-kRR_A4paaOTby8$4VAX)54|Qeh?NvFK%{XrZ0YK4oLpf z5J^E^X+=1b7Zjoq{x%etQoHN7Zdt~0758{z>y*+frQsUdv2N5Wp0f3gEmz4y@-)}ad`^`txhgQnOrn6!cLvS<_BisM-INTQ6Zk>5iE}Tj!2JTpK_*S~YeN(fDyH z{c{qf=W@CcWtMnrXQq78+{N?<^@VsMemH6Q!0|Y16D*d8t+no^dN%BGR8q;|lb@hG z9Js!qvAq!dovF(2e`xs(=Z;jCzqYtI@n(64mRF|NwWf74ZF!zweFj%zyp%wMc%8{%6dVtiO(+3HI(Wa4kNt<;AVag8Xxo>ohn z%N#P(mw>C{L$mlVDwzbnvb4L!?prp-P`|{u^Q3+4Ls?rPu< zz=bxf>pE4a#J``PAcS68y0`k;k8^PUhp#;$11?HQwHI97`4F8v1bjs&rDocEg3{nR zLY^F#2lXi|Ha86AgYtY!yx-H_%{E;v(bwa84)S4O8I{Xua{<}|^?fGm+BWmyv%_&7 zfD2{$xPt8m{Y9_s&A8mPexk_p`jZ!+Iu+3GU9dT<(;mp|D%Z=UihO4W(|kCCSY=+o4E@Rn9@UYrof;>#aQ9Q)<=0ZtGRo)8B?2OW#0Ctn1Z&(E$BoKs)9`Ash%3 zA-2juKA^w*9<KPXDj>g?z5HuGgY|BEO8!GZ^FFsRd$^Puq-ZM|D$cWb zfR{4jzh5tx(>4cUk7GOpPm+?={4+rQjcbA88=vg92V9wI=~aE8yKjaB?47m$r#2EJ zWR=GbfOuLN9J~`A`MZ=_9#hf9(hl-6Yz@@J1+uvs(-xfIe}`lFPW*5$1S33ZX!pcz zE-7_WMjDhsxMsmQL>KZfy(|)s#SL%H*3q*_jmKnuTX?uHG1qVFDjl+PpOO~W6T=8p zx8ski5sdKQJRCzee71@aGiNgL!#02XN9HA_oyxI`2k+3vPruu8FrCc<3r-iW zx9iG?9_ax*1~vk6Kl=~Ql@cT1B*67N^qE77kL($eDIaz76Mzi^BfOE{)QfONo6>8l znS4AyvcY7G{&>*WNblJkXjOXn%fJZl+sUJ8HZ63uHl4>y2y|hbca1~d|80m9udQ$m z@mxFA^?pUBvic^gg43~ zy7HUksAQ+2FDIt#-k#tra$lot*VA03=K`g~AgB~b58E52JM4R_>2U|fgVDrTvzJP* zj`SDKL%e9Md1~7xMmJq^bk{3w6YRzL7w-shW_4Afd_Ax2{k8us`h0#&KLQ4EKaPhs zWp0kAO|D(J3u z4q#ybx97OPy4myJ$(YaNfo7D`k=PaLY1y;;Rrvv121a-zfA7s1X)aR|mdEKX}I1x+y> "CfgWeapons" >> _weapon; - -getNumber (_config >> "ACE_Bipod") == 1 || -getNumber (_config >> "AGM_Bipod") == 1 || -{getNumber (_config >> "tmr_autorest_deployable") == 1} diff --git a/addons/resting/functions/fnc_pfhCheckRest.sqf b/addons/resting/functions/fnc_pfhCheckRest.sqf deleted file mode 100644 index 0f6fea300b..0000000000 --- a/addons/resting/functions/fnc_pfhCheckRest.sqf +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Author: KoffeinFlummi, edited by commy2 and esteldunedain - * - * PFH that check for player moving away, changing weapon, etc - * and unrests the weapon if necessary - * - * Arguments: - * 0: unit - * 1: vehicle - * 2: weapon - * 3: rested position - * - * Return Values: - * None - * - */ -#include "script_component.hpp" - -EXPLODE_2_PVT(_this,_params,_pfhId); -EXPLODE_4_PVT(_params,_unit,_vehicle,_weapon,_restedPosition); - -if !(_unit getVariable ["ACE_weaponRested", false]) exitWith { - [_pfhId] call cba_fnc_removePerFrameHandler; -}; - -private ["_intersects"]; -_intersects = _params call FUNC(getIntersection); - -if ( - _unit != ACE_player - || {_vehicle != vehicle _unit} - || {inputAction "reloadMagazine" != 0} - || {weaponLowered _unit} - || {speed _unit > 1} - || {currentWeapon _unit != _weapon} - || {getPosASL _unit distanceSqr _restedPosition > 1} - || {!(true in _intersects)} -) exitWith { - [_pfhId] call cba_fnc_removePerFrameHandler; - [_unit, _vehicle, _weapon] call FUNC(unRestWeapon); -}; diff --git a/addons/resting/functions/fnc_restWeapon.sqf b/addons/resting/functions/fnc_restWeapon.sqf deleted file mode 100644 index 75d16a62be..0000000000 --- a/addons/resting/functions/fnc_restWeapon.sqf +++ /dev/null @@ -1,66 +0,0 @@ -/* - * Author: KoffeinFlummi, edited by commy2 and esteldunedain - * - * Rests the player's weapon if possible. - * - * Arguments: - * None - * - * Return Values: - * None - * - */ -#include "script_component.hpp" - -EXPLODE_3_PVT(_this,_unit,_vehicle,_weapon); - -if (_weapon != primaryWeapon _unit) exitWith {}; - -if (_unit getVariable ["ACE_weaponRested", false]) exitWith {_this call FUNC(unRestWeapon)}; - -// exit if this is not an available animation -if (!isClass (configFile >> "CfgMovesMaleSdr" >> "States" >> format ["%1_ace_deploy", animationState _unit])) exitWith {}; - -// CHECK FOR APPROPRIATE SURFACE -private "_intersects"; -_intersects = _this call FUNC(getIntersection); - -if (true in _intersects) then { - _unit setVariable ["ACE_weaponRested", true]; - if (_unit == ACE_PLAYER) then { - [QGVAR(bipodDeployed), true, QUOTE(PATHTOF(data\icons\icon_bipod.paa)), [1,1,1,1], -1] call EFUNC(common,displayIcon); - }; - - private "_restedPosition"; - _restedPosition = getPosASL _unit; - - // REST THE WEAPON - addCamShake CAMSHAKE; - playSound QGVAR(rest); - - if ([_weapon] call FUNC(hasBipod) && {_intersects select 3}) then { - _unit setVariable ["ACE_bipodDeployed", true]; - - _unit setUnitRecoilCoefficient (BIPODRECOIL * unitRecoilCoefficient _unit); - //[_unit, format ["%1_ace_deploy", animationState _unit], 2] call EFUNC(common,doAnimation); - _unit switchMove format ["%1_ace_deploy", animationState _unit]; - - private "_picture"; - _picture = getText (configFile >> "CfgWeapons" >> _weapon >> "picture"); - [localize "STR_ACE_Resting_BipodDeployed", _picture] call EFUNC(common,displayTextPicture); - - } else { - _unit setVariable ["ACE_bipodDeployed", false]; - - _unit setUnitRecoilCoefficient (RESTEDRECOIL * unitRecoilCoefficient _unit); - //[_unit, format ["%1_ace_rested", animationState _unit], 2] call EFUNC(common,doAnimation); - _unit switchMove format ["%1_ace_rested", animationState _unit]; - - private "_picture"; - _picture = getText (configFile >> "CfgWeapons" >> _weapon >> "picture"); - [localize "STR_ACE_Resting_WeaponRested", _picture] call EFUNC(common,displayTextPicture); - }; - - // Launch a PFH to check for player moving away, changing weapon, etc - [FUNC(pfhCheckRest), 0.2, [_unit, _vehicle, _weapon, _restedPosition] ] call CBA_fnc_addPerFrameHandler; -}; diff --git a/addons/resting/functions/fnc_unRestWeapon.sqf b/addons/resting/functions/fnc_unRestWeapon.sqf deleted file mode 100644 index ef5a52b824..0000000000 --- a/addons/resting/functions/fnc_unRestWeapon.sqf +++ /dev/null @@ -1,53 +0,0 @@ -/* - * Author: KoffeinFlummi, edited by commy2 and esteldunedain - * - * Un Rests the player's weapon - * - * Arguments: - * 0: unit - * 1: vehicle - * 2: weapon - * - * Return Values: - * None - * - */ -#include "script_component.hpp" - -EXPLODE_3_PVT(_this,_unit,_vehicle,_weapon); - -addCamShake CAMSHAKE; - -private "_animation"; -_animation = animationState _unit; - -if (_unit getVariable ["ACE_bipodDeployed", false]) then { - _unit setUnitRecoilCoefficient (unitRecoilCoefficient _unit / BIPODRECOIL); - if (_animation find "_ace_deploy" != -1) then { - //[_unit, [_animation, "_ace_deploy", ""] call CBA_fnc_replace, 2] call EFUNC(common,doAnimation); - _unit switchMove ([_animation, "_ace_deploy", ""] call CBA_fnc_replace); - }; - - private "_picture"; - _picture = getText (configFile >> "CfgWeapons" >> _weapon >> "picture"); - [localize "STR_ACE_Resting_BipodUndeployed", _picture] call EFUNC(common,displayTextPicture); - -} else { - _unit setUnitRecoilCoefficient (unitRecoilCoefficient _unit / RESTEDRECOIL); - if (_animation find "_ace_rested" != -1) then { - //[_unit, [_animation, "_ace_rested", ""] call CBA_fnc_replace, 2] call EFUNC(common,doAnimation); - _unit switchMove ([_animation, "_ace_rested", ""] call CBA_fnc_replace); - }; - - private "_picture"; - _picture = getText (configFile >> "CfgWeapons" >> _weapon >> "picture"); - [localize "STR_ACE_Resting_WeaponLifted", _picture] call EFUNC(common,displayTextPicture); -}; -playSound QGVAR(unrest); - -_unit setVariable ["ACE_weaponRested", false]; -_unit setVariable ["ACE_bipodDeployed", false]; - -if (_unit == ACE_PLAYER) then { - [QGVAR(bipodDeployed), false, "", [1,1,1,1], -1] call EFUNC(common,displayIcon); -}; \ No newline at end of file diff --git a/addons/resting/functions/script_component.hpp b/addons/resting/functions/script_component.hpp deleted file mode 100644 index 9a1f2912f9..0000000000 --- a/addons/resting/functions/script_component.hpp +++ /dev/null @@ -1 +0,0 @@ -#include "\z\ace\addons\resting\script_component.hpp" \ No newline at end of file diff --git a/addons/resting/script_component.hpp b/addons/resting/script_component.hpp deleted file mode 100644 index f6d28bc482..0000000000 --- a/addons/resting/script_component.hpp +++ /dev/null @@ -1,19 +0,0 @@ -#define COMPONENT resting -#include "\z\ace\Addons\main\script_mod.hpp" - -#ifdef DEBUG_ENABLED_RESTING - #define DEBUG_MODE_FULL -#endif - -#ifdef DEBUG_SETTINGS_RESTING - #define DEBUG_SETTINGS DEBUG_SETTINGS_RESTING -#endif - -#include "\z\ace\Addons\main\script_macros.hpp" - -#define RESTEDRECOIL 0.6 -#define BIPODRECOIL 0.3 -#define MAXDISTANCE 1 -#define MAXANGLE 15 -#define MAXHEIGHT 0.45 -#define CAMSHAKE [1,0.5,5] diff --git a/addons/resting/sounds/weaponrest_rest.wav b/addons/resting/sounds/weaponrest_rest.wav deleted file mode 100644 index fce6386425bc3dec26b8eda01649e9643549e4c8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19866 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 K8Xg_Z*na^jA(k)z diff --git a/addons/resting/sounds/weaponrest_unrest.wav b/addons/resting/sounds/weaponrest_unrest.wav deleted file mode 100644 index 72518ddbbf761d6442b8d0c41a05da1c1fbbeae2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 77354 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 - - - - - Rest Weapon - Waffe auflegen - Apoyar el arma - Oprzyj broń - Zapřít zbraň - Appuyer l'arme - Зафиксировать оружие - Fegyver kitámasztása - Apoiar Arma - Appoggia l'arma - - - - Bipod deployed - Zweibein ausgeklappt - Bípode desplegado - Dwójnóg rozstawiony - Dvojnožka rozložena - Bipied déployé - Сошки установлены - Állványon - Bipé apoiado - Bipiede appoggiato - - - Weapon rested - Waffe aufgelegt - Arma apoyada - Broń oparta - Zbraň zapřena - Arme appuyée - Оружие зафиксировано - Fegyver kitámasztva - Arma apoiada - Arma appoggiata - - - - Bipod undeployed - Zweibein eingeklappt - Bípode plegado - Dwójnóg złożony - Dvojnožka rozložena - Bipied replié - Сошки убраны - Állvány csukva - Bipé recolhido - Bipiede richiuso - - - Weapon lifted - Waffe gehoben - Arma levantada - Broń podniesiona - Zbraň zdvihnuta - Arme relevée - Оружие не зафиксировано - Fegyver nincs támasztva - Arma levantada - Arma sollevata - - - - From b10d3b26ce0ef93d8c86aa4e7664743f8cb574d9 Mon Sep 17 00:00:00 2001 From: commy2 Date: Sat, 28 Mar 2015 11:23:13 +0100 Subject: [PATCH 09/28] replace variables with new scripting commands --- addons/recoil/functions/fnc_burstDispersion.sqf | 4 ++-- addons/recoil/functions/fnc_camShake.sqf | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/addons/recoil/functions/fnc_burstDispersion.sqf b/addons/recoil/functions/fnc_burstDispersion.sqf index 9467e922ff..c038d1fb4d 100644 --- a/addons/recoil/functions/fnc_burstDispersion.sqf +++ b/addons/recoil/functions/fnc_burstDispersion.sqf @@ -41,8 +41,8 @@ if (time - _lastFired < 0.45) then { // Maximum possible dispersion (without _sightsBurst mod) _maxBurst = 50; - if (_unit getVariable [QUOTE(EGVAR(resting,weaponRested)), false]) then {_maxBurst = 25}; - if (_unit getVariable [QUOTE(EGVAR(resting,bipodDeployed)), false]) then {_maxBurst = 18}; + if (isWeaponRested _unit) then {_maxBurst = 25}; + if (isWeaponDeployed _unit) then {_maxBurst = 18}; // Cap the dispersion _burst = (_burst min _maxBurst) + _sightsBurst; diff --git a/addons/recoil/functions/fnc_camShake.sqf b/addons/recoil/functions/fnc_camShake.sqf index cfe179d67b..ad9a98c4d4 100644 --- a/addons/recoil/functions/fnc_camShake.sqf +++ b/addons/recoil/functions/fnc_camShake.sqf @@ -48,8 +48,8 @@ if (_unit != vehicle _unit) then { _powerCoef = (call compile format ["%1", _powerCoef]) * RECOIL_COEF; }; -if (_unit getVariable [QUOTE(EGVAR(resting,weaponRested)), false]) then {_powerMod = _powerMod - 0.07}; -if (_unit getVariable [QUOTE(EGVAR(resting,bipodDeployed)), false]) then {_powerMod = _powerMod - 0.11}; +if (isWeaponRested _unit) then {_powerMod = _powerMod - 0.07}; +if (isWeaponDeployed _unit) then {_powerMod = _powerMod - 0.11}; private "_camshake"; _camshake = [ From 33f0ff9b82f7b4eed146b18a6e676955312d99f2 Mon Sep 17 00:00:00 2001 From: commy2 Date: Sun, 29 Mar 2015 14:19:01 +0200 Subject: [PATCH 10/28] 1.42 ensure ace is loaded after marksmen configs --- addons/main/config.cpp | 49 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/addons/main/config.cpp b/addons/main/config.cpp index 44e9c6f33e..a6a85418c3 100644 --- a/addons/main/config.cpp +++ b/addons/main/config.cpp @@ -51,6 +51,7 @@ class CfgPatches { "a3_anims_f_epc", "a3_anims_f_heli", "a3_anims_f_kart", + "a3_anims_f_mark_deployment", "a3_armor_f", "a3_armor_f_amv", "a3_armor_f_apc_wheeled_03", @@ -93,6 +94,7 @@ class CfgPatches { "a3_characters_f_heads", "a3_characters_f_indep", "a3_characters_f_kart", + "a3_characters_f_mark", "a3_characters_f_opfor", "a3_characters_f_proxies", "a3_data_f", @@ -108,6 +110,7 @@ class CfgPatches { "a3_data_f_hook", "a3_data_f_kart", "a3_data_f_kart_particleeffects", + "a3_data_f_mark", "a3_data_f_particleeffects", "a3_dubbing_radio_f", "a3_editor_f", @@ -117,6 +120,8 @@ class CfgPatches { "a3_functions_f_epa", "a3_functions_f_epc", "a3_functions_f_heli", + "a3_functions_f_mark", + "a3_functions_f_mp_mark", "a3_language_f", "a3_language_f_beta", "a3_language_f_bootcamp", @@ -127,10 +132,13 @@ class CfgPatches { "a3_language_f_gamma", "a3_language_f_heli", "a3_language_f_kart", + "a3_language_f_mark", + "a3_language_f_mp_mark", "a3_languagemissions_f", "a3_languagemissions_f_beta", "a3_languagemissions_f_gamma", "a3_languagemissions_f_kart", + "a3_languagemissions_f_mp_mark", "a3_map_altis", "a3_map_altis_scenes", "a3_map_data", @@ -149,6 +157,8 @@ class CfgPatches { "a3_missions_f_gamma", "a3_missions_f_heli", "a3_missions_f_kart", + "a3_missions_f_mark", + "a3_missions_f_mp_mark", "a3_modules_f", "a3_modules_f_beta", "a3_modules_f_beta_firingdrills", @@ -184,8 +194,12 @@ class CfgPatches { "a3_modules_f_kart", "a3_modules_f_kart_timetrials", "a3_modules_f_livefeed", + "a3_modules_f_mark", + "a3_modules_f_mark_firingdrills", + "a3_modules_f_mark_objectives", "a3_modules_f_marta", "a3_modules_f_misc", + "a3_modules_f_mp_mark", "a3_modules_f_multiplayer", "a3_modules_f_objectmodifiers", "a3_modules_f_sites", @@ -199,6 +213,7 @@ class CfgPatches { "a3_music_f_epb", "a3_music_f_epc", "a3_music_f_heli", + "a3_music_f_mark", "a3_plants_f_bush", "a3_roads_f", "a3_rocks_f", @@ -244,6 +259,8 @@ class CfgPatches { "a3_static_f_gamma_aa", "a3_static_f_gamma_at", "a3_static_f_gamma_mortar_01", + "a3_static_f_mark_designator_01", + "a3_static_f_mark_designator_02", "a3_static_f_mortar_01", "a3_structures_f", "a3_structures_f_bootcamp_civ_camping", @@ -385,6 +402,13 @@ class CfgPatches { "a3_structures_f_kart_civ_sportsgrounds", "a3_structures_f_kart_mil_flags", "a3_structures_f_kart_signs_companies", + "a3_structures_f_mark_items_military", + "a3_structures_f_mark_items_sport", + "a3_structures_f_mark_mil_flags", + "a3_structures_f_mark_training", + "a3_structures_f_mark_vr_helpers", + "a3_structures_f_mark_vr_shapes", + "a3_structures_f_mark_vr_targets", "a3_structures_f_mil", "a3_structures_f_mil_bagbunker", "a3_structures_f_mil_bagfence", @@ -416,6 +440,7 @@ class CfgPatches { "a3_supplies_f_heli_cargonets", "a3_supplies_f_heli_fuel", "a3_supplies_f_heli_slingload", + "a3_supplies_f_mark", "a3_uav_f_characters_f_gamma", "a3_uav_f_weapons_f_gamma_ammoboxes", "a3_ui_f", @@ -423,6 +448,8 @@ class CfgPatches { "a3_ui_f_curator", "a3_ui_f_heli", "a3_ui_f_kart", + "a3_ui_f_mark", + "a3_ui_f_mp_mark", "a3_uifonts_f", "a3_weapons_f", "a3_weapons_f_aaf", @@ -474,6 +501,28 @@ class CfgPatches { "a3_weapons_f_longrangerifles_m320", "a3_weapons_f_machineguns_m200", "a3_weapons_f_machineguns_zafir", + "a3_weapons_f_mark", + "a3_weapons_f_mark_acc", + "a3_weapons_f_mark_ebr", + "a3_weapons_f_mark_longrangerifles_dmr_01", + "a3_weapons_f_mark_longrangerifles_dmr_02", + "a3_weapons_f_mark_longrangerifles_dmr_03", + "a3_weapons_f_mark_longrangerifles_dmr_04", + "a3_weapons_f_mark_longrangerifles_dmr_05", + "a3_weapons_f_mark_longrangerifles_dmr_06", + "a3_weapons_f_mark_longrangerifles_gm6", + "a3_weapons_f_mark_longrangerifles_gm6_camo", + "a3_weapons_f_mark_longrangerifles_m320", + "a3_weapons_f_mark_longrangerifles_m320_camo", + "a3_weapons_f_mark_machineguns_m200", + "a3_weapons_f_mark_machineguns_mmg_01", + "a3_weapons_f_mark_machineguns_mmg_02", + "a3_weapons_f_mark_machineguns_zafir", + "a3_weapons_f_mark_rifles_khaybar", + "a3_weapons_f_mark_rifles_mk20", + "a3_weapons_f_mark_rifles_mx", + "a3_weapons_f_mark_rifles_sdar", + "a3_weapons_f_mark_rifles_trg20", "a3_weapons_f_nato", "a3_weapons_f_pistols_acpc2", "a3_weapons_f_pistols_p07", From 1e0ece9fa272266e764229a2a2f5d9f37334cc37 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=A1s=20Badano?= Date: Mon, 30 Mar 2015 17:32:55 -0300 Subject: [PATCH 11/28] Revert "Revert "1.42 - cursor mode when bipod deployed"" --- addons/interact_menu/functions/fnc_keyDown.sqf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/addons/interact_menu/functions/fnc_keyDown.sqf b/addons/interact_menu/functions/fnc_keyDown.sqf index faa5b0f453..d4a7f8a96e 100644 --- a/addons/interact_menu/functions/fnc_keyDown.sqf +++ b/addons/interact_menu/functions/fnc_keyDown.sqf @@ -32,7 +32,7 @@ GVAR(openedMenuType) = _menuType; GVAR(useCursorMenu) = (vehicle ACE_player != ACE_player) || visibleMap || - (GVAR(AlwaysUseCursorSelfInteraction) && _menuType == 1); + {(_menuType == 1) && {(isWeaponDeployed ACE_player) || GVAR(AlwaysUseCursorSelfInteraction)}}; if (GVAR(useCursorMenu)) then { createDialog QGVAR(cursorMenu); // The dialog sets: From 55d7c0f0e6ddfcb02b14a2e8fca25617918ef997 Mon Sep 17 00:00:00 2001 From: commy2 Date: Sat, 4 Apr 2015 20:02:02 +0200 Subject: [PATCH 12/28] remove scripted recoil --- addons/recoil/CfgEventHandlers.hpp | 43 ------ addons/recoil/XEH_preInit.sqf | 8 - addons/recoil/config.cpp | 137 +----------------- .../recoil/functions/fnc_burstDispersion.sqf | 62 -------- addons/recoil/functions/fnc_camShake.sqf | 61 -------- addons/recoil/functions/script_component.hpp | 12 -- 6 files changed, 6 insertions(+), 317 deletions(-) delete mode 100644 addons/recoil/CfgEventHandlers.hpp delete mode 100644 addons/recoil/XEH_preInit.sqf delete mode 100644 addons/recoil/functions/fnc_burstDispersion.sqf delete mode 100644 addons/recoil/functions/fnc_camShake.sqf delete mode 100644 addons/recoil/functions/script_component.hpp diff --git a/addons/recoil/CfgEventHandlers.hpp b/addons/recoil/CfgEventHandlers.hpp deleted file mode 100644 index 1bf256e028..0000000000 --- a/addons/recoil/CfgEventHandlers.hpp +++ /dev/null @@ -1,43 +0,0 @@ -class Extended_PreInit_EventHandlers { - class ADDON { - init = QUOTE(call COMPILE_FILE(XEH_preInit) ); - }; -}; - -class Extended_FiredBis_EventHandlers { - class CAManBase { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == ACE_player) then {_this call FUNC(camShake); _this call FUNC(burstDispersion);};); - }; - }; - class Tank { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; - class Car { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; - class Helicopter { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; - class Plane { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; - class Ship_F { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; - class StaticWeapon { - class ADDON { - clientFiredBis = QUOTE(if (_this select 0 == vehicle ACE_player) then {_this call FUNC(camShake);};); - }; - }; -}; diff --git a/addons/recoil/XEH_preInit.sqf b/addons/recoil/XEH_preInit.sqf deleted file mode 100644 index 2df8a83ebd..0000000000 --- a/addons/recoil/XEH_preInit.sqf +++ /dev/null @@ -1,8 +0,0 @@ -#include "script_component.hpp" - -ADDON = false; - -PREP(burstDispersion); -PREP(camShake); - -ADDON = true; diff --git a/addons/recoil/config.cpp b/addons/recoil/config.cpp index db08a49143..2b003e6c65 100644 --- a/addons/recoil/config.cpp +++ b/addons/recoil/config.cpp @@ -6,14 +6,12 @@ class CfgPatches { weapons[] = {}; requiredVersion = REQUIRED_VERSION; requiredAddons[] = {"ace_common"}; - author[] = {"KoffeinFlummi", "TaoSensai", "commy2"}; + author[] = {"KoffeinFlummi","TaoSensai","commy2"}; authorUrl = "https://github.com/Taosenai/tmr"; VERSION_CONFIG; }; }; -#include "CfgEventHandlers.hpp" - // DOC: http://forums.bistudio.com/showthread.php?94464-explaining-the-cfgRecoils-array class CfgRecoils { #define KICKBACK 0.07 @@ -114,17 +112,18 @@ class CfgRecoils { recoil_single_titan[] = {0,0,0}; }; -class CfgCameraShake { +/*class CfgCameraShake { // Seems to be ignored by Arma defaultCaliberCoefWeaponFire = 0; -}; +};*/ // Completely disable BI's camshake on fire. -class CfgMovesBasic { +/*class CfgMovesBasic { class Default { camShakeFire = 0; }; }; + class CfgMovesMaleSdr : CfgMovesBasic { class States { class AmovPercMstpSlowWrflDnon; @@ -183,128 +182,4 @@ class CfgMovesMaleSdr : CfgMovesBasic { camShakeFire = 0; }; }; -}; - -// Ammo -class CfgAmmo { - class MissileCore; - class MissileBase: MissileCore { - GVAR(shakeMultiplier) = 2; - }; - - class BombCore; - class LaserBombCore: BombCore { - GVAR(shakeMultiplier) = 2; - }; - class Bo_Mk82: BombCore { - GVAR(shakeMultiplier) = 2; - }; - - class RocketCore; - class ArtilleryRocketCore: RocketCore { - GVAR(shakeMultiplier) = 1.4; - }; - class RocketBase: RocketCore { - GVAR(shakeMultiplier) = 1.4; - }; - - class BulletCore; - class BulletBase: BulletCore { - GVAR(shakeMultiplier) = 1; - }; - - class ShotgunCore; - class ShotgunBase: ShotgunCore { - GVAR(shakeMultiplier) = 1.1; - }; - - class ShellCore; - class ShellBase: ShellCore { - GVAR(shakeMultiplier) = 3; - }; - - class SubmunitionCore; - class SubmunitionBase: SubmunitionCore { - GVAR(shakeMultiplier) = 3; - }; - - class ShotDeployCore; - class ShotDeployBase: ShotDeployCore { - GVAR(shakeMultiplier) = 3; - }; -}; - -// Weapons -// 1. Set the recoil profiles for all fire modes. -// 2. Set the shake multiplier. This determines the camshake for the weapon. -// Ex: GVAR(shakeMultiplier) = 1; (disabled currently) - -class CfgWeapons { - class CannonCore; - class autocannon_Base_F: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class autocannon_35mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class cannon_120mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class mortar_155mm_AMOS: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class mortar_82mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - - // No camshake for gatlings - class gatling_20mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class gatling_25mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - class gatling_30mm: CannonCore { - GVAR(shakeMultiplier) = 0; - }; - - class MGunCore; - class MGun: MGunCore { - GVAR(shakeMultiplier) = 0; - }; - // No camshake for smoke launchers - class SmokeLauncher: MGun { - GVAR(shakeMultiplier) = 0; - }; - - // No camshake for coax machine guns - class LMG_RCWS; - class LMG_M200: LMG_RCWS { - GVAR(shakeMultiplier) = 0; - }; - class LMG_coax: LMG_RCWS { - GVAR(shakeMultiplier) = 0; - }; - class LMG_Minigun: LMG_RCWS { - GVAR(shakeMultiplier) = 0; - }; -}; - -// Vehicles -class CfgVehicles { - class LandVehicle; - class Tank: LandVehicle { - GVAR(enableCamshake) = 1; - }; - class Car: LandVehicle { - GVAR(enableCamshake) = 1; - }; - class StaticWeapon: LandVehicle { - GVAR(enableCamshake) = 1; - }; - - class Allvehicles; - class Air: Allvehicles { - GVAR(enableCamshake) = 1; - }; -}; +};*/ diff --git a/addons/recoil/functions/fnc_burstDispersion.sqf b/addons/recoil/functions/fnc_burstDispersion.sqf deleted file mode 100644 index c038d1fb4d..0000000000 --- a/addons/recoil/functions/fnc_burstDispersion.sqf +++ /dev/null @@ -1,62 +0,0 @@ -// TMR: Small Arms - Recoil initialization and functions -// (C) 2013 Ryan Schultz. See LICENSE. -// Edited for compatability in ACE by KoffeinFlummi -// Edited by commy2 - -#include "script_component.hpp" - -private ["_unit", "_weapon", "_projectile"]; - -_unit = _this select 0; -_weapon = _this select 1; -_projectile = _this select 6; - -if (_weapon in ["Throw", "Put"]) exitWith {}; - -private ["_lastFired", "_burst"]; - -_lastFired = _unit getVariable [QUOTE(GVAR(lastFired)), -1]; -_burst = _unit getVariable [QUOTE(GVAR(burst)), 0]; - -if (time - _lastFired < 0.45) then { - private "_startDisperse"; - _burst = _burst + 1; - _unit setVariable [QUOTE(GVAR(burst)), _burst, false]; - - _startDisperse = [1, 3] select (cameraView == "GUNNER"); - - if (_burst > _startDisperse) then { - // Reset burst size for calcs - _burst = _burst - _startDisperse; - - // Increase dispersion cap if player is not using sights - _sightsBurst = [30, 0] select (cameraView == "GUNNER"); - - // Increase initial dispersion and cap if player is moving - if (speed _unit > 0.5) then { - _sightsBurst = 25; - _burst = _burst + 15; - }; - - // Maximum possible dispersion (without _sightsBurst mod) - _maxBurst = 50; - - if (isWeaponRested _unit) then {_maxBurst = 25}; - if (isWeaponDeployed _unit) then {_maxBurst = 18}; - - // Cap the dispersion - _burst = (_burst min _maxBurst) + _sightsBurst; - - // Add random variance - _elevAngle = (_burst / 300) - random (_burst / 300) * 2; - _travAngle = (_burst / 260) - random (_burst / 260) * 2; - - [_projectile, _travAngle, _elevAngle] call EFUNC(common,changeProjectileDirection); - }; -} else { - - // Long enough delay, reset burst - _unit setVariable [QUOTE(GVAR(burst)), 0, false]; -}; - -_unit setVariable [QUOTE(GVAR(lastFired)), time, false]; diff --git a/addons/recoil/functions/fnc_camShake.sqf b/addons/recoil/functions/fnc_camShake.sqf deleted file mode 100644 index ad9a98c4d4..0000000000 --- a/addons/recoil/functions/fnc_camShake.sqf +++ /dev/null @@ -1,61 +0,0 @@ -// TMR: Small Arms - Recoil initialization and functions -// (C) 2013 Ryan Schultz. See LICENSE. -// Edited for compatability in ACE by KoffeinFlummi -// Edited by commy2 - -#include "script_component.hpp" - -#define BASE_POWER 0.40 -#define BASE_TIME 0.19 -#define BASE_FREQ 13 -#define RECOIL_COEF 40 - -private ["_unit", "_weapon", "_muzzle", "_ammo"]; - -_unit = _this select 0; -_weapon = _this select 1; -_muzzle = _this select 2; -_ammo = _this select 4; - -if (_weapon in [handgunWeapon _unit, "Throw", "Put"]) exitWith {}; - -private ["_powerMod", "_timeMod", "_freqMod", "_powerCoef"]; - -_powerMod = ([0, -0.1, -0.1, 0, -0.2] select (["STAND", "CROUCH", "PRONE", "UNDEFINED", ""] find stance _unit)) + ([0, -1, 0, -1] select (["INTERNAL", "EXTERNAL", "GUNNER", "GROUP"] find cameraView)); -_timeMod = 0; -_freqMod = 0; - -_powerCoef = 0; -if (_unit != vehicle _unit) then { - _powerCoef = getNumber (configFile >> "CfgWeapons" >> _weapon >> QUOTE(GVAR(shakeMultiplier))); - _powerCoef = _powerCoef * getNumber (configFile >> "CfgAmmo" >> _ammo >> QUOTE(GVAR(shakeMultiplier))); -} else { - private ["_type", "_config", "_recoil"]; - - _type = ["recoil", "recoilProne"] select (stance _unit == "PRONE"); - - _config = configFile >> "CfgWeapons" >> _weapon; - _recoil = if (_muzzle == _weapon) then { - getText (_config >> _type) - } else { - getText (_config >> _muzzle >> _type) - }; - - _recoil = getArray (configFile >> "CfgRecoils" >> _recoil); - if (count _recoil < 2) exitWith {}; - - _powerCoef = _recoil select 1; - _powerCoef = (call compile format ["%1", _powerCoef]) * RECOIL_COEF; -}; - -if (isWeaponRested _unit) then {_powerMod = _powerMod - 0.07}; -if (isWeaponDeployed _unit) then {_powerMod = _powerMod - 0.11}; - -private "_camshake"; -_camshake = [ - _powerCoef * (BASE_POWER + _powerMod) max 0, - BASE_TIME + _timeMod max 0, - BASE_FREQ + _freqMod max 0 -]; - -addCamShake _camshake; diff --git a/addons/recoil/functions/script_component.hpp b/addons/recoil/functions/script_component.hpp deleted file mode 100644 index d104528384..0000000000 --- a/addons/recoil/functions/script_component.hpp +++ /dev/null @@ -1,12 +0,0 @@ -#define COMPONENT recoil -#include "\z\ace\Addons\main\script_mod.hpp" - -#ifdef DEBUG_ENABLED_RECOIL - #define DEBUG_MODE_FULL -#endif - -#ifdef DEBUG_SETTINGS_RECOIL - #define DEBUG_SETTINGS DEBUG_SETTINGS_RECOIL -#endif - -#include "\z\ace\Addons\main\script_macros.hpp" From 2ad9193475bbb85475f46748934c661b28a68d4a Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Tue, 7 Apr 2015 14:38:35 -0500 Subject: [PATCH 13/28] Use DrawIcon for map tools --- addons/maptools/XEH_postInitClient.sqf | 2 +- .../functions/fnc_handleMouseButton.sqf | 112 +++++++++--------- .../functions/fnc_handleMouseMove.sqf | 2 +- .../functions/fnc_isInsideMapTool.sqf | 2 + .../functions/fnc_mapStateUpdater.sqf | 7 -- .../functions/fnc_updateMapToolMarkers.sqf | 60 +++------- 6 files changed, 76 insertions(+), 109 deletions(-) diff --git a/addons/maptools/XEH_postInitClient.sqf b/addons/maptools/XEH_postInitClient.sqf index e94cdaf266..26fb005e9f 100644 --- a/addons/maptools/XEH_postInitClient.sqf +++ b/addons/maptools/XEH_postInitClient.sqf @@ -28,7 +28,7 @@ GVAR(drawing_controls) = [36732, 36733, 36734, 36735, 36736, 36737]; ((finddisplay _d) displayctrl 51) ctrlAddEventHandler ["MouseMoving", {_this call FUNC(handleMouseMove);}]; ((finddisplay _d) displayctrl 51) ctrlAddEventHandler ["MouseButtonDown", {[1, _this] call FUNC(handleMouseButton);}]; ((finddisplay _d) displayctrl 51) ctrlAddEventHandler ["MouseButtonUp", {[0, _this] call FUNC(handleMouseButton)}]; - ((finddisplay _d) displayctrl 51) ctrlAddEventHandler ["Draw", {[] call FUNC(updateMapToolMarkers);}]; + ((finddisplay _d) displayctrl 51) ctrlAddEventHandler ["Draw", {_this call FUNC(updateMapToolMarkers);}]; (finddisplay _d) displayAddEventHandler ["KeyDown", {_this call FUNC(handleKeyDown);}]; }; diff --git a/addons/maptools/functions/fnc_handleMouseButton.sqf b/addons/maptools/functions/fnc_handleMouseButton.sqf index b0eb848e61..8db6b8b0f1 100644 --- a/addons/maptools/functions/fnc_handleMouseButton.sqf +++ b/addons/maptools/functions/fnc_handleMouseButton.sqf @@ -31,72 +31,72 @@ if (_button != 0) exitWith {}; // If releasing if (_dir != 1 && (GVAR(mapTool_isDragging) or GVAR(mapTool_isRotating))) exitWith { - GVAR(mapTool_isDragging) = false; - GVAR(mapTool_isRotating) = false; - _handled = true; - _handled + GVAR(mapTool_isDragging) = false; + GVAR(mapTool_isRotating) = false; + _handled = true; + _handled }; // If clicking if (_dir == 1) exitWith { - if !(call FUNC(canDraw)) exitWith {_handled = false;}; + if !(call FUNC(canDraw)) exitWith {_handled = false;}; - // Transform mouse screen position to coordinates - _pos = _control ctrlMapScreenToWorld _screenPos; - _pos set [count _pos, 0]; + // Transform mouse screen position to coordinates + _pos = _control ctrlMapScreenToWorld _screenPos; + _pos set [count _pos, 0]; - if (GVAR(drawing_isDrawing)) exitWith { - // Already drawing -> Add tempLineMarker to permanent list - if (GVAR(drawing_syncMarkers)) then { - deleteMarkerLocal (GVAR(drawing_tempLineMarker) select 0); - // [GVAR(drawing_tempLineMarker), "FUNC(addLineMarker)", 2] call EFUNC(common,execRemoteFnc); - ["drawing_addLineMarker", GVAR(drawing_tempLineMarker)] call EFUNC(common,globalEvent); - // Log who drew on the briefing screen - (text format ["[ACE] Server: Player %1 drew on the briefing screen", name player]) call EFUNC(common,serverLog); - } else { - GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); - GVAR(drawing_lineMarkers) pushBack (+GVAR(drawing_tempLineMarker)); + if (GVAR(drawing_isDrawing)) exitWith { + // Already drawing -> Add tempLineMarker to permanent list + if (GVAR(drawing_syncMarkers)) then { + deleteMarkerLocal (GVAR(drawing_tempLineMarker) select 0); + // [GVAR(drawing_tempLineMarker), "FUNC(addLineMarker)", 2] call EFUNC(common,execRemoteFnc); + ["drawing_addLineMarker", GVAR(drawing_tempLineMarker)] call EFUNC(common,globalEvent); + // Log who drew on the briefing screen + (text format ["[ACE] Server: Player %1 drew on the briefing screen", name player]) call EFUNC(common,serverLog); + } else { + GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); + GVAR(drawing_lineMarkers) pushBack (+GVAR(drawing_tempLineMarker)); + }; + GVAR(drawing_tempLineMarker) = []; + GVAR(drawing_isDrawing) = false; + _handled = true; }; - GVAR(drawing_tempLineMarker) = []; - GVAR(drawing_isDrawing) = false; - _handled = true; - }; - if (_altKey) exitWith { - // Start drawing - GVAR(drawing_isDrawing) = true; - // Create tempLineMarker - _gui = format ["%1%2%3%4", random (100), random (100), random (100), random (100)]; - GVAR(drawing_tempLineMarker) = [_gui, + _pos, + _pos, GVAR(drawing_drawColor)]; - _marker = createMarkerLocal [_gui, [0,0]]; - GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); - _handled = true; - }; - - GVAR(mapTool_isDragging) = false; - GVAR(mapTool_isRotating) = false; - - // If no map tool marker then exit - if (isNil QGVAR(mapTool_markerRotatingFixed)) exitWith {_handled = false;}; - - // Check if clicking the maptool - if (_pos call FUNC(isInsideMapTool)) exitWith { - // Store data for dragging - GVAR(mapTool_startPos) = + GVAR(mapTool_pos); - GVAR(mapTool_startDragPos) = + _pos; - if (_ctrlKey) then { - // Store data for rotating - GVAR(mapTool_startAngle) = + GVAR(mapTool_angle); - GVAR(mapTool_startDragAngle) = (180 + ((GVAR(mapTool_startDragPos) select 0) - (GVAR(mapTool_startPos) select 0)) atan2 ((GVAR(mapTool_startDragPos) select 1) - (GVAR(mapTool_startPos) select 1)) mod 360); - // Start rotating - GVAR(mapTool_isRotating) = true; - } else { - // Start dragging - GVAR(mapTool_isDragging) = true; + if (_altKey) exitWith { + // Start drawing + GVAR(drawing_isDrawing) = true; + // Create tempLineMarker + _gui = format ["%1%2%3%4", random (100), random (100), random (100), random (100)]; + GVAR(drawing_tempLineMarker) = [_gui, + _pos, + _pos, GVAR(drawing_drawColor)]; + _marker = createMarkerLocal [_gui, [0,0]]; + GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); + _handled = true; + }; + + GVAR(mapTool_isDragging) = false; + GVAR(mapTool_isRotating) = false; + + // If no map tool marker then exit + if (GVAR(mapTool_Shown) == 0) exitWith {_handled = false;}; + + // Check if clicking the maptool + if (_pos call FUNC(isInsideMapTool)) exitWith { + // Store data for dragging + GVAR(mapTool_startPos) = + GVAR(mapTool_pos); + GVAR(mapTool_startDragPos) = + _pos; + if (_ctrlKey) then { + // Store data for rotating + GVAR(mapTool_startAngle) = + GVAR(mapTool_angle); + GVAR(mapTool_startDragAngle) = (180 + ((GVAR(mapTool_startDragPos) select 0) - (GVAR(mapTool_startPos) select 0)) atan2 ((GVAR(mapTool_startDragPos) select 1) - (GVAR(mapTool_startPos) select 1)) mod 360); + // Start rotating + GVAR(mapTool_isRotating) = true; + } else { + // Start dragging + GVAR(mapTool_isDragging) = true; + }; + _handled = true; }; - _handled = true; - }; }; _handled diff --git a/addons/maptools/functions/fnc_handleMouseMove.sqf b/addons/maptools/functions/fnc_handleMouseMove.sqf index 6df07cfead..99c36f1581 100644 --- a/addons/maptools/functions/fnc_handleMouseMove.sqf +++ b/addons/maptools/functions/fnc_handleMouseMove.sqf @@ -37,7 +37,7 @@ if (GVAR(drawing_isDrawing)) exitWith { }; // Handle Map tools -if (isNil QGVAR(mapTool_markerRotatingFixed)) exitWith {false}; +if (GVAR(mapTool_Shown) == 0) exitWith {false}; // Translation if (GVAR(mapTool_isDragging)) exitWith { diff --git a/addons/maptools/functions/fnc_isInsideMapTool.sqf b/addons/maptools/functions/fnc_isInsideMapTool.sqf index 4e2339f9f1..b4d4fc8814 100644 --- a/addons/maptools/functions/fnc_isInsideMapTool.sqf +++ b/addons/maptools/functions/fnc_isInsideMapTool.sqf @@ -18,6 +18,8 @@ #define DIST_TOP_TO_CENTER_PERC 0.65 #define DIST_LEFT_TO_CENTER_PERC 0.30 + + if (GVAR(mapTool_Shown) == 0) exitWith {false}; _textureWidth = [TEXTURE_WIDTH_IN_M, TEXTURE_WIDTH_IN_M / 2] select (GVAR(mapTool_Shown) - 1); diff --git a/addons/maptools/functions/fnc_mapStateUpdater.sqf b/addons/maptools/functions/fnc_mapStateUpdater.sqf index efc5efb956..ffe331df71 100644 --- a/addons/maptools/functions/fnc_mapStateUpdater.sqf +++ b/addons/maptools/functions/fnc_mapStateUpdater.sqf @@ -18,13 +18,6 @@ if (GVAR(mapVisableLastFrame) && (!visibleMap)) then { GVAR(mapVisableLastFrame) = false; // Hide GPS [false] call FUNC(openMapGps); - // Hide Map tools - deleteMarkerLocal MARKERNAME_MAPTOOL_FIXED; - deleteMarkerLocal MARKERNAME_MAPTOOL_ROTATINGNORMAL; - deleteMarkerLocal MARKERNAME_MAPTOOL_ROTATINGSMALL; - GVAR(mapTool_markerRotatingFixed) = nil; - GVAR(mapTool_markerRotatingNormal) = nil; - GVAR(mapTool_markerRotatingSmall) = nil; // Cancel drawing call FUNC(cancelDrawing); }; diff --git a/addons/maptools/functions/fnc_updateMapToolMarkers.sqf b/addons/maptools/functions/fnc_updateMapToolMarkers.sqf index bb096bd064..13967413f6 100644 --- a/addons/maptools/functions/fnc_updateMapToolMarkers.sqf +++ b/addons/maptools/functions/fnc_updateMapToolMarkers.sqf @@ -1,10 +1,9 @@ /* * Author: esteldunedain - * * Update the map tool markers, position, size, rotation and visibility. * - * Argument: - * None + * Arguments: + * 0: The Map * * Return value: * Nothing @@ -16,58 +15,31 @@ #define CENTER_OFFSET_Y_PERC 0.1606 #define CONSTANT_SCALE 0.2 -// If markers exist and they should'nt, delete them -if (!("ACE_MapTools" in items ACE_player) || {GVAR(mapTool_Shown) == 0}) then { - // If markers exist, delete them - if (!isNil QGVAR(mapTool_markerRotatingFixed)) then { - deleteMarkerLocal MARKERNAME_MAPTOOL_FIXED; - GVAR(mapTool_markerRotatingFixed) = nil; - }; -}; -if (!("ACE_MapTools" in items ACE_player) || {GVAR(mapTool_Shown) != 1}) then { - if (!isNil QGVAR(mapTool_markerRotatingNormal)) then { - deleteMarkerLocal MARKERNAME_MAPTOOL_ROTATINGNORMAL; - GVAR(mapTool_markerRotatingNormal) = nil; - }; -}; -if (!("ACE_MapTools" in items ACE_player) || {GVAR(mapTool_Shown) != 2}) then { - if (!isNil QGVAR(mapTool_markerRotatingSmall)) then { - deleteMarkerLocal MARKERNAME_MAPTOOL_ROTATINGSMALL; - GVAR(mapTool_markerRotatingSmall) = nil; - }; -}; +PARAMS_1(_theMap); if (!("ACE_MapTools" in items ACE_player)|| {GVAR(mapTool_Shown) == 0}) exitWith {}; -// If markers don't exist and should, create them -if (isNil QGVAR(mapTool_markerRotatingFixed)) then { - GVAR(mapTool_markerRotatingFixed) = createMarkerLocal [MARKERNAME_MAPTOOL_FIXED, GVAR(mapTool_pos)]; - MARKERNAME_MAPTOOL_FIXED setMarkerType MARKERNAME_MAPTOOL_FIXED; +_rotatingTexture = ""; +_textureWidth = 0; +if (GVAR(mapTool_Shown) == 1) then { + _rotatingTexture = QUOTE(PATHTOF(data\mapToolRotatingNormal.paa)); + _textureWidth = TEXTURE_WIDTH_IN_M; +} else { + _rotatingTexture = QUOTE(PATHTOF(data\mapToolRotatingSmall.paa)); + _textureWidth = TEXTURE_WIDTH_IN_M / 2; }; -if ((isNil QGVAR(mapTool_markerRotatingNormal)) && {GVAR(mapTool_Shown) == 1}) then { - GVAR(mapTool_markerRotatingNormal) = createMarkerLocal [MARKERNAME_MAPTOOL_ROTATINGNORMAL, GVAR(mapTool_pos)]; - MARKERNAME_MAPTOOL_ROTATINGNORMAL setMarkerType MARKERNAME_MAPTOOL_ROTATINGNORMAL; -}; -if ((isNil QGVAR(mapTool_markerRotatingSmall)) && {GVAR(mapTool_Shown) == 2}) then { - GVAR(mapTool_markerRotatingSmall) = createMarkerLocal [MARKERNAME_MAPTOOL_ROTATINGSMALL, GVAR(mapTool_pos)]; - MARKERNAME_MAPTOOL_ROTATINGSMALL setMarkerType MARKERNAME_MAPTOOL_ROTATINGSMALL; -}; - -_rotatingMarker = [MARKERNAME_MAPTOOL_ROTATINGNORMAL, MARKERNAME_MAPTOOL_ROTATINGSMALL] select (GVAR(mapTool_Shown) - 1); -_textureWidth = [TEXTURE_WIDTH_IN_M, TEXTURE_WIDTH_IN_M / 2] select (GVAR(mapTool_Shown) - 1); // Update scale of both parts -_scale = _textureWidth * CONSTANT_SCALE * (call FUNC(calculateMapScale)); -MARKERNAME_MAPTOOL_FIXED setMarkerSizeLocal [_scale,_scale]; -_rotatingMarker setMarkerSizeLocal [_scale,_scale]; +_scale = _textureWidth * CONSTANT_SCALE * (call FUNC(calculateMapScale)); // Position of the fixed part _xPos = GVAR(mapTool_pos) select 0; _yPos = (GVAR(mapTool_pos) select 1) + _textureWidth * CENTER_OFFSET_Y_PERC; -MARKERNAME_MAPTOOL_FIXED setMarkerPosLocal [_xPos,_yPos]; + +_theMap drawIcon [QUOTE(PATHTOF(data\mapToolFixed.paa)), [1,1,1,1], [_xPos,_yPos], (32 * _scale), (32 * _scale), 0, "", 0]; // Position and rotation of the rotating part _xPos = (GVAR(mapTool_pos) select 0) + sin(GVAR(mapTool_angle)) * _textureWidth * CENTER_OFFSET_Y_PERC; _yPos = (GVAR(mapTool_pos) select 1) + cos(GVAR(mapTool_angle)) * _textureWidth * CENTER_OFFSET_Y_PERC; -_rotatingMarker setMarkerPosLocal [_xPos,_yPos]; -_rotatingMarker setMarkerDirLocal GVAR(mapTool_angle); + +_theMap drawIcon [_rotatingTexture, [1,1,1,1], [_xPos,_yPos], (32 * _scale), (32 * _scale), GVAR(mapTool_angle), "", 0]; From 6b0fb84f65d291c81f25bf4fd8f763de6bc19a8e Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Tue, 7 Apr 2015 15:01:44 -0500 Subject: [PATCH 14/28] Cleanup / Headers --- addons/maptools/CfgMarkers.hpp | 26 ------- addons/maptools/config.cpp | 1 - .../maptools/functions/fnc_addLineMarker.sqf | 28 +++---- .../functions/fnc_calculateMapScale.sqf | 8 +- addons/maptools/functions/fnc_canDraw.sqf | 14 +++- .../maptools/functions/fnc_canUseMapGPS.sqf | 14 +++- .../maptools/functions/fnc_canUseMapTools.sqf | 14 +++- .../maptools/functions/fnc_cancelDrawing.sqf | 10 +-- .../functions/fnc_copyMapReceiveMarkers.sqf | 20 ++--- .../maptools/functions/fnc_copyMapStart.sqf | 7 +- .../maptools/functions/fnc_handleKeyDown.sqf | 73 +++++++++---------- .../functions/fnc_handleMouseMove.sqf | 38 +++++----- .../functions/fnc_handleMouseZChanged.sqf | 16 ++-- .../functions/fnc_isInsideMapTool.sqf | 9 +-- .../functions/fnc_mapStateUpdater.sqf | 38 +++++----- addons/maptools/functions/fnc_openMapGps.sqf | 29 ++++---- .../functions/fnc_openMapGpsUpdate.sqf | 6 +- .../functions/fnc_removeLineMarker.sqf | 27 ++++--- .../functions/fnc_updateLineMarker.sqf | 30 ++++---- .../functions/fnc_updateMapToolMarkers.sqf | 3 +- addons/maptools/script_component.hpp | 5 -- 21 files changed, 203 insertions(+), 213 deletions(-) delete mode 100644 addons/maptools/CfgMarkers.hpp diff --git a/addons/maptools/CfgMarkers.hpp b/addons/maptools/CfgMarkers.hpp deleted file mode 100644 index 8a2b86fc13..0000000000 --- a/addons/maptools/CfgMarkers.hpp +++ /dev/null @@ -1,26 +0,0 @@ -// MARKERS -class CfgMarkers { - class ACE_MapToolFixed { - name = "MapToolFixed"; - icon = PATHTOF(data\mapToolFixed.paa); - scope = 0; - color[] = {1,1,1,1}; - size = 32; - }; - - class ACE_MapToolRotatingNormal { - name = "MapToolRotating"; - icon = PATHTOF(data\mapToolRotatingNormal.paa); - scope = 0; - color[] = {1,1,1,1}; - size = 32; - }; - - class ACE_MapToolRotatingSmall { - name = "MapToolRotating"; - icon = PATHTOF(data\mapToolRotatingSmall.paa); - scope = 0; - color[] = {1,1,1,1}; - size = 32; - }; -}; diff --git a/addons/maptools/config.cpp b/addons/maptools/config.cpp index d5b1f26396..6ccf874e69 100644 --- a/addons/maptools/config.cpp +++ b/addons/maptools/config.cpp @@ -32,7 +32,6 @@ class RscEdit; #include "MapGpsUI.hpp" #include "CfgEventHandlers.hpp" -#include "CfgMarkers.hpp" #include "CfgVehicles.hpp" #include "CfgWeapons.hpp" diff --git a/addons/maptools/functions/fnc_addLineMarker.sqf b/addons/maptools/functions/fnc_addLineMarker.sqf index a55792e98a..83e983d0e3 100644 --- a/addons/maptools/functions/fnc_addLineMarker.sqf +++ b/addons/maptools/functions/fnc_addLineMarker.sqf @@ -1,18 +1,18 @@ /* * Author: esteldunedain - * * Add the line marker * - * Argument: - * 0: Marker Name (string) - * 1: Marker start pos (array) - * 2: Marker end pos (array) - * 3: Color index (Number) + * Arguments: + * 0: Marker Name + * 1: Marker start pos + * 2: Marker end pos + * 3: Color index * * Return value: - * Return + * None + * + * Public: No */ - #include "script_component.hpp" _name = _this select 0; @@ -27,16 +27,16 @@ _name setMarkerColorLocal _color; _name setMarkerPosLocal (_startPos vectorAdd (_difPos vectorMultiply 0.5)); _mag = vectorMagnitude _difPos; if (_mag > 0) then { - _name setMarkerSizeLocal [5, _mag / 2]; - _name setMarkerDirLocal (180 + (_difPos select 0) atan2 (_difPos select 1) mod 360); + _name setMarkerSizeLocal [5, _mag / 2]; + _name setMarkerDirLocal (180 + (_difPos select 0) atan2 (_difPos select 1) mod 360); } else { - _name setMarkerSizeLocal [5, 5]; - _name setMarkerDirLocal 0; + _name setMarkerSizeLocal [5, 5]; + _name setMarkerDirLocal 0; }; GVAR(drawing_lineMarkers) pushBack (+_this); if (isServer && GVAR(drawing_syncMarkers)) then { - GVAR(drawing_serverLineMarkers) pushBack (+_this); - publicVariable QGVAR(drawing_serverLineMarkers); + GVAR(drawing_serverLineMarkers) pushBack (+_this); + publicVariable QGVAR(drawing_serverLineMarkers); }; diff --git a/addons/maptools/functions/fnc_calculateMapScale.sqf b/addons/maptools/functions/fnc_calculateMapScale.sqf index d8ed1cfcb9..700e089a88 100644 --- a/addons/maptools/functions/fnc_calculateMapScale.sqf +++ b/addons/maptools/functions/fnc_calculateMapScale.sqf @@ -1,15 +1,15 @@ /* * Author: esteldunedain - * * Returns the equivalent of 100m in screen coordinates * - * Argument: + * Arguments: * None * * Return value: - * Return + * No + * + * Public: No */ - #include "script_component.hpp" _pos = ((finddisplay 12) displayctrl 51) ctrlMapScreenToWorld [0.5, 0.5]; diff --git a/addons/maptools/functions/fnc_canDraw.sqf b/addons/maptools/functions/fnc_canDraw.sqf index a5088f668b..da55043d85 100644 --- a/addons/maptools/functions/fnc_canDraw.sqf +++ b/addons/maptools/functions/fnc_canDraw.sqf @@ -1,5 +1,15 @@ -// by esteldunedain - +/* + * Author: esteldunedain + * canDraw + * + * Arguments: + * None + * + * Return value: + * + * + * Public: No + */ #include "script_component.hpp" (missionNameSpace getVariable [QGVAR(drawing_syncMarkers), true] && {GVAR(EveryoneCanDrawOnBriefing)}) || diff --git a/addons/maptools/functions/fnc_canUseMapGPS.sqf b/addons/maptools/functions/fnc_canUseMapGPS.sqf index f3d0b10c56..381136a1cc 100644 --- a/addons/maptools/functions/fnc_canUseMapGPS.sqf +++ b/addons/maptools/functions/fnc_canUseMapGPS.sqf @@ -1,5 +1,15 @@ -// by esteldunedain - +/* + * Author: esteldunedain + * canUseMapGPS + * + * Arguments: + * None + * + * Return value: + * + * + * Public: No + */ #include "script_component.hpp" visibleMap && diff --git a/addons/maptools/functions/fnc_canUseMapTools.sqf b/addons/maptools/functions/fnc_canUseMapTools.sqf index fe0bf012da..30d86160ab 100644 --- a/addons/maptools/functions/fnc_canUseMapTools.sqf +++ b/addons/maptools/functions/fnc_canUseMapTools.sqf @@ -1,5 +1,15 @@ -// by esteldunedain - +/* + * Author: esteldunedain + * canUseMapTools + * + * Arguments: + * None + * + * Return value: + * + * + * Public: No + */ #include "script_component.hpp" visibleMap && diff --git a/addons/maptools/functions/fnc_cancelDrawing.sqf b/addons/maptools/functions/fnc_cancelDrawing.sqf index 09396e61fe..bc80602cfc 100644 --- a/addons/maptools/functions/fnc_cancelDrawing.sqf +++ b/addons/maptools/functions/fnc_cancelDrawing.sqf @@ -1,19 +1,19 @@ /* * Author: esteldunedain - * * Cancel the drawing of the current line marker * - * Argument: + * Arguments: * None * * Return value: - * Nothing + * None + * + * Public: No */ - #include "script_component.hpp" GVAR(drawing_isDrawing) = false; if (count GVAR(drawing_tempLineMarker) > 0) then { - deleteMarkerLocal (GVAR(drawing_tempLineMarker) select 0); + deleteMarkerLocal (GVAR(drawing_tempLineMarker) select 0); }; GVAR(drawing_tempLineMarker) = []; diff --git a/addons/maptools/functions/fnc_copyMapReceiveMarkers.sqf b/addons/maptools/functions/fnc_copyMapReceiveMarkers.sqf index d2675a2b06..e3de77316a 100644 --- a/addons/maptools/functions/fnc_copyMapReceiveMarkers.sqf +++ b/addons/maptools/functions/fnc_copyMapReceiveMarkers.sqf @@ -1,23 +1,23 @@ /* * Author: esteldunedain - * * Copy recieved markers to map * - * Argument: - * 0: Array of markers to copy (Array) + * Arguments: + * 0: Array of markers to copy * * Return value: - * Return + * None + * + * Public: No */ - #include "script_component.hpp" PARAMS_1(_lineMarkers); { - _marker = _x; - //Add marker if we don't already have it - if (({(_x select 0) == (_marker select 0)} count GVAR(drawing_lineMarkers)) == 0) then { - _marker call FUNC(addLineMarker); - }; + _marker = _x; + //Add marker if we don't already have it + if (({(_x select 0) == (_marker select 0)} count GVAR(drawing_lineMarkers)) == 0) then { + _marker call FUNC(addLineMarker); + }; } forEach _lineMarkers; diff --git a/addons/maptools/functions/fnc_copyMapStart.sqf b/addons/maptools/functions/fnc_copyMapStart.sqf index 11464d7573..a39c74d225 100644 --- a/addons/maptools/functions/fnc_copyMapStart.sqf +++ b/addons/maptools/functions/fnc_copyMapStart.sqf @@ -1,11 +1,10 @@ /* * Author: esteldunedain - * * Send request to remote player * - * Argument: - * 0: Player (Unit) - * 0: Target player (Unit) + * Arguments: + * 0: Player + * 0: Target player * * Code Chain: * START: copyMapStart: triggers event drawing_requestMarkers on remote diff --git a/addons/maptools/functions/fnc_handleKeyDown.sqf b/addons/maptools/functions/fnc_handleKeyDown.sqf index 4553ed62ab..d2b3a060b8 100644 --- a/addons/maptools/functions/fnc_handleKeyDown.sqf +++ b/addons/maptools/functions/fnc_handleKeyDown.sqf @@ -1,9 +1,8 @@ /* * Author: esteldunedain - * * Handle key down on map. * - * Argument: + * Arguments: * 0: Display (display) * 1: Key code (number) * 2: Shift Key (boolean) @@ -30,45 +29,45 @@ _handled = false; // If pressed Esc while drawing if (_code == DIK_ESCAPE) exitWith { - if (GVAR(drawing_isDrawing)) then { - call FUNC(cancelDrawing); - _handled = true; - }; + if (GVAR(drawing_isDrawing)) then { + call FUNC(cancelDrawing); + _handled = true; + }; }; if (_code == DIK_DELETE) exitWith { - if (GVAR(drawing_isDrawing)) then { - call FUNC(cancelDrawing); - _handled = true; - } else { - - // Check if a line marker needs to be deleted - { - _relPos = GVAR(mousePosition) vectorDiff (_x select 1); - _diffVector = (_x select 2) vectorDiff (_x select 1); - _magDiffVector = vectorMagnitude _diffVector; - if (_magDiffVector == 0) then { - _diffVector = [10,0,0]; - _magDiffVector = vectorMagnitude _diffVector; - }; - _diffVector = _diffVector vectorMultiply (1/_magDiffVector); - - // Projection of the relative position over the longitudinal axis - _lambdaLong = _diffVector vectorDotProduct _relPos; - // Projection of the relative position over the trasversal axis - _lambdaTrasAbs = vectorMagnitude (_relPos vectorDiff (_diffVector vectorMultiply _lambdaLong)); - if (_lambdaLong >= 0 && _lambdaLong <= _magDiffVector && _lambdaTrasAbs <= 5) exitWith { - // Delete the line marker - if (GVAR(drawing_syncMarkers)) then { - ["drawing_removeLineMarker", [_x select 0]] call EFUNC(common,globalEvent); - } else { - deleteMarkerLocal (_x select 0); - GVAR(drawing_lineMarkers) = GVAR(drawing_lineMarkers) - [_x]; - }; + if (GVAR(drawing_isDrawing)) then { + call FUNC(cancelDrawing); _handled = true; - }; - } forEach GVAR(drawing_lineMarkers); - }; + } else { + + // Check if a line marker needs to be deleted + { + _relPos = GVAR(mousePosition) vectorDiff (_x select 1); + _diffVector = (_x select 2) vectorDiff (_x select 1); + _magDiffVector = vectorMagnitude _diffVector; + if (_magDiffVector == 0) then { + _diffVector = [10,0,0]; + _magDiffVector = vectorMagnitude _diffVector; + }; + _diffVector = _diffVector vectorMultiply (1/_magDiffVector); + + // Projection of the relative position over the longitudinal axis + _lambdaLong = _diffVector vectorDotProduct _relPos; + // Projection of the relative position over the trasversal axis + _lambdaTrasAbs = vectorMagnitude (_relPos vectorDiff (_diffVector vectorMultiply _lambdaLong)); + if (_lambdaLong >= 0 && _lambdaLong <= _magDiffVector && _lambdaTrasAbs <= 5) exitWith { + // Delete the line marker + if (GVAR(drawing_syncMarkers)) then { + ["drawing_removeLineMarker", [_x select 0]] call EFUNC(common,globalEvent); + } else { + deleteMarkerLocal (_x select 0); + GVAR(drawing_lineMarkers) = GVAR(drawing_lineMarkers) - [_x]; + }; + _handled = true; + }; + } forEach GVAR(drawing_lineMarkers); + }; }; _handled diff --git a/addons/maptools/functions/fnc_handleMouseMove.sqf b/addons/maptools/functions/fnc_handleMouseMove.sqf index 99c36f1581..4111c8fad4 100644 --- a/addons/maptools/functions/fnc_handleMouseMove.sqf +++ b/addons/maptools/functions/fnc_handleMouseMove.sqf @@ -22,18 +22,18 @@ GVAR(mousePosition) set [2, 0]; //convert 2d pos to 3d // If cannot draw then exit if !(call FUNC(canDraw)) exitWith { - // If was drawing, cancel - if (GVAR(drawing_isDrawing)) then { - call FUNC(cancelDrawing); - }; - false + // If was drawing, cancel + if (GVAR(drawing_isDrawing)) then { + call FUNC(cancelDrawing); + }; + false }; // Handle drawing if (GVAR(drawing_isDrawing)) exitWith { - GVAR(drawing_tempLineMarker) set [2, GVAR(mousePosition)]; - GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); - false + GVAR(drawing_tempLineMarker) set [2, GVAR(mousePosition)]; + GVAR(drawing_tempLineMarker) call FUNC(updateLineMarker); + false }; // Handle Map tools @@ -41,23 +41,23 @@ if (GVAR(mapTool_Shown) == 0) exitWith {false}; // Translation if (GVAR(mapTool_isDragging)) exitWith { - GVAR(mapTool_pos) set [0, (GVAR(mapTool_startPos) select 0) + (GVAR(mousePosition) select 0) - (GVAR(mapTool_startDragPos) select 0)]; - GVAR(mapTool_pos) set [1, (GVAR(mapTool_startPos) select 1) + (GVAR(mousePosition) select 1) - (GVAR(mapTool_startDragPos) select 1)]; + GVAR(mapTool_pos) set [0, (GVAR(mapTool_startPos) select 0) + (GVAR(mousePosition) select 0) - (GVAR(mapTool_startDragPos) select 0)]; + GVAR(mapTool_pos) set [1, (GVAR(mapTool_startPos) select 1) + (GVAR(mousePosition) select 1) - (GVAR(mapTool_startDragPos) select 1)]; - // Update the size and rotation of the maptool - [] call FUNC(updateMapToolMarkers); - true + // Update the size and rotation of the maptool + [] call FUNC(updateMapToolMarkers); + true }; // Rotation if (GVAR(mapTool_isRotating)) exitWith { - // Get new angle - _angle = (180 + ((GVAR(mousePosition) select 0) - (GVAR(mapTool_startPos) select 0)) atan2 ((GVAR(mousePosition) select 1) - (GVAR(mapTool_startPos) select 1)) mod 360); - GVAR(mapTool_angle) = GVAR(mapTool_startAngle) + _angle - GVAR(mapTool_startDragAngle); + // Get new angle + _angle = (180 + ((GVAR(mousePosition) select 0) - (GVAR(mapTool_startPos) select 0)) atan2 ((GVAR(mousePosition) select 1) - (GVAR(mapTool_startPos) select 1)) mod 360); + GVAR(mapTool_angle) = GVAR(mapTool_startAngle) + _angle - GVAR(mapTool_startDragAngle); - // Update the size and rotation of the maptool - [] call FUNC(updateMapToolMarkers); - true + // Update the size and rotation of the maptool + [] call FUNC(updateMapToolMarkers); + true }; false diff --git a/addons/maptools/functions/fnc_handleMouseZChanged.sqf b/addons/maptools/functions/fnc_handleMouseZChanged.sqf index 483efc56b7..35626238e5 100644 --- a/addons/maptools/functions/fnc_handleMouseZChanged.sqf +++ b/addons/maptools/functions/fnc_handleMouseZChanged.sqf @@ -29,16 +29,16 @@ _handled = true; // ACE_Map_drawColors is never defined /* if (count GVAR(drawing_tempLineMarker) > 0) then { - ACE_Map_drawColor = if (_dir > 0) then {ACE_Map_drawColor + 1} else {ACE_Map_drawColor - 1}; - if (ACE_Map_drawColor >= count ACE_Map_drawColors) then { +ACE_Map_drawColor = if (_dir > 0) then {ACE_Map_drawColor + 1} else {ACE_Map_drawColor - 1}; +if (ACE_Map_drawColor >= count ACE_Map_drawColors) then { ACE_Map_drawColor = ACE_Map_drawColor - count ACE_Map_drawColors; - }; - if (ACE_Map_drawColor < 0) then { +}; +if (ACE_Map_drawColor < 0) then { ACE_Map_drawColor = ACE_Map_drawColor + count ACE_Map_drawColors; - }; - GVAR(drawing_tempLineMarker) set [3, ACE_Map_drawColor]; - GVAR(drawing_tempLineMarker) call ACE_Map_fnc_updateLineMarker; +}; +GVAR(drawing_tempLineMarker) set [3, ACE_Map_drawColor]; +GVAR(drawing_tempLineMarker) call ACE_Map_fnc_updateLineMarker; - _handled = true; +_handled = true; }; */ _handled diff --git a/addons/maptools/functions/fnc_isInsideMapTool.sqf b/addons/maptools/functions/fnc_isInsideMapTool.sqf index b4d4fc8814..4dd66e2b9a 100644 --- a/addons/maptools/functions/fnc_isInsideMapTool.sqf +++ b/addons/maptools/functions/fnc_isInsideMapTool.sqf @@ -1,16 +1,14 @@ /* * Author: esteldunedain - * * Return true if the position is inside the map marker (to allow dragging). * - * Argument: - * 0: x Position (in meters) - * 1: y Position (in meters) + * Arguments: + * 0: x Position (in meters) + * 1: y Position (in meters) * * Return value: * Boolean */ - #include "script_component.hpp" #define TEXTURE_WIDTH_IN_M 6205 @@ -19,7 +17,6 @@ #define DIST_LEFT_TO_CENTER_PERC 0.30 - if (GVAR(mapTool_Shown) == 0) exitWith {false}; _textureWidth = [TEXTURE_WIDTH_IN_M, TEXTURE_WIDTH_IN_M / 2] select (GVAR(mapTool_Shown) - 1); diff --git a/addons/maptools/functions/fnc_mapStateUpdater.sqf b/addons/maptools/functions/fnc_mapStateUpdater.sqf index ffe331df71..2b4e634567 100644 --- a/addons/maptools/functions/fnc_mapStateUpdater.sqf +++ b/addons/maptools/functions/fnc_mapStateUpdater.sqf @@ -2,32 +2,32 @@ #include "script_component.hpp" if (visibleMap) then { - // Show/Hide draw buttons - if ("ACE_MapTools" in items ACE_player) then { - { ((finddisplay 12) displayctrl _x) ctrlShow true; } forEach GVAR(drawing_controls); - } else { - { ((finddisplay 12) displayctrl _x) ctrlShow false; } forEach GVAR(drawing_controls); - if (GVAR(drawing_isDrawing)) then { - call FUNC(cancelDrawing); + // Show/Hide draw buttons + if ("ACE_MapTools" in items ACE_player) then { + { ((finddisplay 12) displayctrl _x) ctrlShow true; } forEach GVAR(drawing_controls); + } else { + { ((finddisplay 12) displayctrl _x) ctrlShow false; } forEach GVAR(drawing_controls); + if (GVAR(drawing_isDrawing)) then { + call FUNC(cancelDrawing); + }; }; - }; }; //When Map is Closed: if (GVAR(mapVisableLastFrame) && (!visibleMap)) then { - GVAR(mapVisableLastFrame) = false; - // Hide GPS - [false] call FUNC(openMapGps); - // Cancel drawing - call FUNC(cancelDrawing); + GVAR(mapVisableLastFrame) = false; + // Hide GPS + [false] call FUNC(openMapGps); + // Cancel drawing + call FUNC(cancelDrawing); }; //When Map is Opened: if ((!GVAR(mapVisableLastFrame)) && (visibleMap)) then { - //todo: "mapOpened" Event???? - GVAR(mapVisableLastFrame) = true; - // Show and update map tools if required - [] call FUNC(updateMapToolMarkers); - // Show GPS if required - [GVAR(mapGpsShow)] call FUNC(openMapGps); + //todo: "mapOpened" Event???? + GVAR(mapVisableLastFrame) = true; + // Show and update map tools if required + [] call FUNC(updateMapToolMarkers); + // Show GPS if required + [GVAR(mapGpsShow)] call FUNC(openMapGps); }; diff --git a/addons/maptools/functions/fnc_openMapGps.sqf b/addons/maptools/functions/fnc_openMapGps.sqf index 03b3f5525c..c4e2436b3b 100644 --- a/addons/maptools/functions/fnc_openMapGps.sqf +++ b/addons/maptools/functions/fnc_openMapGps.sqf @@ -1,25 +1,24 @@ /* -* Author: esteldunedain -* -* Opens or closes the gps on the map screen, showing coordinates -* -* Argument: -* 0: Open GPS? (Boolean) -* -* Return value: -* Nothing -*/ - + * Author: esteldunedain + * Opens or closes the gps on the map screen, showing coordinates + * + * Arguments: + * 0: Open GPS? + * + * Return value: + * Nothing + * + * Public: No + */ #include "script_component.hpp" _shouldOpenGps = _this select 0; _isOpen = !(isNull (uiNamespace getVariable [QGVAR(ui_mapGpsDisplay), displayNull])); if (_shouldOpenGps && {"ItemGPS" in assignedItems ACE_player} && {!_isOpen}) then { - ("RscACE_MapGps" call BIS_fnc_rscLayer) cutRsc ["RscACE_MapGps","PLAIN"]; + ("RscACE_MapGps" call BIS_fnc_rscLayer) cutRsc ["RscACE_MapGps","PLAIN"]; - [FUNC(openMapGpsUpdate), 0.5, []] call CBA_fnc_addPerFrameHandler; //update bearing/altitude every 0.5 sec (ticktime) + [FUNC(openMapGpsUpdate), 0.5, []] call CBA_fnc_addPerFrameHandler; //update bearing/altitude every 0.5 sec (ticktime) } else { - ("RscACE_MapGps" call BIS_fnc_rscLayer) cutText ["","PLAIN"]; + ("RscACE_MapGps" call BIS_fnc_rscLayer) cutText ["","PLAIN"]; }; - diff --git a/addons/maptools/functions/fnc_openMapGpsUpdate.sqf b/addons/maptools/functions/fnc_openMapGpsUpdate.sqf index a26a02dd34..ddc177f182 100644 --- a/addons/maptools/functions/fnc_openMapGpsUpdate.sqf +++ b/addons/maptools/functions/fnc_openMapGpsUpdate.sqf @@ -11,8 +11,8 @@ disableSerialization; _mapGpsDisplay = uiNamespace getVariable [QGVAR(ui_mapGpsDisplay), displayNull]; _ctrl = _mapGpsDisplay displayCtrl 913590; -_ctrl ctrlSetText str(round(getDir player)); //set Heading +_ctrl ctrlSetText str(round(getDir ACE_player)); //set Heading _ctrl = _mapGpsDisplay displayCtrl 913591; -_ctrl ctrlSetText str(round((getPosASL player) select 2)); //set Altitude +_ctrl ctrlSetText str(round((getPosASL ACE_player) select 2)); //set Altitude _ctrl = _mapGpsDisplay displayCtrl 913592; -_ctrl ctrlSetText mapGridPosition player; //set grid cords +_ctrl ctrlSetText mapGridPosition ACE_player; //set grid cords diff --git a/addons/maptools/functions/fnc_removeLineMarker.sqf b/addons/maptools/functions/fnc_removeLineMarker.sqf index 15af48217e..45c39611db 100644 --- a/addons/maptools/functions/fnc_removeLineMarker.sqf +++ b/addons/maptools/functions/fnc_removeLineMarker.sqf @@ -1,10 +1,9 @@ /* * Author: esteldunedain - * * Remove the line marker * - * Argument: - * 0: Marker Name (string) + * Arguments: + * 0: Marker Name * * Return value: * Return @@ -12,20 +11,20 @@ #include "script_component.hpp" - _name = _this select 0; +_name = _this select 0; - deleteMarkerLocal _name; +deleteMarkerLocal _name; { - if ((_x select 0) == _name) exitWith { - GVAR(drawing_lineMarkers) = GVAR(drawing_lineMarkers) - [_x]; - }; + if ((_x select 0) == _name) exitWith { + GVAR(drawing_lineMarkers) = GVAR(drawing_lineMarkers) - [_x]; + }; } forEach GVAR(drawing_lineMarkers); if (isServer && GVAR(drawing_syncMarkers)) then { - { - if ((_x select 0) == _name) exitWith { - GVAR(drawing_serverLineMarkers) = GVAR(drawing_serverLineMarkers) - [_x]; - publicVariable QGVAR(drawing_serverLineMarkers); - }; - } forEach GVAR(drawing_serverLineMarkers); + { + if ((_x select 0) == _name) exitWith { + GVAR(drawing_serverLineMarkers) = GVAR(drawing_serverLineMarkers) - [_x]; + publicVariable QGVAR(drawing_serverLineMarkers); + }; + } forEach GVAR(drawing_serverLineMarkers); }; diff --git a/addons/maptools/functions/fnc_updateLineMarker.sqf b/addons/maptools/functions/fnc_updateLineMarker.sqf index 9635dc02fa..cf80c1ac26 100644 --- a/addons/maptools/functions/fnc_updateLineMarker.sqf +++ b/addons/maptools/functions/fnc_updateLineMarker.sqf @@ -1,24 +1,22 @@ /* * Author: esteldunedain - * * Updates the line marker position and scale * - * Argument: - * 0: Marker Name (string) - * 1: Marker start pos (array) - * 2: Marker end pos (array) - * 3: Color index (Number) + * Arguments: + * 0: Marker Name + * 1: Marker start pos + * 2: Marker end pos + * 3: Color index * * Return value: - * Return + * None */ - #include "script_component.hpp" - _name = _this select 0; - _startPos = _this select 1; - _difPos = (_this select 2) vectorDiff _startPos ; - _color = _this select 3; +_name = _this select 0; +_startPos = _this select 1; +_difPos = (_this select 2) vectorDiff _startPos ; +_color = _this select 3; _name setMarkerShapeLocal "RECTANGLE"; _name setMarkerAlphaLocal 1; @@ -26,9 +24,9 @@ _name setMarkerColorLocal GVAR(drawing_drawColor); _name setMarkerPosLocal (_startPos vectorAdd (_difPos vectorMultiply 0.5)); _mag = vectorMagnitude _difPos; if (_mag > 0) then { - _name setMarkerSizeLocal [5, _mag / 2]; - _name setMarkerDirLocal (180 + (_difPos select 0) atan2 (_difPos select 1) mod 360); + _name setMarkerSizeLocal [5, _mag / 2]; + _name setMarkerDirLocal (180 + (_difPos select 0) atan2 (_difPos select 1) mod 360); } else { - _name setMarkerSizeLocal [5, 5]; - _name setMarkerDirLocal 0; + _name setMarkerSizeLocal [5, 5]; + _name setMarkerDirLocal 0; }; diff --git a/addons/maptools/functions/fnc_updateMapToolMarkers.sqf b/addons/maptools/functions/fnc_updateMapToolMarkers.sqf index 13967413f6..3a7b919b8b 100644 --- a/addons/maptools/functions/fnc_updateMapToolMarkers.sqf +++ b/addons/maptools/functions/fnc_updateMapToolMarkers.sqf @@ -7,8 +7,9 @@ * * Return value: * Nothing + * + * Public: No */ - #include "script_component.hpp" #define TEXTURE_WIDTH_IN_M 6205 diff --git a/addons/maptools/script_component.hpp b/addons/maptools/script_component.hpp index df2a8d3f62..30a9f83d0d 100644 --- a/addons/maptools/script_component.hpp +++ b/addons/maptools/script_component.hpp @@ -10,8 +10,3 @@ #endif #include "\z\ace\Addons\main\script_macros.hpp" - - -#define MARKERNAME_MAPTOOL_FIXED "ACE_MapToolFixed" -#define MARKERNAME_MAPTOOL_ROTATINGNORMAL "ACE_MapToolRotatingNormal" -#define MARKERNAME_MAPTOOL_ROTATINGSMALL "ACE_MapToolRotatingSmall" From d060b13bbeaa104f4cf976487640abe9e02df187 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Tue, 7 Apr 2015 15:47:12 -0500 Subject: [PATCH 15/28] #86 - Stretch gps info box to support 8 digits --- addons/maptools/MapGpsUI.hpp | 8 ++++---- addons/maptools/UI/mapGps.paa | Bin 34174 -> 37350 bytes 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/addons/maptools/MapGpsUI.hpp b/addons/maptools/MapGpsUI.hpp index ff8ec8b96e..170f0d1620 100644 --- a/addons/maptools/MapGpsUI.hpp +++ b/addons/maptools/MapGpsUI.hpp @@ -31,7 +31,7 @@ class RscTitles { }; class heading: RscText{ idc = 913590; - x = X_gps + W_gps * 0.25; + x = X_gps + W_gps * 0.225; y = Y_gps + H_gps * 0.12; w = W_gps * 0.2; h = H_gps * 0.16; @@ -46,7 +46,7 @@ class RscTitles { }; class altitude: RscText{ idc = 913591; - x = X_gps + W_gps * 0.55; + x = X_gps + W_gps * 0.575; y = Y_gps + H_gps * 0.12; w = W_gps * 0.2; h = H_gps * 0.16; @@ -61,9 +61,9 @@ class RscTitles { }; class coordinates: RscText{ idc = 913592; - x = X_gps + W_gps * 0.2; + x = X_gps + W_gps * 0.15; y = Y_gps + H_gps * 0.33; - w = W_gps * 0.6; + w = W_gps * 0.7; h = H_gps * 0.35; style = ST_CENTER; text = "012.3 115.1"; diff --git a/addons/maptools/UI/mapGps.paa b/addons/maptools/UI/mapGps.paa index f4ed1dfc5492fe773000917998ead184345e966f..defcdbc63bd398ec89b79bb7c9aed3cb3adc3f1b 100644 GIT binary patch literal 37350 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 literal 34174 zcmbrmeRNY*)<1quZqg)eLQ`I(m6zNUYLa`C7ElVbNp7g3w2EMd@Y*(o&NyS4QAS2( zG|4TcA{3Mv6=zhSwV>1+O;860(=ouRmTkcR}tkfq%Kjcg(%( z_S|C(Ke@-hxc&BpUig0-{EWICp#v)ria(0bKs!PwIuN?&ad_eX+rM^%pO}Y6qjwOQ zi;x{5`j`vp^r-gfskKk52^kDvjd#qz!QXwJH?V}dG+jrj&n-c(BKqsK8XeJ9q4hqw zZfo8Tf57^)SD%>P?IUFWyTAE9fc5uu49#itA=E!`*JTmwYLFi%k9@itKe(+y+ko-w zZ(9DtfZAyTyIzRORNX|_4%a6_xjFpSa|lu=MzP6 zrRV-Se^=qdgxY~GGeq_0r}ewE&%s^SUUs;Vm*vp5KRvk%|9ucYwY^rtUFOaw4e;dF zCr>&(XxWc&w_Be4B^yGIKam`BEs-qf*pwXeNkXJHZZdVvx|(=G#E%zz|Ahtw66~;C zgSQ9T@7v84C*v5mwJ-Y~p4hPQoiB{ZDeK#kg(b-(eq?>pTzpi-e^|evYkcw1+eQ3H z?PbP;)~-t|m_3Mp_rNDz#uZ2B?Z#_<8()Bze{j2n$G`dQf-`tt7ryVeZM!soJd0P~ zC%XUmL0K1WZb7@uFPx>CS0~oIcosLc#5pU6R=syEjzw)_bIoqe3m?I&bI)j|?#84k zx#oqBWQ~{QQDf8mv)Zzf-Pm6Mn`>y6vAPSd^m~)zK2q=2EceIP5xlH%(OK$ZahIlP z!+*Zec2O%Eyk|5T5jTGFJrhF98sb}senr!rES&y|#&h4p0XOJbIOSz4-?_%{ctz79 zR#dHQnCnnb)1O%$uWVci2eh;y!N%l*hB!~~iiTUAE>&VdY^PIA1m|$O%=vLBeax^= zbDAgPdJpaz)r6B*8(viv`1mpV{BM^?qFUY1f>FVaqTPx1slQY&uf+7AG=VBCD1d50(z7Sx!m}zphm?6P{W_WXv#h4 zVliFqLbOG~js*I!+>Lg6LhvLkK^tAF#sUjH%8g2@1IQCl(Iyu~8{O!wUCRY$LNC}u zsLbL>7%s9w^t4k#9(c*k!;S25!cuWm?oxSp)q~si%ICqvU$)RQ{FSeW`_rr_9$3g62iR#NCz+V4VN-5a3>@`CoTMt zud_GzSL8eMoe5mZxDjt0!+==@eF7U)oi>`=;5lN{_U0VS6<vfhBo@oMa_EynH3! z2}^*&rQxW%oibKAMXHz2IAqmT2anJrNqbzY+GFbW$zas^Bnz&qb1=y!Fml2M^Lw9kj$L^Q%{RWy3l zMN>cakNRpzT#Tuc_05YKmi(x`e~sZW>|eTLrh>!uqn>ELYzv`z7Q=Sj^zsGC7S~e) z#ckc4G1!^Pw7GZqgq1I$FPi>3-wyf{VItdPyvG?t18&&47NMzKj85vqB0EE1g~QU1iC*}ZguTP5f>#%ZmH z-lZ>0Bd8~Ks49TL4q~kg(I0MSSV@fyJtdDm(D%v$)uyKm?sFI)7pS$2B+E@OI3TQ3}diX6Jvyo z9?r6%!dM^cGT?LX)9qA{jQG!3W0*y)IRJS!o5i1c-X8jP#% zRqTo49%H)KAr)gG(iw3E)v?MrIJ{`YKvlXlAsiE`TxKxh&Zj&qZ&4x=D^0<}oyu@k zAP+|}!&`F>F%n}_)q%40T~)lL^H7x5#&tJyH%7xFv{pj#mmQ?+!f-1HZEJWKJVBVG z?eVb|{uWSgHfik<*uVsw4U=qDLgmqQvEt8sjfcVT$)+94rRDe1eavt$Z(sH9brXv>X2d&PTezVVMbv2f}Xy#L)3=B*|;YWvTqG{O0h?r(w8XWz8Bwdv>XNPTpBEB%DD6B^#oUpmnfdZTyP7cEzh0{q^ z!7;E)`h1GB2MYcARPsa>rwUgjSxz6Zh1n2n!RB&M_u6|*pWSJ5(VFNwb;%av%pKt8 zk!Fp(<^iF%*ZT4k@+X}1F(LLEO0Tifs7*4fE55FL;L_2wSEj=C&1)Aev&BP{aplK5 zX3orMlDcGB!;+6}E*AmRY;t@iR_!jz=>EcrC7B+M@n3;Kkw# z**-Q{WYZmEU1RXZ?A1ZoHwinGX(NPnmlWXHBBRvD(vGB>2|L75OpG{!RGN{-;2u-& zh(j6I8*}h8hQ%Zs#MjEn43fIaiV&EH!!wZ(Hn4;ZYI_U?PI8+-c+h0a?|*$I=Oj9_ zWDsJI;*crT`YB9eau#AYlXQx+2$2Dy+XKa+*CSb*3+=LwFhO*rNkf7RSVAV7d5BF; z7|B|LllO$Q!%3E?xFlh@2?Szp5=WzsggfgDAu+|qRev>u`(CaeW)v(&3^!N0bfKF& zlMXWbsiesAEUOSUNDJk}l_hC5RNVI_8!CV5Cr6_Cyq=4($%$}b5k>wj+XHIYaDLd4 zD6K;MtYY3Cb_7)(b%8aQf4E`hqC!@j7!e6eCNRl9mY7p9VvjrgH!CD%Q`F~m<#AhM zOOz3j7|XJvAxyw`SClUaKlbqauY09-3p&;>v@ApDOsf$1GBtwrAsp z^3Qn5Os+PVsBc%y9Jk~2&pJ5aUn6Nr*$(m0*wWCjc(E;D1s$yT$Ek&Yv8F?0EWYuD z7+oM$<4lDRt4{iqtTj|vTT}R#(>o4Wla{&`?X{);sMU41YJN+P$!8CQ0Cn0Rx?9~I zWLpW4RhxsnmsY^jhXDW|qb+V!4AIghqk6FD_v*_P)MKi0qxakrq8D=L*opz#A){lS z0HVDv1PEXSZFZ|J(39hc=G(b5DgiY(gqLGt#o;icBLbPwJork&6z~D7MB~% zHx#n6v36Pj0elTkN?C*THj5O({zo5N?Fili0-PS*8fHa{7|yVyOn7rEORR@_1#7@U z-EQeIy%n|vigo{7H_xKqvgJu~6-@~oD{!{d*3kXlx(#UI`Kfo6D*Z2fpvj|X^m|ux z{!QiAy2wvmB$ytW^B*s=alI$&>)@}*sY^b?h%j+KJ}V~AR>mJLbuS7#xkV#GaCB>9 z;#R9-Z>`HSfZ@mIYPN3ERF!Eo8bCYYZLJ+l2yg8$QhqP8N=VgF*O5xu63ul+D!{~@ zR9y!XP!yX~fSC^c9{|%*Oh6yVWZ)T9eqd-_uNT2}^nq{IF$((TF(bvpbvU%{)pd*; zA0I`n>AwDk-gPI|0H)pCLPJHt0|`moh+lo|_!>qreX~wuNO%!gE9h-63qM`<fHA391U%d&1Dwl)wcDvxUmtRvx$e9 zfMyi6)CcaPk-FmKkZPvSmMqk+T#j%~RH#5U=O-TbvYw*021l^SZ%Y)_1^;~7K(XTJ zg3~^SXN<~8>m+ld#tX}+JL?8a53XL#N@l=95a)@17+e?EmVzjsyidH!hFV0ymh8CK z-b5BIw94EAPI&8r7F|`~nEKhj?00|uhOvqK{Q!;r0Gq3AAi7K!abGg7TnztMnY)vb zIMu~sC6lox^;C)WPtmMWoqPt+5C4o!$goL$YQ(UoQsO+4xvQmrZ3812@Dkq+Ba{lR z6xgKCG)!P#jS5{}1TGgJTd^M5f+*j=&bO=|iW|q*6<#uq^I1a!->eJ$9$^{;kdn>% zhAo!FbgxZD8cXOuz8#Ec_LWg~QgmsBGZ$pmbiB9jQ8rLdX=<9zA;d_d@ebdTwX8UX zGR_2`VQzZWv^uv>MPV|PuI^H@Ashjzc>A(_4*5@gHYu#S*S<=(&`!+vuPK9L)z@^9 z9s7+_C5}c9E9Tm}77{Nef&PKm>ZA|pezF7U7E_ufDSJB^X&NrmQ;60Q|C(*R!Gcy>08Np-PMc`fuJqbnWB46AmM*sP2U|PlHN8aP z+(rXeE%LDltMn+tY|@`h+FYq1B_hPe+i~Iy{p#p~w>+^hY$>Ihp!QZUgWE@l(26Ov)ACxoLW|ODuEm9NSF>YoVT`chp zTI^lhu#}09#y($TdoEU2j61!AiI2gH)_QMcTw_5vnzGrl`EUi{VzKX8B8t%{O9mxn zh!ww7q9PkOhF=r5_JYxwr^0PNzjObBsWNwvMh_A5J-@hy{)n?(WKxA|bT6d>h6K&hfYYh`Y$h2OfYp}`vWYg#*w)?)8TZ&SCO(!{DF8Jbgo}#9 zCe5u_jKvtPxo>2c4g3eEsym;e^|IeyD*4rSKL6rdlRkedcZ~c!i>J!s1X=|;u9P1YhVw6vL#n!xaUJ7(!@p3%Qq z!^9u-NFvDZt2s*-FI#JKjkOR9gd2$QV1UVy4B+H+I&D%9%q1~Motj66x0=-bWq6o{ zLnx5^p<_F{Wbz!GqGZ-DZ@;#kNL}Rfk7{ceVveq9t$@qib@y$zG14He_@k&)5wn=? zHL1OJd?I-$RVDk&KwZ~1+azOvU}M?L9rP^8Yzc0!D-UePO91^c3DX{Xz?|FI5yE}5 z?g17K;;T8nrAr!Y@oCh&I=xDT;X{LgU3e{EX)!_?s{*fbeL7c}Y zz6^Kfa_DgVMcO2Z7Pq6B;ms<2nKg7*U59ZP+2hG1xrQ9FnPMezIa zwiHXaFo04~%w!>BZc7UUWJhC$jb>r7yJx}A7eu|Ydw=8SZ%u-|DBRXRTO{5>xIccN ztCr1A6d^DE`r^f}Z4zfu276Pqfpo?G76W(sW_G|9V8H~-Xg&DQ026qP&-xn9v9MvM z&)39yx`}U=Yb21h$ma@}_yc&R9(o0^7i5%(B{aPmu`b#opFPKlMF)JoO4sP%j`e!# z0GoVzW`Ug>b9^0TkB_0p5VO!TlvD8Rd6pkk1cep5E?gKfsnJU~936?ylDU?0*=(Pp zh+TVblDe)t@u#1$$o`-5(ek4X$voQoL^QG6{M*WssPL(L4QZ||%y zsW-;2b@hR#GMmODFN7Ffpp_M0x3(;?ONJnJL&eyXyYc1lA`{TItY^g;)|S(Z%iOr* zRnyJLn~OK$x}M?+#h)Q;yvwJJL6nF@AlDPfd6UVzXPV+ymw;nhdF)Q%a8YId8_pnk z{d(Yi=DD$yclJ@e8?Ld(1S+GK{H6l*F@EYP*tgQ%8?^;~TZG%na)8JTx~qBF=VRhw zN8C|_or2TtOgTJGL}n+P4Dcb2=5TN+d9>Grl7v{exC(ow_%{Y=C z&dgT0sg~)WeQ&%QAf+<*Fqp4m{_6{t%YznOGcHcrYg}-r?WQ9~JC0QGey44UX)M(r zergCVbc$&|Zw=~er_1J-S<*GX#b-}AS^>hB2Aw`p|;|(T3otZz=%%yG*cwa>?Y07nKJ`*U_VbV>&B1q^W835dQr6 zYmCPn1JFWJhjMw8B1GZDFJwkikQd(FqISyW+R@T7Ro%Ns_Zw*xAYj`+?Iza}F4??k zH#vHwGQiD9nln`<&BiZY>x~tw`}6UMlU1+SWb+X?d3q8Y7~B*37InKNer$V}5@V90 zl4b&Y5&BPY9;J^l6|8gvj%@|sp_jSZ-N%lexJmBvT^HPo-4<{P`SiyJoW#6NR|U5? zy!a7Z&v&#-nV=|xZfQlFJD)_?mZT%%c5`odpR+$8JgoD z=GD5RfGx+h@o*&_B;CRZNU0+x4eH0?v={~7CJ2BDeqObbaG6Zfq&{qp5}WIWE*#E? zZ0H=gdSy`PwZ+HpB6ou)zt{e_7n$-XZ{5icz`cOCnt6Tad-qu``z>J`oW8;@hL zr~<*0M8VnhXCU`YJjd#}3$wu`OXizEt^aX)zcWexv-A4iUlGQt+MatIUII+~-gIz? zH5J4h7kY}-w{B@=SP)@fv{=(ti{p$K&w&<}i9j*%f7ZS&cQXP>Ga++YDW=eBKOPnj>E$xF z38SMXO4S^Q6l*rF?-Y93Ko=fSUhBy@_V|6p8mf-X^!&VYm&5^jGZhT@)7dUI;U~H= zxziS_^ZVvVP!ut%j4P*Fj9vsN_Vma5$Elh>d=_?1%R z>u7dPVOMu;ik367u2ZYQ#z?5eACDdu()lXHgZ4*c5_ z1x*YQt2&Ws?5+J7NGZf`_6V_J6>9r=l^KfISr59`U93fi!N#X3`~fJ-boUKIz4l=o z{ej)=Q20})WNd(&nMwxltoyk1JMy>DxF2xRuOu_lV`xmPYyUKrK+_1dwV{8Wg~U1| zlKnhS6idGIJJ`Jn@sNe%Vpq%USc`XBaw-&w34xGx6niez_R)TV4{t(zhf&HqZD zFX9p9pv|(kZ1X zrQZZeW&T6jP628JT0(a38N zU+o!!ldVnmg>4D@5liTJO88$HnBi1V7ZGgNyA=u z%QuV@F@4YV1JP;o53ZVU@V;t7pnqgmnL4)CUG$<#$$TU3zXK`*aSmTQ+{-X=Gu8>I z_gG?nQ%C`fjHM0%cG2T-@_gp!8vyWXs*<|OUCrejI#S$I!8ea6Nvr$Z?L~7xnde0w z#eC-C4XSg~J7C|6*n`=VRe|F!p=Fc`SegGRaGdlkbWo59U-pJ))3m#or@X z6X)zj2mr6{=hbeJ%u@&#*zdE`uT)%hkUb|wx-2#u7lUe|o%`E@kp$x;i zyjZA?44E`F_GqNiP1pUr_N|h62FN3vFPyIocmoGYWReAu3}@01f-Dx9yMvLrspS&a zj=uWZ@;$d7u-tt)7cl1Fs+BtQ1<7?jPpx}@#n%_V{<;c8P`jYEmf^YK&LP$##xf3m zaBHjzAa0vN&akp&#i zD(1UeH1wTb=$G^KXzT+)TS{9?|boJ%M^)Y;4bc7^L~9tN5>|(@p<5Q?t>He zm<0tgpZhYgut{BG7ete0fM-VpaOrm3Ih^YI`7R(D+l%HNsDV!e&F%Uze*MAyrvPoaRrjr0#ey0LJs{cgSd10tM-*t^(z%S9`{oBB1{EHAje%mM_kO;i zsel{6>r})EPkQ@Opa(tEA?+dnwi(IHN<4&fXUo>2Yv$4%diK8w;G$JFkGK55A6!!n zLWSDt<4-*PB#5F6EO%3otb$085T1qyX21NIdci(jr^TJEtTE6qYS*q~Sb=S?Wbc*FNZ_%Bb zM$F;*EnxAvpr>j3BS;q%a=7RCc2I;pF-M%hnM3OhHWdvEOr<3LEbUu}*3&yI>-47rUOx|&8sVufYVJGL|JL|V> z*s#GS=jDX`3M4k=gi~Trtrdk6fawN$QyEg6%Z}J^OsRyk{dwJ+iMh4zLbc?l$G|Cm z$3ZdFO!b&fZQs7#E}Ki>81oiBpq4gF`uvSx6LGd&U-23T?) zgp0`VFbfV&N(o`pn0_-(kw|%Nr%az`7#yai>gP45<$}A%WT5&LQGx#CgpFtZ5&4LFyDTg0I~!lB$6!f*_z zK6;T1TP6SK0bU%2dbKwj8HTej2F2@`4)6MT{Tm5c3={txoWH8g+n=`j>I~h?olF8+z&;cjuVJ41nGB&&ig4)kF16~x&j0;3@mWW|+ zJRXUM=6HG-da)o8$TSQK7v6cQaLg0IPqzm@Bjn`uK%;NG@8Bx%JAH(Fe%7II_8La= zm&@jTJo){1-<^DUev%aoRI2exj`Yx6sy~h_mN`U-lZ;S0_L7WJSSd&Ug!U2c~-e#+o-=IV&hP2 zhsH<=HaDtk@}m?~mw=K}2aS>cpDCZF6G}JUR!F~d`2!&dS{FB)47avH)dupSLdXS; zr%s$Yb>kF}ZdCq+kZ}F=175RsiY%^#!fy_@PEokuf5#-bWENr|f9r5I!@9SKUN!6P zkAXL9PG!S(*?$Dw(aUxyDR*{2*0-}*^1C=F>02RFW&%Jef+CxC<^Ox)*X2g*jQdiM zmE%oynwsTrKnAthjqYv4fL}f6m3l`2PXpfotsx-!p*bGt|4fq*8$h`J$Q-Dn)_bJE z8N5hHs5;OM{0R9fL%IsL7h1XT;rcxl5|?-KRk6;X|P_Ybo~Oqy5_67%TY6w$Aj7?ryD2Wq}Ob!hkn3p=z(Z>VBGki z@T^K|rNy&kv<6sHA&iW(J*s=_pcnx<5OON$fX|sgm|hxK9w=fIgQmvt7$^u0!U`J) zYx35qR5ocr2sbRNOrp+?5LKpuR#|^Ptxe$0-5NcH&dSp~wiYM&{5g&EIWfh$(K&`! z$RiaZ`P0jc*(@^Qd-P z99se_RaM^pHdU2u9%qPxS8TJ#XM}M6X@;!5x31rw(D(ASOP4IB{|?14fKYQJadf{Q zKNWu^27&H^|7}8kn&oPSfEBGk$Qsnt0XBZp66jYwzWs^dXH%epPZ|J*H7jQR@tYJf z8>(s?;IT~>X%K|UUsXh?$3Z+xrH^Jy0{mhIFr`ti$Fp2dTNK!bO}X*Xil*mxoMsc%&3gYLCa9WOtZLg! zQ-K?oy=Zq$f*P0#irJtV3>kZT-Ta`oH7A=zi=f2-t+kR|9Ulw?f=;zKw_({L)??8d zZGk(2crntk+*E9Y(rQgr9x&DDUk9G2qksoO-<=-Ex+a^b_Gw$UX?5Pi8?7PjZ(2fE zcZ_HFrw)4o?wi7mWB{Xgs-($y2edYrByMiD#S8eWP*}Grg-~>J70iH}66?R3TNb>K zV!$ea$(9(k*c+nXCguypHFUl-I92fvrcLI4Z;(_#8gR0HwCdxsGDhO5?N2_r{i(n1 zBv5~?tJBk{MKM3VX%WfQqUcew8H&1QLWYag8#ebDsS1ZYB-#_)VUx~#yu_=wx@kSQ z?5*_OviVrB%V&e?y*@C%rSTuoEt1X0cW-HE0P!sUQa@XPrV4UnJ9O*Mig4 zcz+9y=ElT}OIU6av2FVJs@2`wbsU;cEE83zFIz^nF&l@{+)(_uJ!oJTO5os2^cDJ zL1zPDT)G(mfQ`JKAwbyewI;M%Eo8eWvj~;H3Nx*D;sB*s&;9&FjBGQP%|3 z_?J4}K|R2!Ht#ZrvTDan@c7mi=ok6{^iAU@Kue8vW6JKDl548|fZEoxJh#Mm+6K+| zvKl>BAxE+Wec^Q1eB+eqC5+f?G=iqsB|hleF~{XD72npB&9n!+Si4fKvn3}n9S-@f zPD{cI*VL5;*`@Zl4!V7FJZ+3J89`63&yRt?!SY`4Akfz1XiB2!B;=J~U;JCwfXW17 z?h$%(Y`D#O_Bw}^nJh#qUEa}D_ko!+L5D9ELr$fNz8u{fDV0cw=xeS!^e6uWk4lxn zj}PSB`Tc9&n_eyrLh5~?kt}Bkmr}qPVAae5mq)dDNqIv3 zF~r3k1rC`9R1DS`7;Yp!#x-dfZv{a#O&YfYbQ)YyTYsys%7rb5?qm5cK7Q^7yDJpZ zdVO>OuR#J*ke)updqe(Mmxk-tFlsFNG!bzkp78 zEH=a@iIOsD`Z<8h%5bHtZS-73Oe!xL{Z8t2lMZ*!ba=i+$Pxc`4uDChv0uktrBc`b zMP5L6ISwS`S0TxQG^!gS{hVdLwkJzErXTt(jW%&$hI>n0G(BI+gW$J!IxuK+`B(*z zz>7G*73ZwngOD?nQdVCH=^$2mhRcC;l+h`A>)y6`;+^yn4 zs~R;Q8wzFv9iEaaq&%lbzf_(rp&3B%1~s{D7k&sn@=$p~6?A#jOJ#WQvD<~6LA}rE z$$NySjV_9F0fAl(OXalnj2n1Kg)+W6J9kr>889jGG0?a1&2BVEPY$Bfba^oEMdTr11NuUl;Ow zCvHTjR3Sg?gyL$mL*g4r3HU)^0IvJthjpw1lo^v+)t~J%Y1+kWDZscy{0Zv2BGlkH zTIkEL@pCvs;IGG$2EH%q69_B4gnLJlY0#r`Tnv;>q@-E#JQL1BRi}LqTxx(FNkS(< zHIVwA<)=iWDTps8GP_ymO$%8d?QkeE0!?B(1XMJc67_e+*bo+zOyVh%Z(X|5HE)+0 zsN1USutWJOEdu-d@7KxX8DM2{s%$#Tl1*7?YzFaFhpc6dvxZG$+KYxoLxsugeRH=l ztI#^v(=*&}4eBT4%4b*po@EnxZ{cSzu)LaxQ8uJY!}jisDQO3vpG}5Y51R(A9uzj9 zu0egI0EMw2#|_Lo1Ux`l7dDmlKNr$|D}#od0&<|l186TUXj_K6`@&mcfr4br<|_2# z7q&*KWz?gmUY`~C)K7g)vXEuHZL;-$)>N=XfDXfd;ggV(fb-P{H26Feh^v!vo@Ybr zLeN#&zw>c7Umz0R5j4oN0|lk7vp7tyUUek%iIT%2Z9?z$1m9|l<@)XIK*Qzeq!4k0 znuV75B8EN%2$}B?XbFu0d58uvBRZ6q(w)F= z1kSHhddVKgsw1Wd&}==baG!(F5#W1rrDQnba1TTr@`Q{-oTLDG(WS=9b|`STR5%-b zKs1fn_+&Ia%z8?o`x7tu>v21eIYn^-i&TN6W#WJ{aCA40@+`Sg6!}^4u`|Hg^@(hJ zBIFzY>KeZW>`EILAJF5zVaRB;(wiRFgc;JfMe|Jbt5+?7Mcd2K7P(DPEPno|oeYz0#M z`S}h`9bv23_)eV4bf&62>PXlDEB1EwhO3jPS74gDBd)?DWN^4DG%=|-B+orXumJS{NrH~N0=iTs-GXhXK2=TVun5NC zs-)HY=<@;tXG`xcA!)#?c!q1zJ?z!WK&p6R&ELqs;i($BFkVVi!CU`c9@G*?U_5jM z;gCEf=et?1Bm$Ije)5lx9%5a2_~}^cQ81V{g}uONW|%2p>LV#oUmQDc%aP{$!fu#M z(1ugPaNaPEz=o>8s(4j|^s$PHsd9iTjO?4`syXxJXW)V>dK~W3lx`283ZXCR^jN0t zcDS(1)mRal+FMmEqL@$&SR@rO+zAss0`SNzL%qN*E`JSDM*(J7R3qTG%ICQ9r%BII zb9J33>N=rrU?GFniVB;u?3L*Tt@cFS1f?tZ$s3KILsn)%-_vN7WQGpE&hd>bl51&c z_tjbeRYpx~-M;C~Lqq47_&z-N!!Osv@!~^6*Lv9GjcFJJnvl+>;CJ=t5$xrOku|{pTJwD$fO@NuQX>L0A2~XlH@V_SrIR*ZE#m(H*OlFvMv%s0U zT?Bnfuwt>ceWpTSbSw{MWt3}G0fbYj$g5R=%6nO+)ET^S0-O)19A6@=Y-Pm>$<+Pj zfk|vq7lvJ<;j}YUoeG1lD@jLaBB+SVf-~X11v&fw9V_f%6DaElJ+?XK5UGstD$7mm zfe;1sZDF^N4_8h{9UKw( z_c?-|pIm`z%iES-M`A(`D>n`2QvaGx;RQ#+4(GT*j0&tR{e^2X||CxW}PP4J*0kOXLONEX!M8 zPYDi5?cno-N1>2xi~&=W!>e0iF*Ey0PnD|!_oW}Ll<~eI?=qZty`q4L&qgYzy`X@8 zll)}nrIWkTYD?F6D-?p(!ZCW#6tNTttf8Bxb(AXEIbV7y-FpwneP=HgU%C3lq8z#Y ziRq6%dhMJ|(&CH7O-(j8t+qfh<;v0(y{y=oJiXLLbTG}hzSa&}n8^mgJDIdv2doQJetq8as|F*^rZYYmF%z7U%5v=`mWQdxPT+g1 zOICw>gt^0ZlS+pmeS-XI5dO5mai~-d5vic56QIg@sLImt9BP{tM>7;e+Z-b9rd77U z)CP>(J5d(=Zg=;kDh}(IP5>UA$zFRx-ELe+!y5%vzCBpnZY+RPrg|B0C!IaLkdKdP zXSqBZBY>Yq&_e*s;CRi}2$ON`!cy?&`GPHXCIZ9!#FA&*@;`QjZru<1sbYEoP4@Oe zg%~qJ@1w2YzQbo7vImT|I=nZyMZ2LcRcs$o) zPOfnXR3>0?@aTotA`mTKI1e#4`$D)1@KWnH<$xEeU+F0i>|#Yv_Ej(i6=tFbPdI~9 z0bnr^7;4GyWckv+Ll#%y{@+Kynp=f{<%H)$(w=Ws#m5P_24{yA2&l4 zMUDTv@_{J_f90Pw&)z(G!=pDWQfXDD{N&Y5cAszQc<*d#Xb$A6879!Ig1*K2?(rMS z=UL*-*iSOOxf<)zNTwT-(bK?xgOl*(KgBSz`5`B<`yxQdN2hxj9<}Sh^&?2YcxV6> zY&3~GC)y$7kx{2p#5O{p99=5W<#7z~$`l+2xO}Xy_qsQINJxXzM3?p7B9|$^h?1(^ zbOq7X3iidSMHM1IOob|<9s)8Nc8f@WV+7q3QgE$KdtgTs?jvmCrmN*{tQdab3_#`f zmrb}Eq8Z9o$SP=kAmRw>9x=>*b}1mfW{gK$|nm*~OIL-6Bs^7tx{ z_k(C@MFO=$?zjv0R)w$(sgB0S*aP{Ezk?zxz^bcG*C;4MlSc%Hj2>~ysL`2#>{c>3 ziRuwwFRbea5eDAEr~e(zXT(RYBr3)qhObo6?tPtQtpRjn{|!17YM!|HTOxh(gmKrq zGwuD*W7~ZF&{Y$|m8(CW67t@&4d~vQh~@70zkcBM3-{WKHXLfRyXLEkd)xGXvnjeV zi{))^8xUmxjN4py;fwUtBF4k0OA58Vt6y8=(=Ggl;uGB_+_tD#-#^zP{p>{?{+2B9qxb%WY}T2nVy)?9=1sS55-+Fd)rt|I~vr4^G9wkIAdHfm!qvrwGB@fX)(?GB>PT#h+H|0Ef@ zL^AlfREErk{7n;10_#gv&NqnyV~2*vK(WZ^R4hO4^=PRrV22Tj(*-cJ1udror@bJQ z@#=XNt|H(2tEpoyXrKR}A(7|v%~b!ukNfOzyu8T{+_z@}99;o3z$N=mJaDT)t4dzI zP`thYYc0pfDe2&<&j(54f>6=s%pJcZpR8`2H(;PtzFzd*2MywA3 zVKj)pD9vAtn+G)neIC^O#uh{ zAyK>B^X)SA4Hy7D8JL>Gp@QbmK?j%F5;#?QJUPJ*MGRTHdKbPr`pNv00j=GGysKgE z1O4QP=ca;oYu~xoDx)j+XO^|t+&Fti1H(7jQsr56pEZQA9HdrT8h5YSjfv?G_pAOi zb=TE_1{V8J(db|QzHsX9GkDZn_f5AXIAYMwh7orV*rq0!FSHS~V9lz# z7Gqz<{QlsSDVEULsg@$XG{5P;7s*rPrZOXSpz!5IpKU;N2Y(kH>RLLc`YZ9uK>`$$(M$;9`? z1>H}-)#|5rlvxCXd>?)J>g5ow-xkOC<4^S8^Y8^M^LAqV;l~@UtdQ%vEm&D~Y>))y3h z_vqZ*ccJLcYTla@!iNWBY6#YR=kWa8x0i_TyaPa@|DE};VqdZdLQJeLp?_u&AAH-g zd;D9^8rHy_9ykc!tpW?ZabQ92KKH+&gJX&A2ecB|{~iFfNK}7zoUSH;=bx#tcj4Eg zCA+EIx5>N~!MpI&gZTA`{;adME=ird%*0Uxbw*QrMqBWOMxk`yL)IRz*i}dysjyLd zW%oTDHc6BCMMr#`szlm(nQOp?iI-aItbX3N;LO3sPx;I7M(9EL*6v=_K6MoJ=CjKe zg9~(xf*+(V`25HF<@ZkQG{ZQ;;-&vlYk(hDJk+{uiG-19*|&*$Yo>&LxG@Xh-25=m!~TP_(BO(S_!dU9!WpA>pfH=+o+LK|zPT#eSYC4#pjjx7L_p>w(rb0Ajx-g@ zPzO?p#tEwHIToJ>U#bDXj*uAG*g&KHGxoHi=MSfdC;2c^%eBXINuLl_x1Lqwyeg7 ztTs+}eBBVdH>rDd4J1OFTcE^Aqjnf&Si=I%E~pK|i$wd)I+%%dcy!I5FhtkA)M=Lr z;fjp!9AZViN^^sa%kN#|%~6PKjeLV$DLhY4BbFE#NkZjp;8*f9>+T#yj&VF6t}ml| zl){(yjUpF*4D#t}sjxh5Rt*$uiaI@{aKk%ufu;}lZG}!E6VJoVF!RJng;+&lW6qv; zegeZ(ZuINm9k0^pJ$T`pb@N-6qyF4`ZqXX`R`?4;!ZO^v%Y+eX*q3|dpUt(8+ax{Q zb6fjHpx6~2VWq;Up<9N-m7ZzFl}Y~2yD4&#lj&ZiuvajWbQiy%1vnkF4rB`nr&1W+ zW+bcN+r&uW{1(a^U`XK~nxQ&bNCC}91^kty7T7)qfK8#Zwpiv^C>kaW3mZ8oY3ACZ zc8`3HtD~8veue3cWyIMTY%Fb7tYV|=A;T3h{)#Xs|vqhp@HB5 zUOGkZQwm=@a+6%)1aWx?P{l679N{|~Y*GbGm0_dx3m~5~H~*jZt_3Qp>uTT2%m@RF zcQ6{qKTR2Q24;qrPa+BoV3X*isfJ|42ndmeMV&;5n8&XJLn2A>(O@68HbtRgA`DfU zzrVJUfgwON)KqOFY7#}OsDK7E#`>C>^MB`F?l6#aHT`Q`t6jNkCCukJ_q_Jm=j?s< zKKqvH$i4X%3CkoK9R6(K=CRPzPq<^<(I`|KK6U|oy%sTg;{=1%z)}}2Ih&kwJWiJo zDDlsDx3#4O7V++AOrSR9z(AkT6Z+_aOk5B0gzoEb*U zpj7J4^lEt2#4g_L2iGYKha8)}8YgSU*G%wd3Yh4OeRD}E;zz9N4Ai^khZ)sSzHu#M zUTQl`vaG#t*RCWFw;(Ib9cxq9c{tqvpci&RT(L1mWx%ZNSQ1-juEX%a=&rRRUXgVa z)&o;CHV3N=(ur^j2U~B4nyE-+dLcap2Ctr-6ksY#NRY=g$?G$rE1UaD;d3ErS6;O5 zs*iTBvSSXM-D=Cq4ZA#F>&e#6kis2_a337rqab@qY|AZRt>6qzqHBHegeix6mGq9Z%ZQT{*)BK)Ws<|l4W8D$MZ|{K8V`4*d!jqG0JGrIV#S=ps2$$l&aK<*T0k}A<{TW!xi zS4_Z2Fy}C`;}!0n3fHM<%-k545u=H$zlH){qdFT9MJK}%GT_vCIOzmiM!^baFu@Rg zkfz@5=KLSCyqn7Pni?an_am>!DK#=OhiWn5j&W?Xv$|DB`EoH7-u- zFW)!dJ~)tNi%xWLlZr3Fd8nJVZlgOiKL;V$7@FuPycArd_8y?YRa5RxNU0OV>X_HNg0)Jl)K5&%pnzWzZoBFX z3f=|7^?@$iD{DOj%!*kud4_{nCm0f>aPWo`iq>6akMnTrH%#;x>u>{j9~MYE&e`^1 ztEbLE%tXf_{KR&}vr_|BKC6F>$3M`T;0TBTH#y|+mtadv`^@mz;o3_`1Bq~l)_2)( zE7Rj7E;_s765tpRg+7%Wv0{J<#`BQ&ot4=VqQwD9Ut$wmhhq!7+CK@qnBtx#`jS!FR7EZ~+34aaPUlCC!93s-2GTHdnkU9$&8!>%4)Qdgg;aHW9VtcfPV985fn)@zted>pS zRQka+%Hq*mtxXh}>*$;S=e)5Ku8_Zs zCD?#v(8bJhWlwg;!nBLMHlzJOCfFO3851*m&O=$Yqb0TjX@*28ypB1rexz->2X>k$ z!Yx=(sPywwQ^!<4_%Geh=Hw)|7!o+8q&0c1rR1^A_ZpnRW5-tNj7r`YH5Jlkc!W&n zP%mN4Z(_gCUZV()gU}mIxa4GPveG(B$eKy4q#7C13zPMZF=0l7gq5gYbaA$V&P|*2 z)==zZGrv_?X-MK8S*o+%TkK9l7cliwB-`M1$t1t>BP^HL{179=4@3NIc(OV;cwNyo zBgPZD-qdV6bS#`-B^n-{kG&dBpxmX!HCPg?kjESPJ(Q@oJRVP?o7)M&tK7oq5t6}F zmJgweks9C$SBhh45hML8aOSuyZA-3 z8s{DPxtwI&CbQm=fU-{Dke;bu!Y<0j-}Ot_&u)VsaB5d#l>5a^L z@o4|37)jl?D;DM%k<(SqW+-dVq2yT|y8)0H%)D`HNORBZ~YR1Y76EE8)x*O`PHg&Zt zJ9rj(AvZQ|>8}WRKfbUqC&HQtLo0%7z4X#)dc_?Pe|}@IjqbPOo-ucO7i@q`Km3-A zusvRcwe?lRu^VW_V$uv}m86h&ZmVZHMkl#OtEXUWixtlfenlbs8IEa1$3nyXvDbhbT$ZATPDUBt}OE&HmKrI=-VA9{K^PS{Zx-AqKJW z43T|;NW27|K4VJF!Aojz=di!v!j|hj@#ck@<5L&xn8H224YQ5%S|`GJ zF#|iJadPO954-_pak|m(b+@Tr*LN%09atQVBX0h`ro}k>m$FWh?nJ;VGmgBcqGJ%{ z*>2@iN@(;lYFa9_UuSe~|ED5dAQ%&CWiSDmEY>iyn0Y0OHRIpZ|Aq5@oIhqiY3nq= z5jP~|FS|$Io_@|>Y9v=eT8x=bNzI#PgdKWY;dmNXd|@8_v4g|N%BJEfCV~}fTrW$% z)pfJNvnN0Ee%aIdbOe+M{ByD_@Mb}N^L1?)tR2EHDOt6(xLGpKbke`r;cq>J zKwgq66t}u$t1MjC#g^EbLIS$j^0m$K`m|>DhZ~w$dl$R;jV-dU%o$tRUsX9IsJo_# zi|%4;wl_(ly4dY+;-qx@TU*#@&waIZP1?_M3 zTMn~7zEX~3*gXA-aY%z^t10dznZ+mAG0FEyoRN`*MJ-kOv9A|dpJb%w=ulXtx7P*Z z+&WKh?u_<3%@ls-e9E4tP^URK98;Du$%C;U82Z3EO!yyz|NDD*G}-g)eR0dC;eJyF z1Bdip-oKHVIm`={j zgZ9NBB(IQu`mb`nJ`tZfoibRzQ2xm-R(zkY@8c6f`}y{wzT+Pc$K;q$zL-7|A3Y|t zM@jpO_m3VE$_M7#FJiI1M~^Xldk%^1Kk8FH#&cc=9H=oq&DXnCM$%~}%)HMutNgS) zJtPXPNJBb?;&1x*PT?tk*jL~=IN%~+#v4|vRjfrep-p9V4b`%)tR38WEm};+2@o(r zJA_urt;2C|(QsV%FXOYr>ibvA>-a)@hL=Aw{U71p5#z!q&0qSd*^2WAU;5MisLw}V`-cC&UjFyeKapI?CfAIYaT7cTqhCh< zMz6m1Oj)ZE>YrEsM^K?$sCVA;zd-0az+QcT*N@EAxM?e{pV0rz_BA5r^*^(n8-a}? zF1OJ9u#^qHKbZgW2<)wYFx`tgie#w_S-4QlFJPQldfP+Ohj5)mOYwU{={$Z`#C1hH z{(%<@`P)R?E2MkNH(2@nUW}mfCg1v=Eo)U3uCm$0_eK7H$b5JCUp+}!|7Y$SPJb$o z_BHl>W%*Bz{{BHKO%VIjQS?^Y8yd~GM7$Q`^+@;j?}?cDMSOeXMwN&=Fn)XAz8~?i zg!xi#dCl~Lci;7%C$6Unl>WDkD>j_HE9<{z8u%aU|Ic@S3H|%}`o#9F!})bI zf{u&WU_Hy*KSbPt%aYZwhlse`a#pp?2d@S8^TGMRfxbBRi|GcRbXs1m53U2I_7}0f zk(ie6at)=+QitasiD~}zKI;MP&jugdyZWpu!3WnO{WBjtvb=wU1^PelZGW4phNu6t zFH-v7G%8^~yBqtzp3FU?S$;KP~KOql>UAwk> z#@D_7D~>(1JQCNT2w7*!ENo$>{+b|CS;1s_9t7jO>-UYoq@uJZp4#)$8PZ5wv{AD^ zzD)^h{XfKeh4*3X7V-<2QxC_X-tvU>A?&Sh%JBMj4B~g1`Sxk{3%Hgv3+>C(3;CO! zLi%e$y1lKP;wrWH{s#vs=Av|1kNN)mS$ID{#D5Vm`p>5yf%gaUs|V|2$Y~*cus@|D z&ePW*f4Ub-!)lboOuV>TMR6dr`g2;|;sT)1G(-|~60^y`*xl^+81eSS?ayRWst ztWC*!buUND=%;3Sv)O+2b0HmOY#v|vOu%CLvQbdQPiy(hesS-8qLkK{L&*L?k!qtxpCu`_gH(Rm~p2utuH8OeUMnc!5Wd+W{FIM{ipjWt3N_1(?C(gtVkLR|D%rFjjN5t|?W#yJ5=|g6_ z-XdLYt+{r{jAPM3?5ERDsG;r-V|o`N&>R>jmQUOB^G;uk{x8YQ-1N&Ix<9UF3`)GT&o8Qp#S=>GXKk8 z$NcB%-!sLx|Gh=S`%mXvb#->WI39F9*4CzbM2t|FFawxB8iBoP;$XU0tl-s7#-1+b zucK-yWA7Zoc_!+?E@G+%0cVStx>@+9_pRpXpIyBJ!Gd}E=Y6IAZ`>TW{4Brz?fA0( zd+T3T1~I<6)QjgrEC;6#$Lb**F(O?M!-vx06rh5Wy!ZV;>lu~N==9=py5IQpzpm(v z>hcYbH(d~;hsvX3^P)wI%>UDf{_mjl|7!g=?~N-syC)ah>M|3Yvs+#~L3gW)aD3m7 ziZwULNxGhG)I6xC*vyQk7V#Uc*G(Q(Lm|jgz4VD+iziS+4)Y_qvjJNBan_eU=)&>z14 zUO9o5%IBnCQ-bsL9z@CBlRKM`ON*(tdHmK~e%rUho5Q|SE+;n$|LPx$!cz%d)^E(` zz3c2E{u?4J;;|P!B&1&xw(SFh>Bk1e20Of;?5lEeCU@X7S8v~sW*taF2rPE5Q~VOe z2YmhFw5H20J>3#<2fRhnF;BeMl5a8lNar0RFl9@pk2X!c(U#`qb=vH){p8}9sJ90 z75K~->R-m!KlzUs{5_WYXnSb=hx#djDl|0z+MVWf(oaWsqh@X{*Z|&u{SeTobU7Cn zCn+Ad%46NbV6!A>o1fnha5==b7T_~Hu99j~QU5A)=Lu%+D;m=ojaa`DqF^b*O#A$y zeZbI@+PaHXNgt#8%$y#SwYXa37a_a>Vr%^mB&*<83!-ZawXBszt{P Date: Tue, 7 Apr 2015 23:02:54 +0200 Subject: [PATCH 16/28] light intensity from object: handle campfires --- addons/common/functions/fnc_lightIntensityFromObject.sqf | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/addons/common/functions/fnc_lightIntensityFromObject.sqf b/addons/common/functions/fnc_lightIntensityFromObject.sqf index f9749ab8a0..98e7935f9f 100644 --- a/addons/common/functions/fnc_lightIntensityFromObject.sqf +++ b/addons/common/functions/fnc_lightIntensityFromObject.sqf @@ -96,6 +96,14 @@ if (_lightSource isKindOf "CAManBase") then { } forEach _lights; + // handle campfires + if (inflamed _lightSource) then { + private "_distance"; + _distance = _unitPos distance position _lightSource; + + _lightLevel = _lightLevel max linearConversion [0, 30, _distance, 0.5, 0, true]; + }; + }; _lightLevel From 2f4335d3c28062579cb4aa541fea7ecab3dcc57c Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Tue, 7 Apr 2015 17:14:27 -0500 Subject: [PATCH 17/28] #344 - Ignore missing ace_serverconfig on client --- addons/common/scripts/Version/checkVersionNumber.sqf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/addons/common/scripts/Version/checkVersionNumber.sqf b/addons/common/scripts/Version/checkVersionNumber.sqf index 87b89a8b6b..467ebd9c1a 100644 --- a/addons/common/scripts/Version/checkVersionNumber.sqf +++ b/addons/common/scripts/Version/checkVersionNumber.sqf @@ -81,7 +81,7 @@ if (!isServer) then { _index = _files find _x; if (_index == -1) then { - _missingAddons pushBack _x; + if (_x != "ace_serverconfig") then {_missingAddons pushBack _x;}; } else { _clientVersion = _versions select _index; From 50dbbda8ebacef8995459073326dd7a9aef08230 Mon Sep 17 00:00:00 2001 From: commy2 Date: Wed, 8 Apr 2015 00:20:43 +0200 Subject: [PATCH 18/28] disable cursor showing map position --- addons/common/RscInfoType.hpp | 18 ++++++++++++++++++ addons/common/XEH_preInit.sqf | 10 ++++++++++ 2 files changed, 28 insertions(+) diff --git a/addons/common/RscInfoType.hpp b/addons/common/RscInfoType.hpp index fe21b05265..429d1d7b02 100644 --- a/addons/common/RscInfoType.hpp +++ b/addons/common/RscInfoType.hpp @@ -28,3 +28,21 @@ class RscDisplayInventory { class RscDisplayChannel { onLoad = QUOTE(_this call FUNC(onLoadRscDisplayChannel)); }; + +// map +class RscDisplayMainMap { + onLoad = QUOTE([ARR_4(""onLoad"",_this,""RscDiary"",'GUI')] call (uinamespace getvariable 'BIS_fnc_initDisplay'); uiNamespace setVariable [ARR_2('ACE_dlgMap', _this select 0)]; [ARR_2('mapDisplayLoaded', [ARR_2(_this select 0, 'Ingame')])] call FUNC(localEvent);); +}; + +class RscDisplayGetReady: RscDisplayMainMap { + onLoad = QUOTE([ARR_4(""onLoad"",_this,""RscDiary"",'GUI')] call (uinamespace getvariable 'BIS_fnc_initDisplay'); uiNamespace setVariable [ARR_2('ACE_dlgMap', _this select 0)]; [ARR_2('mapDisplayLoaded', [ARR_2(_this select 0, 'Briefing')])] call FUNC(localEvent);); +}; + +class RscDisplayServerGetReady: RscDisplayGetReady { + onLoad = QUOTE([ARR_4(""onLoad"",_this,""RscDiary"",'GUI')] call (uinamespace getvariable 'BIS_fnc_initDisplay'); uiNamespace setVariable [ARR_2('ACE_dlgMap', _this select 0)]; [ARR_2('mapDisplayLoaded', [ARR_2(_this select 0, 'ServerBriefing')])] call FUNC(localEvent);); +}; + + +class RscDisplayClientGetReady: RscDisplayGetReady { + onLoad = QUOTE([ARR_4(""onLoad"",_this,""RscDiary"",'GUI')] call (uinamespace getvariable 'BIS_fnc_initDisplay'); uiNamespace setVariable [ARR_2('ACE_dlgMap', _this select 0)]; [ARR_2('mapDisplayLoaded', [ARR_2(_this select 0, 'ClientBriefing')])] call FUNC(localEvent);); +}; diff --git a/addons/common/XEH_preInit.sqf b/addons/common/XEH_preInit.sqf index b7da27ea75..98b0d17c7d 100644 --- a/addons/common/XEH_preInit.sqf +++ b/addons/common/XEH_preInit.sqf @@ -283,6 +283,16 @@ if (hasInterface) then { ["playerChanged", [ACE_player, _oldPlayer]] call FUNC(localEvent); }; }, 0, []] call cba_fnc_addPerFrameHandler; + + // doesn't work on postInit in SP + ["mapDisplayLoaded", { + //hint str _this; systemChat str _this; diag_log str _this; + + if (_this select 1 == "ingame") then { + ((_this select 0) displayCtrl 1016) ctrlShow false; + }; + }] call FUNC(addEventhandler); + }; // Init toHex From 4834facccf64ab01443362c0220be2155e9e7358 Mon Sep 17 00:00:00 2001 From: commy2 Date: Wed, 8 Apr 2015 00:30:36 +0200 Subject: [PATCH 19/28] moving it to map --- addons/common/XEH_preInit.sqf | 10 ---------- addons/map/XEH_postInitClient.sqf | 9 +++++++++ 2 files changed, 9 insertions(+), 10 deletions(-) diff --git a/addons/common/XEH_preInit.sqf b/addons/common/XEH_preInit.sqf index 98b0d17c7d..b7da27ea75 100644 --- a/addons/common/XEH_preInit.sqf +++ b/addons/common/XEH_preInit.sqf @@ -283,16 +283,6 @@ if (hasInterface) then { ["playerChanged", [ACE_player, _oldPlayer]] call FUNC(localEvent); }; }, 0, []] call cba_fnc_addPerFrameHandler; - - // doesn't work on postInit in SP - ["mapDisplayLoaded", { - //hint str _this; systemChat str _this; diag_log str _this; - - if (_this select 1 == "ingame") then { - ((_this select 0) displayCtrl 1016) ctrlShow false; - }; - }] call FUNC(addEventhandler); - }; // Init toHex diff --git a/addons/map/XEH_postInitClient.sqf b/addons/map/XEH_postInitClient.sqf index ccaf9041ab..778b1c8191 100644 --- a/addons/map/XEH_postInitClient.sqf +++ b/addons/map/XEH_postInitClient.sqf @@ -19,4 +19,13 @@ call FUNC(determineZoom); ((findDisplay 12) displayCtrl 51) ctrlAddEventHandler ["Draw", {[] call FUNC(updateMapEffects);}]; }; +// doesn't work on postInit in SP +["mapDisplayLoaded", { + hint str _this; systemChat str _this; diag_log str _this;// + + if (_this select 1 == "ingame") then { + ((_this select 0) displayCtrl 1016) ctrlShow false; + }; +}] call FUNC(addEventhandler); + ADDON = true; From 691ab012b4a1cbc1d7201160c10c7ae22061e95a Mon Sep 17 00:00:00 2001 From: commy2 Date: Wed, 8 Apr 2015 00:44:14 +0200 Subject: [PATCH 20/28] fix map loaded on preInit --- addons/map/XEH_postInitClient.sqf | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/addons/map/XEH_postInitClient.sqf b/addons/map/XEH_postInitClient.sqf index 778b1c8191..f60fb696f6 100644 --- a/addons/map/XEH_postInitClient.sqf +++ b/addons/map/XEH_postInitClient.sqf @@ -19,12 +19,14 @@ call FUNC(determineZoom); ((findDisplay 12) displayCtrl 51) ctrlAddEventHandler ["Draw", {[] call FUNC(updateMapEffects);}]; }; -// doesn't work on postInit in SP +// Note: doesn't work on postInit in SP, therefore use default setting +(findDisplay 12 displayCtrl 1016) ctrlShow (GETGVAR(showPositionOnCursor,false)); + ["mapDisplayLoaded", { - hint str _this; systemChat str _this; diag_log str _this;// + //hint str _this; systemChat str _this; diag_log str _this; if (_this select 1 == "ingame") then { - ((_this select 0) displayCtrl 1016) ctrlShow false; + ((_this select 0) displayCtrl 1016) ctrlShow (GETGVAR(showPositionOnCursor,false)); }; }] call FUNC(addEventhandler); From 29d9da9f4d0dbcfa942d50a5f95e24d448abca4b Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Tue, 7 Apr 2015 22:05:15 -0500 Subject: [PATCH 21/28] Include needed CBA file prerec Dragging needs this to compile --- tools/cba/addons/xeh/init_pre.sqf | 358 ++++++++++++++++++++++++++++++ 1 file changed, 358 insertions(+) create mode 100644 tools/cba/addons/xeh/init_pre.sqf diff --git a/tools/cba/addons/xeh/init_pre.sqf b/tools/cba/addons/xeh/init_pre.sqf new file mode 100644 index 0000000000..8e6a31f8c8 --- /dev/null +++ b/tools/cba/addons/xeh/init_pre.sqf @@ -0,0 +1,358 @@ +// #define DEBUG_MODE_FULL +#include "script_component.hpp" +SCRIPT(init_pre); + +if !(isNil'SLX_XEH_MACHINE') exitWith {}; // Doublecheck.. + +LOG(MSG_INIT); +// No _this in pre/PostInit, also fixes call to init_compile +private "_this"; +_this = nil; + +private ["_id", "_cfgRespawn", "_respawn", "_level"]; + +// UNIQUE Session ID since start of game +_id = uiNamespace getVariable "SLX_XEH_ID"; +if (isNil "_id") then { _id = 1 } else { if (typeName _id != "SCALAR") then { _id = 0 }; if (_id < 0) then { _id = 0 }; INC(_id) }; +uiNamespace setVariable ["SLX_XEH_ID", _id]; + +CBA_isCached = uiNamespace getVariable "CBA_isCached"; +CBA_isCached = if (isNil "CBA_isCached" && {isMultiplayer} && {!isDedicated}) then { -1 } else { _id }; +uiNamespace setVariable ["CBA_isCached", CBA_isCached]; + +if (isNil "SLX_XEH_RECOMPILE") then { SLX_XEH_RECOMPILE = CACHE_DIS(xeh) }; + +if (!isMultiplayer || {isDedicated} || {CBA_isCached == -1}) then { + uiNamespace setVariable ["SLX_XEH_CACHE_KEYS", []]; + uiNamespace setVariable ["SLX_XEH_CACHE_KEYS2", []]; + uiNamespace setVariable ["SLX_XEH_CACHE_KEYS3", []]; + uiNamespace setVariable ["CBA_CACHE_KEYS", []]; +}; + +SLX_XEH_CACHE_KEYS = uiNamespace getVariable "SLX_XEH_CACHE_KEYS"; +SLX_XEH_CACHE_KEYS2 = uiNamespace getVariable "SLX_XEH_CACHE_KEYS2"; +SLX_XEH_CACHE_KEYS3 = uiNamespace getVariable "SLX_XEH_CACHE_KEYS3"; +CBA_CACHE_KEYS = uiNamespace getVariable "CBA_CACHE_KEYS"; + +// Always compile cache function once +call compile preProcessFileLineNumbers 'x\cba\addons\xeh\init_compile.sqf'; + +// Log +SLX_XEH_DisableLogging = isClass(configFile/"CfgPatches"/"Disable_XEH_Logging"); + +// Backup functions for macros +// TODO: Cleanup... +// CBA_fnc_log = { diag_log [diag_frameNo, diag_tickTime, time, _this] }; + + +/* CBA_fnc_defaultParam = { + PARAMS_3(_params,_index,_defaultValue); + + private "_value"; + + if (!isNil "_defaultValue") then { + _value = _defaultValue; + }; + + if (!isNil "_params" && {(typeName _params) == "ARRAY"} && {count _params > _index} && {!isNil { _params select _index }}) then { + _value = _params select _index; + }; + + // Return. + if (isNil "_value") then { + nil; + } else { + _value; + }; +}; +*/ + +XEH_LOG("XEH: PreInit Started. v"+getText(configFile >> "CfgPatches" >> "CBA_XEH" >> "version")+". "+PFORMAT_5("MISSINIT",missionName,worldName,isMultiplayer,isServer,isDedicated)); +if (time > 0) then { XEH_LOG("XEH WARNING: Time > 0; This probably means there are no XEH compatible units by default on the map, perhaps add the SLX_XEH_Logic module.") }; + +// Compile all necessary scripts and start one vehicle crew initialisation thread +_cfgRespawn = (missionConfigFile/"respawn"); +_respawn = false; +if ( isNumber(_cfgRespawn) ) then { + _respawn = !(getNumber(_cfgRespawn) in [0, 1, 4, 5]); +}; +if ( isText(_cfgRespawn) ) then { + _respawn = !(getText(_cfgRespawn) in ["none", "bird", "group", "side"]); +}; + +SLX_XEH_objects = []; // Temporary array, to track InitPosts at mission initialization +SLX_XEH_INIT_MEN = []; // Temporary array, to track ManBased inits - to workaround JIP issue "Double init eh ran for crew units" +SLX_XEH_DELAYED = []; // Temporary array, to track Delayed Inits at mission initialization + + +// Game version detection +_level = 0; // pre v1.60 +// TODO: Improve v1.60 detection +// TODO: Temporary disabled due to #28652 +//if ((isNumber (configFile >> "CfgDifficulties" >> "recruit" >> "recoilCoef")) && (isNumber (configFile >> "CfgVehicles" >> "Car" >> "turnCoef"))) then { + //_level = 1; // v1.60 +//}; + +FUNC(determineProductVersion) = { + private "_pv"; + _pv = call {productVersion}; + + // A2 (and OA pre 1.61beta, and TOH pre 1.05?) does not support productVersion so we deal with it manually + if (isNil "_pv") then { + _pv = if (isClass(configFile >> "CfgPatches" >> "A3_Map_Stratis")) then { + // A3 Backup + ["Arma 3 Alpha","Arma3Alpha", -1, -1]; //,5,102571] + + } else { + if (isClass(configFile >> "CfgPatches" >> "United_States_H")) then { + // TOH Backup + ["TakeOn H", "TakeOnH", -1, -1]; + } else { + if (isClass(configFile >> "CfgPatches" >> "Takistan")) then { + // OA Backup + ["ArmA 2OA", "ArmA2OA", -1, -1]; + } else { + // A2 Backup + ["ArmA 2", "ArmA2", -1, -1]; + }; + }; + }; + }; + + _pv; +}; + +FUNC(determineGame) = { + // 0 = A2 + // 1 = OA + // 2 = TOH + // 3 = A3 :P + private "_pv"; + _pv = call FUNC(determineProductVersion); + + switch (_pv select 1) do { + case "ArmA2": {0}; + case "ArmA2OA": {1}; + case "TakeOnH": {2}; + case "Arma3Alpha": {3}; + case "Arma3": {3}; + default {0}; + }; +}; + +// System array with machine / mission / session information +SLX_XEH_MACHINE = +[ + !isDedicated, // 0 - isClient (and thus has player) + false, // 1 - isJip + !isServer, // 2 - isDedicatedClient (and thus not a Client-Server) + isServer, // 3 - isServer + isDedicated, // 4 - isDedicatedServer (and thus not a Client-Server) + false, // 5 - Player Check Finished + !isMultiplayer, // 6 - SP? + false, // 7 - StartInit Passed + false, // 8 - Postinit Passed + isMultiplayer && {_respawn}, // 9 - Multiplayer && respawn? + if (isDedicated) then { 0 } else { if (isServer) then { 1 } else { 2 } }, // 10 - Machine type (only 3 possible configurations) + _id, // 11 - SESSION_ID + _level, // 12 - LEVEL - Used for version determination + false, // 13 - TIMEOUT - PostInit timedOut + call FUNC(determineGame), // 14 - Game + call FUNC(determineProductVersion) // 15 - Product+Version +]; + +SLX_XEH_DUMMY = switch (SLX_XEH_MACHINE select 14) do { + case 2: {"Helipad_Invisible_H" }; + case 3: {"Land_HelipadEmpty_F" }; + default { "HeliHEmpty" }; +}; + +SLX_XEH_STR = ""; // Empty string +SLX_XEH_STR_INIT_EH = "Extended_Init_EventHandlers"; +SLX_XEH_STR_INIT_POST_EH = "Extended_InitPost_EventHandlers"; +SLX_XEH_STR_PreInit = "Extended_PreInit_EventHandlers"; +SLX_XEH_STR_PostInit = "Extended_PostInit_EventHandlers"; +SLX_XEH_STR_DEH = "DefaultEventhandlers"; +SLX_XEH_STR_TAG = "SLX_XEH_"; +SLX_XEH_STR_PLAYABLE = "SLX_XEH_PLAYABLE"; + +SLX_XEH_STR_PROCESSED = "SLX_XEH_PROCESSED"; +SLX_XEH_AR_FALSE = [SLX_XEH_STR_PROCESSED, false]; +SLX_XEH_AR_TRUE = [SLX_XEH_STR_PROCESSED, true]; + +SLX_XEH_OTHER_EVENTS = [XEH_EVENTS,XEH_CUSTOM_EVENTS]; // All events except the init event +SLX_XEH_OTHER_EVENTS_FULL = []; +{ SLX_XEH_OTHER_EVENTS_FULL pushBack format["Extended_%1_EventHandlers", _x] } forEach SLX_XEH_OTHER_EVENTS; +SLX_XEH_OTHER_EVENTS_XEH = []; +{ SLX_XEH_OTHER_EVENTS_XEH pushBack format["Extended_%1EH", _x] } forEach SLX_XEH_OTHER_EVENTS; +SLX_XEH_OTHER_EVENTS_XEH_PLAYERS = []; +{ SLX_XEH_OTHER_EVENTS_XEH_PLAYERS pushBack format["Extended_%1EH_Player", _x] } forEach SLX_XEH_OTHER_EVENTS; +SLX_XEH_OTHER_EVENTS_PLAYERS = []; + +// HitPart is special in that the passed parameter to the event handler is an array of arrays +{ + if (_x == "HitPart") then + { + SLX_XEH_OTHER_EVENTS_PLAYERS pushBack (compile format["{ { _this call _x } forEach (((_this select 0) select 0) getVariable [SLX_XEH_STR_%1_Player,[]]) }",_x]) + } + else + { + SLX_XEH_OTHER_EVENTS_PLAYERS pushBack (compile format["{ { _this call _x } forEach ((_this select 0) getVariable [SLX_XEH_STR_%1_Player,[]]) }",_x]) + } +} forEach SLX_XEH_OTHER_EVENTS; + +SLX_XEH_CONFIG_FILES = [configFile, campaignConfigFile, missionConfigFile]; +SLX_XEH_CONFIG_FILES_VARIABLE = [campaignConfigFile, missionConfigFile]; + +SLX_XEH_DEF_CLASSES = [SLX_XEH_STR, "All"]; + +// XEH for non XEH supported addons +// Only works until someone uses removeAllEventhandlers on the object +// Only works if there is at least 1 XEH-enabled object on the Map - Place SLX_XEH_Logic to make sure XEH initializes. +// TODO: Perhaps do a config verification - if no custom eventhandlers detected in _all_ CfgVehicles classes, don't run this XEH handler - might be too much processing. +SLX_XEH_EVENTS_NAT = [XEH_EVENTS]; +SLX_XEH_EVENTS_FULL_NAT = []; +{ SLX_XEH_EVENTS_FULL_NAT pushBack format["Extended_%1_EventHandlers", _x] } forEach SLX_XEH_EVENTS_NAT; + +SLX_XEH_EXCLUDES = []; // TODO: Anything else?? - Ammo crates for instance have no XEH by default due to crashes) - however, they don't appear in 'vehicles' list anyway. +SLX_XEH_CLASSES = []; // Used to cache classes that have full XEH setup - TODO: Performance test.. Could use object with a variable space, classname as key +SLX_XEH_FULL_CLASSES = []; // Used to cache classes that NEED full XEH setup +SLX_XEH_EXCL_CLASSES = []; // Used for exclusion classes + + +// Function Compilation +SLX_XEH_LOG = { XEH_LOG(_this); }; + +PREP(init_once); // Pre and PostInits + +PREP(init_delayed); +PREP(init_playable); + +// Inits and InitPosts +PREP(init); +PREP(init_enum); +PREP(init_enum_cache); +PREP(init_post); + +// Init Others +PREP(init_others); +PREP(init_others_enum); +PREP(init_others_enum_cache); + +PREP(addPlayerEvents); // Add / Remove the playerEvents +PREP(removePlayerEvents); +PREP(support_monitor); +PREP(support_monitor2); + +call COMPILE_FILE(init_eh); // All XEH Event functions + + +/* +* Process the crews of vehicles. This "thread" will run just +* before PostInit and the mission init.sqf is processed. The order of execution is +* +* 1) all config.cpp init EHs (including all Extended_Init_Eventhandlers) +* 2) all the init lines in the mission.sqm +* 3) spawn:ed "threads" are started +* 4) the mission's init.sqf/sqs is run +*/ + +GVAR(init_obj) = SLX_XEH_DUMMY createVehicleLocal [0, 0, 0]; +GVAR(init_obj) addEventHandler ["killed", { + #ifdef DEBUG_MODE_FULL + XEH_LOG("XEH: VehicleCrewInit: "+str(count vehicles)); + #endif + + { + _sim = getText(configFile/"CfgVehicles"/(typeOf _x)/"simulation"); + _crew = crew _x; + /* + * If it's a vehicle then start event handlers for the crew. + * (Vehicles have crew and are neither humanoids nor game logics) + */ + if (count _crew > 0 && {{ _sim == _x }count["soldier", "invisible"] == 0}) then { + { if !(_x in SLX_XEH_INIT_MEN) then { [_x] call SLX_XEH_EH_Init } } forEach _crew; + }; + } forEach vehicles; + SLX_XEH_INIT_MEN = nil; + + deleteVehicle GVAR(init_obj);GVAR(init_obj) = nil +}]; + +GVAR(init_obj) setDamage 1; // Schedule to run itsy bitsy later + +// Prepare postInit +GVAR(init_obj2) = SLX_XEH_DUMMY createVehicleLocal [0, 0, 0]; +GVAR(init_obj2) addEventHandler ["killed", { + call COMPILE_FILE(init_post); + deleteVehicle GVAR(init_obj2);GVAR(init_obj2) = nil; +}]; + +// Schedule PostInit +SLX_XEH_STR spawn { + // Warn if PostInit takes longer than 10 tickTime seconds + SLX_XEH_STR spawn { + private["_time2Wait"]; + _time2Wait = diag_ticktime + 10; + waituntil {diag_ticktime > _time2Wait}; + if !(SLX_XEH_MACHINE select 8) then { + XEH_LOG("WARNING: PostInit did not finish in a timely fashion"); + waitUntil {time > 0}; + // Consider there will be no player if neither PostInit-Ready, nor PlayerCheck-Ready + if !(SLX_XEH_MACHINE select 8 || {SLX_XEH_MACHINE select 5}) then { SLX_XEH_MACHINE set [13, true]; }; + }; + }; + + // On Server + Non JIP Client, we are now after all objects have inited + // and at the briefing, still time == 0 + if (isNull player) then { + #ifdef DEBUG_MODE_FULL + "NULL PLAYER" call SLX_XEH_LOG; + #endif + if !((SLX_XEH_MACHINE select 4) || {(SLX_XEH_MACHINE select 6)}) then { // only if MultiPlayer and not dedicated + #ifdef DEBUG_MODE_FULL + "JIP" call SLX_XEH_LOG; + #endif + + SLX_XEH_MACHINE set [1, true]; // set JIP + // TEST for weird jip-is-server-issue :S + if (!(SLX_XEH_MACHINE select 2) || {SLX_XEH_MACHINE select 3} || {SLX_XEH_MACHINE select 4}) then { + str(["WARNING: JIP Client, yet wrong detection", SLX_XEH_MACHINE]) call SLX_XEH_LOG; + SLX_XEH_MACHINE set [2, true]; // set Dedicated client + SLX_XEH_MACHINE set [3, false]; // set server + SLX_XEH_MACHINE set [4, false]; // set dedicatedserver + }; + waitUntil { !(isNull player) || {SLX_XEH_MACHINE select 13} }; + if (SLX_XEH_MACHINE select 13) then { XEH_LOG("WARNING: TimedOut waiting for player object to be ready. Continueing PostInit without Player ready") }; + }; + }; + + if !(isNull player) then { + if (isNull (group player) && {player isKindOf "CAManBase"}) then { + // DEBUG TEST: Crashing due to JIP, or when going from briefing + // into game + #ifdef DEBUG_MODE_FULL + "NULLGROUP" call SLX_XEH_LOG; + #endif + waitUntil { !(isNull (group player)) }; + }; + waitUntil { local player }; + }; + + GVAR(init_obj2) setDamage 1; // Schedule to run itsy bitsy later + + SLX_XEH_MACHINE set [5, true]; // set player check = complete +}; + +// Load and call any "pre-init", run-once event handlers +/* + Compile code strings in the Extended_PreInit_EventHandlers class and call + them. This is done once per mission and before any extended init event + handler code is run. An addon maker can put run-once initialisation code + in such a pre-init "EH" rather than in a normal XEH init EH which might be + called several times. +*/ +{ (_x/SLX_XEH_STR_PreInit) call FUNC(init_once) } forEach SLX_XEH_CONFIG_FILES; + + +XEH_LOG("XEH: PreInit Finished. " + PFORMAT_3("CACHE DISABLED? (Disable caching with cba_cache_disable.pbo)",SLX_XEH_RECOMPILE,CBA_COMPILE_RECOMPILE,CBA_FUNC_RECOMPILE)); From ca1bafcc79c46bb1a1bcedbd711fded00947db09 Mon Sep 17 00:00:00 2001 From: ViperMaul Date: Tue, 7 Apr 2015 20:36:19 -0700 Subject: [PATCH 22/28] Improved usage of the registry for path to CfgConvert.exe and MikeRo Tools --- .../pabstFrankensteinBuilder.py | 23 ++++++++++++++----- 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/tools/ace_build_tool/pabstFrankensteinBuilder.py b/tools/ace_build_tool/pabstFrankensteinBuilder.py index 09b12a5dc3..f58f192a53 100644 --- a/tools/ace_build_tool/pabstFrankensteinBuilder.py +++ b/tools/ace_build_tool/pabstFrankensteinBuilder.py @@ -188,10 +188,16 @@ def find_bi_tools(work_drive): else: raise Exception("BadTools","Arma 3 Tools are not installed correctly or the P: drive needs to be created.") -def find_depbo_tools(): +def find_depbo_tools(regKey): """Use registry entries to find DePBO-based tools.""" + stop = False + + if regKey == "HKCU": + reg = winreg.ConnectRegistry(None, winreg.HKEY_CURRENT_USER) + stop = True + else: + reg = winreg.ConnectRegistry(None, winreg.HKEY_LOCAL_MACHINE) - reg = winreg.ConnectRegistry(None, winreg.HKEY_CURRENT_USER) try: k = winreg.OpenKey(reg, r"Software\Mikero\pboProject") try: @@ -217,7 +223,10 @@ def find_depbo_tools(): except: print_error("Could not find makepbo.") except: - raise Exception("BadDePBO", "DePBO tools not installed correctly") + if stop == True: + raise Exception("BadDePBO", "DePBO tools not installed correctly") + return -1 + #Strip any quotations from the path due to a MikeRo tool bug which leaves a trailing space in some of its registry paths. return [pboproject_path.strip('"'),rapify_path.strip('"'),makepbo_path.strip('"')] @@ -439,7 +448,9 @@ See the make.cfg file for additional build options. if build_tool == "pboproject": try: - depbo_tools = find_depbo_tools() + depbo_tools = find_depbo_tools("HKLM") + if depbo_tools == -1: + depbo_tools = find_depbo_tools("HKCU") pboproject = depbo_tools[0] rapifyTool = depbo_tools[1] makepboTool = depbo_tools[2] @@ -580,7 +591,7 @@ See the make.cfg file for additional build options. os.chdir("P:\\") - cmd = [os.path.join(work_drive, "CfgConvert", "CfgConvert.exe"), "-bin", "-dst", os.path.join(work_drive, prefix, module, "config.bin"), os.path.join(work_drive, prefix, module, "config.cpp")] + cmd = [os.path.join(arma3tools_path, "CfgConvert", "CfgConvert.exe"), "-bin", "-dst", os.path.join(work_drive, prefix, module, "config.bin"), os.path.join(work_drive, prefix, module, "config.cpp")] ret = subprocess.call(cmd) #ret = subprocess.call(["cfgConvertGUI.exe", os.path.join(work_drive, prefix, module, "config.cpp")]) @@ -589,7 +600,7 @@ See the make.cfg file for additional build options. input("Press Enter to continue...") - cmd = [os.path.join(work_drive, "CfgConvert", "CfgConvert.exe"), "-txt", "-dst", os.path.join(work_drive, prefix, module, "config.cpp"), os.path.join(work_drive, prefix, module, "config.bin")] + cmd = [os.path.join(arma3tools_path, "CfgConvert", "CfgConvert.exe"), "-txt", "-dst", os.path.join(work_drive, prefix, module, "config.cpp"), os.path.join(work_drive, prefix, module, "config.bin")] ret = subprocess.call(cmd) if ret != 0: print_error("CfgConvert -txt) return code == " + str(ret)) From b18bcf883565f7a0bc4750643f5be82ac9b25889 Mon Sep 17 00:00:00 2001 From: esteldunedain Date: Wed, 8 Apr 2015 01:49:56 -0300 Subject: [PATCH 23/28] Add option to turn on/off cursor coordinates --- addons/map/CfgVehicles.hpp | 9 +++++++++ addons/map/XEH_postInitClient.sqf | 4 ++-- addons/map/config.cpp | 4 ++++ addons/map/functions/fnc_moduleMap.sqf | 7 ++++--- 4 files changed, 19 insertions(+), 5 deletions(-) diff --git a/addons/map/CfgVehicles.hpp b/addons/map/CfgVehicles.hpp index b8d3a54d96..612cadb006 100644 --- a/addons/map/CfgVehicles.hpp +++ b/addons/map/CfgVehicles.hpp @@ -36,6 +36,15 @@ class CfgVehicles { class No { name = "No"; value = 0; default = 1;}; }; }; + class MapShowCursorCoordinates { + displayName = "Show cursor coordinates?"; + description = "Show the grid coordinates on the mouse pointer?"; + typeName = "BOOL"; + class values { + class Yes { name = "Yes"; value = 1; }; + class No { name = "No"; value = 0; default = 1;}; + }; + }; }; }; diff --git a/addons/map/XEH_postInitClient.sqf b/addons/map/XEH_postInitClient.sqf index f60fb696f6..c6a2c572ad 100644 --- a/addons/map/XEH_postInitClient.sqf +++ b/addons/map/XEH_postInitClient.sqf @@ -20,13 +20,13 @@ call FUNC(determineZoom); }; // Note: doesn't work on postInit in SP, therefore use default setting -(findDisplay 12 displayCtrl 1016) ctrlShow (GETGVAR(showPositionOnCursor,false)); +(findDisplay 12 displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); ["mapDisplayLoaded", { //hint str _this; systemChat str _this; diag_log str _this; if (_this select 1 == "ingame") then { - ((_this select 0) displayCtrl 1016) ctrlShow (GETGVAR(showPositionOnCursor,false)); + ((_this select 0) displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); }; }] call FUNC(addEventhandler); diff --git a/addons/map/config.cpp b/addons/map/config.cpp index e544a67c12..d9dae47bd3 100644 --- a/addons/map/config.cpp +++ b/addons/map/config.cpp @@ -48,6 +48,10 @@ class ACE_Settings { value = 0; typeName = "BOOL"; }; + class GVAR(mapShowCursorCoordinates) { + value = 0; + typeName = "BOOL"; + }; }; #include "CfgEventHandlers.hpp" diff --git a/addons/map/functions/fnc_moduleMap.sqf b/addons/map/functions/fnc_moduleMap.sqf index b6e556c92e..a22bbbb385 100644 --- a/addons/map/functions/fnc_moduleMap.sqf +++ b/addons/map/functions/fnc_moduleMap.sqf @@ -15,8 +15,9 @@ _activated = _this select 2; if !(_activated) exitWith {}; -[_logic, QGVAR(mapIllumination), "MapIllumination"] call EFUNC(common,readSettingFromModule); -[_logic, QGVAR(mapShake), "MapShake" ] call EFUNC(common,readSettingFromModule); -[_logic, QGVAR(mapLimitZoom), "MapLimitZoom" ] call EFUNC(common,readSettingFromModule); +[_logic, QGVAR(mapIllumination), "MapIllumination" ] call EFUNC(common,readSettingFromModule); +[_logic, QGVAR(mapShake), "MapShake" ] call EFUNC(common,readSettingFromModule); +[_logic, QGVAR(mapLimitZoom), "MapLimitZoom" ] call EFUNC(common,readSettingFromModule); +[_logic, QGVAR(mapShowCursorCoordinates), "MapShowCursorCoordinates"] call EFUNC(common,readSettingFromModule); diag_log text "[ACE]: Interaction Module Initialized."; From a47cdb9738290976b8e3e5b1e33b3d0ecfc15420 Mon Sep 17 00:00:00 2001 From: commy2 Date: Wed, 8 Apr 2015 10:45:57 +0200 Subject: [PATCH 24/28] disable map cursor coordinates in mp --- addons/map/XEH_postInitClient.sqf | 11 ----------- addons/map/XEH_preInit.sqf | 1 + addons/map/config.cpp | 10 +++++++++- addons/map/functions/fnc_onDrawMap.sqf | 5 +++++ 4 files changed, 15 insertions(+), 12 deletions(-) create mode 100644 addons/map/functions/fnc_onDrawMap.sqf diff --git a/addons/map/XEH_postInitClient.sqf b/addons/map/XEH_postInitClient.sqf index c6a2c572ad..ccaf9041ab 100644 --- a/addons/map/XEH_postInitClient.sqf +++ b/addons/map/XEH_postInitClient.sqf @@ -19,15 +19,4 @@ call FUNC(determineZoom); ((findDisplay 12) displayCtrl 51) ctrlAddEventHandler ["Draw", {[] call FUNC(updateMapEffects);}]; }; -// Note: doesn't work on postInit in SP, therefore use default setting -(findDisplay 12 displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); - -["mapDisplayLoaded", { - //hint str _this; systemChat str _this; diag_log str _this; - - if (_this select 1 == "ingame") then { - ((_this select 0) displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); - }; -}] call FUNC(addEventhandler); - ADDON = true; diff --git a/addons/map/XEH_preInit.sqf b/addons/map/XEH_preInit.sqf index 7899c6a637..c5645a52e7 100644 --- a/addons/map/XEH_preInit.sqf +++ b/addons/map/XEH_preInit.sqf @@ -8,6 +8,7 @@ PREP(blueForceTrackingUpdate); PREP(determineMapLight); PREP(determineZoom); PREP(moduleMap); +PREP(onDrawMap); PREP(updateMapEffects); ADDON = true; diff --git a/addons/map/config.cpp b/addons/map/config.cpp index d9dae47bd3..cb3cbc8d6d 100644 --- a/addons/map/config.cpp +++ b/addons/map/config.cpp @@ -89,7 +89,8 @@ class RscMapControl { class RscDisplayMainMap { // Tweak map styling class controlsBackground { - class CA_Map : RscMapControl { + class CA_Map: RscMapControl { + onDraw = QUOTE([ctrlParent (_this select 0)] call DFUNC(onDrawMap)); #include "MapTweaks.hpp" }; }; @@ -147,6 +148,13 @@ class RscDisplayDiary { // BRIEFING SCREEN class RscDisplayGetReady: RscDisplayMainMap { + // Tweak map styling + class controlsBackground { + class CA_Map: RscMapControl { + onDraw = QUOTE([ctrlParent (_this select 0)] call DFUNC(onDrawMap)); + //#include "MapTweaks.hpp" @todo Shouldn't this apply to briefing too? + }; + }; // get rid of the "center to player position" - button (as it works even on elite) class controls { class TopRight: RscControlsGroup { diff --git a/addons/map/functions/fnc_onDrawMap.sqf b/addons/map/functions/fnc_onDrawMap.sqf new file mode 100644 index 0000000000..2d17c24962 --- /dev/null +++ b/addons/map/functions/fnc_onDrawMap.sqf @@ -0,0 +1,5 @@ +// by commy2 +#include "script_component.hpp" + +diag_log text str diag_frameno; +((_this select 0) displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); From deece11689490ce26001a7e771cc4853c7d4ecaf Mon Sep 17 00:00:00 2001 From: commy2 Date: Wed, 8 Apr 2015 10:47:56 +0200 Subject: [PATCH 25/28] remove debug --- addons/map/functions/fnc_onDrawMap.sqf | 1 - 1 file changed, 1 deletion(-) diff --git a/addons/map/functions/fnc_onDrawMap.sqf b/addons/map/functions/fnc_onDrawMap.sqf index 2d17c24962..bc147884e4 100644 --- a/addons/map/functions/fnc_onDrawMap.sqf +++ b/addons/map/functions/fnc_onDrawMap.sqf @@ -1,5 +1,4 @@ // by commy2 #include "script_component.hpp" -diag_log text str diag_frameno; ((_this select 0) displayCtrl 1016) ctrlShow GVAR(mapShowCursorCoordinates); From af3d6a5113e64bcbf0c72c7e0222fb8be8115736 Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Wed, 8 Apr 2015 10:33:12 -0500 Subject: [PATCH 26/28] #386 - Ace Options Menu on main menu Same limitations as CBA controls, needs a intro or mission loaded Doesn't work with -skipintro command line. --- addons/optionsmenu/gui/pauseMenu.hpp | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/addons/optionsmenu/gui/pauseMenu.hpp b/addons/optionsmenu/gui/pauseMenu.hpp index 880f418a38..d6a831c2aa 100644 --- a/addons/optionsmenu/gui/pauseMenu.hpp +++ b/addons/optionsmenu/gui/pauseMenu.hpp @@ -94,4 +94,13 @@ class RscDisplayInterruptEditor3D: RscStandardDisplay { class controls { class ACE_Open_settingsMenu_Btn : ACE_Open_SettingsMenu_BtnBase {}; }; -}; \ No newline at end of file +}; +class RscDisplayMain: RscStandardDisplay { + class controls { + class ACE_Open_settingsMenu_Btn : ACE_Open_SettingsMenu_BtnBase { + action = "if (missionName != '') then {createDialog 'ACE_settingsMenu';};"; + y = "4 * ((((safezoneW / safezoneH) min 1.2) / 1.2) / 25) + safezoneY"; + }; + }; +}; + From a4af1fcb3081b945596314281e299f9c174147cf Mon Sep 17 00:00:00 2001 From: PabstMirror Date: Wed, 8 Apr 2015 13:55:29 -0500 Subject: [PATCH 27/28] Fix Marker Placement on UAV Map --- addons/markers/functions/fnc_initInsertMarker.sqf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/addons/markers/functions/fnc_initInsertMarker.sqf b/addons/markers/functions/fnc_initInsertMarker.sqf index 9b77134b56..6ac13f9e80 100644 --- a/addons/markers/functions/fnc_initInsertMarker.sqf +++ b/addons/markers/functions/fnc_initInsertMarker.sqf @@ -50,7 +50,7 @@ _mapIDD = -1; { if (!isNull (findDisplay _x)) exitWith {_mapIDD = _x}; - } forEach [12, 37, 52, 53]; + } forEach [12, 37, 52, 53, 160]; if (_mapIDD == -1) exitWith {ERROR("No Map?");}; if (!(_mapIDD in GVAR(mapDisplaysWithDrawEHs))) then { GVAR(mapDisplaysWithDrawEHs) pushBack _mapIDD; From 3f84a084940c47d7d16ef8ca93886d7f2a75df5c Mon Sep 17 00:00:00 2001 From: jaynus Date: Wed, 8 Apr 2015 12:09:11 -0700 Subject: [PATCH 28/28] Update FCS iteration limit for accuracy over range. --- ace_fcs.dll | Bin 779264 -> 779264 bytes extensions/fcs/ace_fcs.cpp | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/ace_fcs.dll b/ace_fcs.dll index 189c3c0826ce75e1559ad934a4891813f27a6d47..2cb8b86de25ab55527693de98e36f855afb6a766 100644 GIT binary patch delta 98 zcmZoTq2F*qf5H#uIW?+{zqkHoJSi+J`iWmawStLDz^(CL1QP=Tf6s~OS40?3wl5H6 s1Y#y2W(HywAZ7((HXvpPVh$kY+`d4RD`Yz(OZ(R|T-(2%;pP?x07>&CLjV8( delta 95 zcmZoTq2F*qf5H#un*U0TzqkHoJSi+7^od_UwStLDz^(aT1%J=!>DNUVPqxn$Wdvd- pAZ7+)79eH?Vm2UV2VxE&=G;D4lq-BYBUAg=GhExhp5f*e2LMCBB&GlW diff --git a/extensions/fcs/ace_fcs.cpp b/extensions/fcs/ace_fcs.cpp index 6338dd8571..a1a3b64ba7 100644 --- a/extensions/fcs/ace_fcs.cpp +++ b/extensions/fcs/ace_fcs.cpp @@ -21,7 +21,7 @@ #include #define MAXELEVATION 20 -#define MAXITERATIONS 120 +#define MAXITERATIONS 600 #define PRECISION 0.1 #define RADIANS(X) (X / (180 / M_PI))