Added several improvements to the user interface. See Changlog for details

Added mission notifications using Toasts (Exile Only)
Added Killer notifications that display Bonus Recieved for the Kill.
Minor corrections of typos and bug fixes
This commit is contained in:
Ghostrider-DbD- 2016-11-20 13:16:41 -05:00
parent aa7ed60592
commit 4a2e7088b9
10 changed files with 82 additions and 34 deletions

View File

@ -1,16 +0,0 @@
//This script sends Message Information to allplayers
// Last modified 9/3/15 by Ghostrider-DBD-
blck_Message = _this;
//diag_log format["AIM.sqf ===] _this = %1",_this];
{
//diag_log format["AIM.sqf ===] (owner _x) = %1", (owner _x)];
(owner _x) publicVariableClient "blck_Message";
} forEach playableUnits;
/*
if (_modType isEqualTo "Exile") then
{
[_blck_Message] remoteExec["fn_blck_MessageHandler",0];
};
*/

View File

@ -3,10 +3,10 @@
//blck_Message = _this; //blck_Message = _this;
params["_msg",["_players",playableUnits]]; params["_msg",["_players",playableUnits]];
diag_log format["AIM.sqf ===] _this = %1 | _msg = %2 | _players = %3",_this,_msg, _players]; //diag_log format["AIM.sqf ===] _this = %1 | _msg = %2 | _players = %3",_this,_msg, _players];
blck_Message = _msg; blck_Message = _msg;
{ {
diag_log format["AIM.sqf ===] _ = %2, and (owner _x) = %1", (owner _x), _x]; //diag_log format["AIM.sqf ===] _ = %2, and (owner _x) = %1", (owner _x), _x];
(owner _x) publicVariableClient "blck_Message"; (owner _x) publicVariableClient "blck_Message";
} forEach _players; } forEach _players;
/* /*

View File

@ -4,7 +4,7 @@
By Ghostrider-DbD- By Ghostrider-DbD-
11/16/16 11/16/16
*/ */
if (_fnc_cleanEmptyGroups) then if (true) then
{ {
diag_log format ["_fnc_cleanEmptyGroups:: -- >> group count = %1 ",(count allGroups)]; diag_log format ["_fnc_cleanEmptyGroups:: -- >> group count = %1 ",(count allGroups)];
}; };

View File

