diff --git a/addons/main/CfgFunctions.hpp b/addons/main/CfgFunctions.hpp index 0be0673..b449a0b 100644 --- a/addons/main/CfgFunctions.hpp +++ b/addons/main/CfgFunctions.hpp @@ -64,6 +64,9 @@ class CfgFunctions { class convert_to_takistan_montains { file = "\armatak\armatak\armatak_main\functions\map\fn_convert_to_takistan_montains.sqf"; }; + class convert_to_chernarus { + file = "\armatak\armatak\armatak_main\functions\map\fn_convert_to_chernarus.sqf"; + }; }; }; }; \ No newline at end of file diff --git a/addons/main/functions/map/fn_convert_location.sqf b/addons/main/functions/map/fn_convert_location.sqf index e5e2a8a..d33bad6 100644 --- a/addons/main/functions/map/fn_convert_location.sqf +++ b/addons/main/functions/map/fn_convert_location.sqf @@ -20,6 +20,9 @@ switch (toLower worldName) do { case "cucui": { _realLocation = _position call armatak_fnc_convert_to_cucui; }; + case "chernarus": { + _realLocation = _position call armatak_fnc_convert_to_chernarus; + }; case "mountains_acr": { _realLocation = _position call armatak_fnc_convert_to_takistan_montains; }; diff --git a/addons/main/functions/map/fn_convert_to_chernarus.sqf b/addons/main/functions/map/fn_convert_to_chernarus.sqf new file mode 100644 index 0000000..b32fa29 --- /dev/null +++ b/addons/main/functions/map/fn_convert_to_chernarus.sqf @@ -0,0 +1,30 @@ +params ["_longitudeInGame", "_latitudeInGame", "_altitude"]; + +private _mapWidth = 15360; +private _mapHeight = 15360; + +// SW corner (used as origin) +private _SW_lat = 50.63894; +private _SW_lon = 14.01891; + +// SE corner +private _SE_lat = 50.65766; +private _SE_lon = 14.23361; + +// NW corner +private _NW_lat = 50.77697; +private _NW_lon = 13.98893; + +private _edgeSE_lat = _SE_lat - _SW_lat; +private _edgeSE_lon = _SE_lon - _SW_lon; + +private _edgeNW_lat = _NW_lat - _SW_lat; +private _edgeNW_lon = _NW_lon - _SW_lon; + +private _fx = _longitudeInGame / _mapWidth; +private _fy = _latitudeInGame / _mapHeight; + +private _realLat = _SW_lat + (_fx * _edgeSE_lat) + (_fy * _edgeNW_lat); +private _realLon = _SW_lon + (_fx * _edgeSE_lon) + (_fy * _edgeNW_lon); + +[_realLat, _realLon, _altitude] \ No newline at end of file