2015-01-11 16:42:31 +00:00
|
|
|
// by commy2
|
2015-01-12 04:02:33 +00:00
|
|
|
#include "script_component.hpp"
|
2015-01-11 16:42:31 +00:00
|
|
|
|
2015-01-11 18:20:14 +00:00
|
|
|
_config = configFile >> QGVAR(Default_Keys);
|
2015-01-11 16:42:31 +00:00
|
|
|
_count = count _config;
|
|
|
|
|
2015-01-12 04:02:33 +00:00
|
|
|
_header = "_keyCode = [_this select 1, _this select 2, _this select 3, _this select 4] call FUNC(convertKeyCode); _keyIndex = floor _keyCode; if (_keyIndex == 0) exitWith {false}; if (!(profileNamespace getVariable ['ACE_enableNumberHotkeys', true]) && {_keyIndex < 12} && {_keyIndex > 1} && {_keyCode mod 1 == 0}) exitWith {false}; _time = time; _player = ACE_player; _vehicle = vehicle _player; _isInput = false;";
|
|
|
|
_headerUp = "_keyCode = _this select 1; _keyIndex = _keyCode; if (_keyIndex == 0) exitWith {false}; _time = time; _player = ACE_player; _vehicle = vehicle _player;";
|
2015-01-11 16:42:31 +00:00
|
|
|
|
|
|
|
_handleDoubleTap = "if (_time < (GVAR(keyTimes) select _keyIndex) + 0.5 && {_keyIndex == _keyCode}) then {_keyCode = _keyIndex + 0.8};";
|
|
|
|
_handleHold = "_allowHold = false; _disallowHold = false; if (GVAR(keyStates) select _keyIndex > 1) exitWith {false}; if (GVAR(keyStates) select _keyIndex > 0) then {_keyCode = _keyIndex + 0.9};";
|
|
|
|
_handleHoldUp = "if (GVAR(keyStates) select _keyIndex > 1) then {_keyCode = _keyIndex + 0.9};";
|
|
|
|
|
2015-01-12 04:02:33 +00:00
|
|
|
_debug = "if (!isNil 'ACE_Debug' && {'Keys' in ACE_Debug}) then {systemChat (str _keyCode + ' ' + str (GVAR(keyStates) select _keyIndex))};";
|
2015-01-11 16:42:31 +00:00
|
|
|
|
|
|
|
_onKeyDown = "" + _debug;
|
|
|
|
_onKeyUp = "" + _debug;
|
|
|
|
|
|
|
|
for "_index" from 0 to (_count - 1) do {
|
|
|
|
_configFile = _config select _index;
|
|
|
|
|
|
|
|
_keyName = configName _configFile;
|
|
|
|
_condition = getText (_configFile >> "condition");
|
|
|
|
if (_condition == "") then {_condition = "true"};
|
|
|
|
|
|
|
|
_statement = getText (_configFile >> "statement");
|
|
|
|
|
|
|
|
_exceptions = getArray (_configFile >> "exceptions");
|
|
|
|
_canInteract = format ["%1 call GVAR(canInteract)", _exceptions];
|
|
|
|
|
2015-01-12 04:02:33 +00:00
|
|
|
_conditionName = format ["ACE_Key_%1_Condition", _keyName];
|
|
|
|
_statementName = format ["ACE_Key_%1_Statement", _keyName];
|
2015-01-11 16:42:31 +00:00
|
|
|
missionNamespace setVariable [_conditionName, compileFinal _condition];
|
|
|
|
missionNamespace setVariable [_statementName, compileFinal _statement];
|
|
|
|
|
|
|
|
_handleHolding = ["_disallowHold = true;", "_allowHold = true;"] select (getNumber (_configFile >> "allowHolding") == 1);
|
|
|
|
|
|
|
|
if (_statement != "") then {
|
2015-01-12 04:02:33 +00:00
|
|
|
_entry = format ["if (_keyCode == profileNamespace getVariable 'ACE_Key_%1' && {call %2}) then {if (%4) then {call %3};%5 _isInput = true;};", _keyName, _conditionName, _statementName, _canInteract, _handleHolding];
|
2015-01-11 16:42:31 +00:00
|
|
|
_onKeyDown = _onKeyDown + _entry;
|
|
|
|
};
|
|
|
|
|
|
|
|
_condition = getText (_configFile >> "conditionUp");
|
|
|
|
if (_condition == "") then {_condition = "true"};
|
|
|
|
|
|
|
|
_statement = getText (_configFile >> "statementUp");
|
|
|
|
|
2015-01-12 04:02:33 +00:00
|
|
|
_conditionName = format ["ACE_Key_%1_ConditionUp", _keyName];
|
|
|
|
_statementName = format ["ACE_Key_%1_StatementUp", _keyName];
|
2015-01-11 16:42:31 +00:00
|
|
|
missionNamespace setVariable [_conditionName, compileFinal _condition];
|
|
|
|
missionNamespace setVariable [_statementName, compileFinal _statement];
|
|
|
|
|
|
|
|
if (_statement != "") then {
|
2015-01-12 04:02:33 +00:00
|
|
|
_entry = format ["if (_keyCode == floor (profileNamespace getVariable 'ACE_Key_%1') && {call %2}) then {call %3; _isInput = true;};", _keyName, _conditionName, _statementName];
|
2015-01-11 16:42:31 +00:00
|
|
|
_onKeyUp = _onKeyUp + _entry;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
_halt = "if (!(_allowHold) || {_disallowHold}) then {GVAR(keyStates) set [_keyIndex, (GVAR(keyStates) select _keyIndex) + 1]; GVAR(keyTimes) set [_keyIndex, _time];};";
|
2015-01-11 18:20:14 +00:00
|
|
|
_haltUp = QGVAR(keyStates) set [_keyIndex, 0];;
|
2015-01-11 16:42:31 +00:00
|
|
|
|
|
|
|
//_return = "_isInput";
|
2015-01-12 04:02:33 +00:00
|
|
|
_return = "if (profileNamespace getVariable ['ACE_enableNumberHotkeys', true] && {_keyIndex < 12} && {_keyIndex > 1}) then {true} else {_isInput}";
|
2015-01-11 16:42:31 +00:00
|
|
|
|
|
|
|
_repeat = "if (!_isInput && {_keyCode mod 1 > 0.75} && {_keyCode mod 1 < 0.85}) exitWith {_keyCode = _keyIndex; " + _onKeyDown + _return + "};";
|
|
|
|
_repeatUp = "if (!_isInput && {_keyCode mod 1 > 0.75} && {_keyCode mod 1 < 0.85}) exitWith {_keyCode = _keyIndex; " + _onKeyUp + "};";
|
|
|
|
|
|
|
|
_onKeyDown = _header + _handleDoubleTap + _handleHold + _onKeyDown + _halt + _repeat + _return;
|
|
|
|
_onKeyUp = _headerUp + _onKeyUp + _haltUp + _repeatUp; //_headerUp + _handleHoldUp + _onKeyUp + _haltUp + _repeatUp;
|
|
|
|
|
|
|
|
GVAR(onKeyDown) = compileFinal _onKeyDown;
|
|
|
|
GVAR(onKeyUp) = compileFinal _onKeyUp;
|