@ -11,6 +11,8 @@ private _index = 0;
_timeAccelUpdated = diag_tickTime; _timeAccelUpdated = diag_tickTime;
_timer1min = diag_tickTime; _timer1min = diag_tickTime;
_timer5min = diag_tickTime; _timer5min = diag_tickTime;
_timer10Min = diag_tickTime;
_modType = [] call blck_fnc_getModType;
while {true} do while {true} do
{ {
uiSleep blck_mainThreadUpdateInterval; uiSleep blck_mainThreadUpdateInterval;
@ -34,15 +36,23 @@ while {true} do
[] call GMS_fnc_cleanupDeadAI; [] call GMS_fnc_cleanupDeadAI;
if ((diag_tickTime - _timeAccelUpdated) > 300) then if (_modType isEqualTo "Epoch") then {[] call blck_fnc_cleanEmptyGroups;}; // Exile cleans up empty groups automatically so this should not be needed with that mod.
{
[] call blck_fnc_timeAcceleration;
_timeAccelUpdated = diag_tickTime;
}; };
if ((diag_tickTime - _timer5min) > 300) then {
[] call blck_fnc_timeAcceleration;
if (blck_useHC) then {[] call blck_fnc_monitorHC;}; if (blck_useHC) then {[] call blck_fnc_monitorHC;};
[] call blck_fnc_cleanEmptyGroups; _timer5min = diag_tickTime;
}; };
/*
if ((diag_tickTime - _timer10Min) > 600) then
{
// Reserved for future use
_timer10Min = diag_tickTime;
};
*/
/* /*
{ {
if (_x select 6 > 0) then // The mission is not running, check the time left till it is spawned if (_x select 6 > 0) then // The mission is not running, check the time left till it is spawned

View File

@ -1,6 +1,6 @@
/* /*
Handle AI Deaths Handle AI Deaths
Last Modified 11/6/16 Last Modified 11/20/16
By Ghostrider-DBD- By Ghostrider-DBD-
Copyright 2016 Copyright 2016
*/ */
@ -20,6 +20,9 @@ if (blck_removeNVG) then {[_unit] spawn blck_fnc_removeNVG;};
if !(isPlayer _killer) exitWith {}; if !(isPlayer _killer) exitWith {};
[_unit,_killer] call blck_fnc_alertNearbyUnits; [_unit,_killer] call blck_fnc_alertNearbyUnits;
_isLegal = [_unit,_killer] call blck_fnc_processIlleagalAIKills; _isLegal = [_unit,_killer] call blck_fnc_processIlleagalAIKills;
if !(_isLegal) exitWith {};
_lastkill = _killer getVariable["blck_lastkill",diag_tickTime]; _lastkill = _killer getVariable["blck_lastkill",diag_tickTime];
_killer setVariable["blck_lastkill",diag_tickTime]; _killer setVariable["blck_lastkill",diag_tickTime];
_kills = (_killer getVariable["blck_kills",0]) + 1; _kills = (_killer getVariable["blck_kills",0]) + 1;
@ -29,9 +32,10 @@ if ((diag_tickTime - _lastkill) < 240) then
} else { } else {
_killer setVariable["blck_kills",0]; _killer setVariable["blck_kills",0];
}; };
if (_isLegal) then {[_unit,_killer,_kills] call blck_fnc_rewardKiller;};
_weapon = currentWeapon _killer; _weapon = currentWeapon _killer;
_killstreakMsg = format[" %1X KILLSTREAK",_kills]; _killstreakMsg = format[" %1X KILLSTREAK",_kills];
if (blck_useKilledAIName) then if (blck_useKilledAIName) then
{ {
_message = format["[blck] %2: killed by %1 from %3m",name _killer,name _unit,round(_unit distance _killer)]; _message = format["[blck] %2: killed by %1 from %3m",name _killer,name _unit,round(_unit distance _killer)];
@ -39,8 +43,9 @@ if (blck_useKilledAIName) then
_message = format["[blck] %1 killed with %2 from %3 meters",name _killer,getText(configFile >> "CfgWeapons" >> _weapon >> "DisplayName"), round(_unit distance _killer)]; _message = format["[blck] %1 killed with %2 from %3 meters",name _killer,getText(configFile >> "CfgWeapons" >> _weapon >> "DisplayName"), round(_unit distance _killer)];
}; };
_message =_message + _killstreakMsg; _message =_message + _killstreakMsg;
//diag_log format["[blck] unit killed message is %1",_message,""]; diag_log format["[blck] unit killed message is %1",_message,""];
[["aikilled",_message,"victory"]] call blck_fnc_messageplayers; [["aikilled",_message,"victory"]] call blck_fnc_messageplayers;
[_unit,_killer,_kills] call blck_fnc_rewardKiller;
{ {
_unit removeAllEventHandlers _x; _unit removeAllEventHandlers _x;
}forEach ["Killed","Fired","HandleDamage","HandleHeal","FiredNear"] }forEach ["Killed","Fired","HandleDamage","HandleHeal","FiredNear"]

View File

@ -34,9 +34,10 @@ if (_modType isEqualTo "Epoch") then
if (_dist < 800) then { _reward = _maxReward - (_maxReward / 2); _reward }; if (_dist < 800) then { _reward = _maxReward - (_maxReward / 2); _reward };
if (_dist > 800) then { _reward = _maxReward - (_maxReward / 4); _reward }; if (_dist > 800) then { _reward = _maxReward - (_maxReward / 4); _reward };
_reward=+(_kills*2); private _killstreakReward=+(_kills*2);
//diag_log format["fnd_rewardKiller:: _bonus returned will be %1",_reward]; //diag_log format["fnd_rewardKiller:: _bonus returned will be %1",_reward];
[_killer,_reward] call blck_fnc_giveTakeCrypto; [_killer,_reward + _killstreakReward] call blck_fnc_giveTakeCrypto;
[["showScore",[_reward,"",_kills],""],[_killer]] call blck_fnc_messageplayers;
}; };
}; };
@ -59,8 +60,8 @@ if (_modType isEqualTo "Exile") then
_killer setVariable ["ExileMoney", _money]; _killer setVariable ["ExileMoney", _money];
format["setAccountMoney:%1:%2", _money, (getPlayerUID _killer)] call ExileServer_system_database_query_fireAndForget; format["setAccountMoney:%1:%2", _money, (getPlayerUID _killer)] call ExileServer_system_database_query_fireAndForget;
_message = ["showFragRequest",_overallRespectChange]; _message = ["showFragRequest",_overallRespectChange];
//_message remoteExecCall ["ExileClient_system_network_dispatchIncomingMessage", (owner _killer)];
_killer call ExileServer_object_player_sendStatsUpdate; _killer call ExileServer_object_player_sendStatsUpdate;
[["showScore",[50,_distanceBonus,_kills]], [_killer]] call blck_fnc_messageplayers;
}; };
//_reward //_reward

