From 2ea850389fe7f23260f8ab49e755266e8293e2e3 Mon Sep 17 00:00:00 2001 From: Schalldampfer Date: Fri, 27 Jul 2018 18:11:32 +0900 Subject: [PATCH] add files --- README.md | 48 ++++++++++++++++++ .../Epoch_Deploy_server_PackVehicle.sqf | 18 +++++++ .../Epoch_Deploy_server_SpawnVehicle.sqf | 49 +++++++++++++++++++ 3 files changed, 115 insertions(+) create mode 100644 epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_PackVehicle.sqf create mode 100644 epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_SpawnVehicle.sqf diff --git a/README.md b/README.md index 520488a..8490bb7 100644 --- a/README.md +++ b/README.md @@ -1 +1,49 @@ # DeployBike4A3E +*Deploy vehicle from dyna menu (Space key menu) +*Pack vehicle from dyna menu while looking at it +*You can define any vehicle to spawn +*The vehicle is spawned server side (not saved in the hive, but theoretically possible) +*No animation like DayZ Epoch's "deploy anything" for now (but theoretically possible with client side modification) + +Server side + +copy these two files: +epoch_server\compile\deploy_vehicle\Epoch_Deploy_server_PackVehicle.sqf +epoch_server\compile\deploy_vehicle\Epoch_Deploy_server_SpawnVehicle.sqf + +Modify those files: +epoch_server\config.cpp Line146~(in class CfgServerFunctions -> class A3E): + + class deploy_vehicle { + class Deploy_server_SpawnVehicle {}; + class Deploy_server_PackVehicle {}; + }; + +epoch_server\init\server_init.sqf : at bottom (outside any curly brackets) +"Deploy_SpawnVehicle" addPublicVariableEventHandler{(_this select 1) call Epoch_Deploy_server_SpawnVehicle}; +"Deploy_PackVehicle" addPublicVariableEventHandler{(_this select 1) call Epoch_Deploy_server_PackVehicle}; + + +Client side + +Modify two files: +epoch_config\Configs\CfgActionMenu\CfgActionMenu_self.hpp (at bottom) + +class Deploy_deploy +{ + condition = "!dyna_inVehicle"; + action = "Deploy_SpawnVehicle = [player,'MBK_01_EPOCH']; publicVariableServer 'Deploy_SpawnVehicle';"; + icon = "x\addons\a3_epoch_code\Data\UI\buttons\repair.paa"; + tooltip = "Deploy Bike"; +}; + +epoch_config\Configs\CfgActionMenu\CfgActionMenu_target.hpp (at bottom) + +class Deploy_pack +{ + condition = "dyna_isVehicle && ((crew dyna_cursorTarget) isEqualTo [])"; + action = "Deploy_PackVehicle = [player,dyna_cursorTarget]; publicVariableServer 'Deploy_PackVehicle';"; + icon = "x\addons\a3_epoch_code\Data\UI\buttons\repair.paa"; + tooltip = "Pack Vehicle"; +}; + diff --git a/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_PackVehicle.sqf b/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_PackVehicle.sqf new file mode 100644 index 0000000..6223a84 --- /dev/null +++ b/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_PackVehicle.sqf @@ -0,0 +1,18 @@ +/* + Author: Schalldampfer + + [_player,_vehObj] +*/ +private ["_player","_puid","_owner","_vehObj","_vehClass"]; +_player = _this select 0; +_puid = getPlayerUID _player; +_owner = owner _player; +_vehObj = _this select 1; +_vehClass = typeOf _vehObj; + +if ((_vehObj getVariable ["EPOCH_DeployOwner","-1"]) == _puid) then {//check owner + Deploy_DeployedVehicles = Deploy_DeployedVehicles - [_vehObj];//remove from array + deleteVehicle _vehObj;//remove vehicle + format["You've packed a %1!", _vehClass] remoteExec ["Epoch_message",_player]; +}; + diff --git a/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_SpawnVehicle.sqf b/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_SpawnVehicle.sqf new file mode 100644 index 0000000..a58b228 --- /dev/null +++ b/epoch_server/compile/deploy_vehicle/Epoch_Deploy_server_SpawnVehicle.sqf @@ -0,0 +1,49 @@ +/* + Author: Schalldampfer + [_player,_vehClass] +*/ +private ["_player","_puid","_owner","_position","_vehClass","_vehObj","_isOk"]; +_player = _this select 0; +_puid = getPlayerUID _player; +_owner = owner _player; +_position = getPos _player; +_vehClass = _this select 1; + +diag_log format["[DeployBike] Try spawning %1 by %2",_vehClass,_player]; + +_isOk = true; +if(isNil "Deploy_DeployedVehicles") then {Deploy_DeployedVehicles = [];}; + +//check player haven't spawned one +{ + if ((_x getVariable ["EPOCH_DeployOwner","-1"]) == _puid) then { _isOk = false;"You've already deployed a vehicle!" remoteExec ["Epoch_message",_player]; }; +} foreach Deploy_DeployedVehicles; + +//spawn +if (_isOk) then { + _vehObj = _vehClass createVehicle _position; //create + _vehObj allowDamage false; + + //init + _vehObj setVectorUp (surfaceNormal (getPos _vehObj)); + _vehObj setVelocity [0,0,.1]; + _vehObj call EPOCH_server_setVToken; + //_vehObj call EPOCH_server_vehicleInit; + Deploy_DeployedVehicles set [count Deploy_DeployedVehicles, _vehObj];//add to array + _vehObj setvariable ["EPOCH_DeployOwner",_puid];//set puid as owner + _vehObj addEventHandler ["GetIn", {"WARNING: This vehicle will be deleted at restart!" remoteExec ["Epoch_message",_this select 2];}];//warn when get in + + // Normalize vehicle inventory + clearWeaponCargoGlobal _vehObj; + clearMagazineCargoGlobal _vehObj; + clearBackpackCargoGlobal _vehObj; + clearItemCargoGlobal _vehObj; + + _vehObj setFuel ((random 1 max 0.1) min 0.9);//fuel + + //complete spaning + _vehObj allowDamage true; + format["You've deployed a %1!", _vehClass] remoteExec ["Epoch_message",_player]; +}; + +_vehObj