View File

@ -0,0 +1,21 @@
/*
unit: Object - Object the event handler is assigned to.
selectionName: String - Name of the selection where the unit was damaged. "" for over-all structural damage, "?" for unknown selections.
damage: Number - Resulting level of damage for the selection.
source: Object - The source unit that caused the damage.
projectile: String - Classname of the projectile that caused inflicted the damage. ("" for unknown, such as falling damage.)
(Since Arma 3 v 1.49.131802)
hitPartIndex: Number - Hit part index of the hit point, -1 otherwise.
*/
private ["_unit","_killer","_group","_deleteAI_At"];
_unit = _this select 0;
_source = _this select 3;
if (isPlayer _source) then {
[_unit,_source] call GRMS_fnc_alertGroup;
};

View File

@ -0,0 +1,23 @@
/*
Send player a mesage regarding reward for the kill.
*/
params["_killer","_distanceBonus"];
private["_kills","_mt"];
_mt = call blck_fnc_getModType;
diag_log format["_fnc_sendRewardMessage:: -- >> _this = %1 and mod type = %2",_this, _mt];
if (_mt isEqualTo "Exile") then
{
_kills = getVariable [_killer,"ExileKills"];
private _killerMsg = [];
_killerMsg pushback "Enemy AI Killed";
_killerMsg pushback _newKillerScore;
_killerMsg pushback format["%1X Killstreak",_kills];
_killerMsg pushback format["Killstreak Bonus %1",(_kills*2)];
private _message = ["showFragRequest",_killerMsg];
diag_log format ["_fnc_rewardKiller:: -- >> _killer %1 _kills %2 _distanceBonus %3 _killerMsg = %1",_killer, _kills, _distanceBonus, _killerMsg];
_message remoteExecCall ["ExileClient_system_network_dispatchIncomingMessage", (owner _killer)];
};

View File

@ -19,6 +19,7 @@ blck_fnc_getModType = compileFinal preprocessFileLineNumbers "\q\addons\custom_
// Player-related functions // Player-related functions
blck_fnc_rewardKiller = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Units\GMS_fnc_rewardKiller.sqf"; blck_fnc_rewardKiller = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Units\GMS_fnc_rewardKiller.sqf";
blck_fnc_MessagePlayers = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Functions\GMS_fnc_AIM.sqf"; // Send messages to players regarding Missions blck_fnc_MessagePlayers = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Functions\GMS_fnc_AIM.sqf"; // Send messages to players regarding Missions
//blck_fnc_sendRewardMessage = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Functions\GMS_fnc_sendRewardMessage.sqf";
// Mission-related functions // Mission-related functions
blck_fnc_missionTimer = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Missions\GMS_fnc_missionTimer.sqf"; blck_fnc_missionTimer = compileFinal preprocessFileLineNumbers "\q\addons\custom_server\Compiles\Missions\GMS_fnc_missionTimer.sqf";

View File

@ -4,6 +4,9 @@ Loosely based on the AI mission system by blckeagls ver 2.0.2
Contributions by Narines: bug fixes, testing, 'fired' event handler Contributions by Narines: bug fixes, testing, 'fired' event handler
Ideas or code from that by Vampire and KiloSwiss have been used for certain functions. Ideas or code from that by Vampire and KiloSwiss have been used for certain functions.
11/20/16 Build 6.45 Build 16
Added Option to display mission information in Toasts (Exile Only).
11/16/16 Version 6.44 Build 15 11/16/16 Version 6.44 Build 15
Added parameters Added parameters
blck_blacklistTraderCities=true; // the locations of the Epoch/Exile trader cities will be pulled from the config and added to the location blacklist for the mission system. blck_blacklistTraderCities=true; // the locations of the Epoch/Exile trader cities will be pulled from the config and added to the location blacklist for the mission system.