diff --git a/addons/main/CfgFunctions.hpp b/addons/main/CfgFunctions.hpp index 3c3944e..613fd97 100644 --- a/addons/main/CfgFunctions.hpp +++ b/addons/main/CfgFunctions.hpp @@ -49,6 +49,9 @@ class CfgFunctions { class convert_to_altis { file = "\armatak\armatak\armatak_main\functions\map\fn_convert_to_altis.sqf"; }; + class convert_to_bukovina { + file = "\armatak\armatak\armatak_main\functions\map\fn_convert_to_bukovina.sqf"; + }; class convert_to_chernarus { file = "\armatak\armatak\armatak_main\functions\map\fn_convert_to_chernarus.sqf"; }; diff --git a/addons/main/functions/map/fn_convert_location.sqf b/addons/main/functions/map/fn_convert_location.sqf index d33bad6..9ffdcf4 100644 --- a/addons/main/functions/map/fn_convert_location.sqf +++ b/addons/main/functions/map/fn_convert_location.sqf @@ -23,6 +23,9 @@ switch (toLower worldName) do { case "chernarus": { _realLocation = _position call armatak_fnc_convert_to_chernarus; }; + case "bukovina": { + _realLocation = _position call armatak_fnc_convert_to_bukovina; + }; case "mountains_acr": { _realLocation = _position call armatak_fnc_convert_to_takistan_montains; }; diff --git a/addons/main/functions/map/fn_convert_to_bukovina.sqf b/addons/main/functions/map/fn_convert_to_bukovina.sqf new file mode 100644 index 0000000..bd0462e --- /dev/null +++ b/addons/main/functions/map/fn_convert_to_bukovina.sqf @@ -0,0 +1,30 @@ +params ["_longitudeInGame", "_latitudeInGame", "_altitude"]; + +private _mapWidth = 3840; +private _mapHeight = 3840; + +// SW corner (used as origin) +private _SW_lat = 50.719010; +private _SW_lon = 14.044244; + +// SE corner +private _SE_lat = 50.723739; +private _SE_lon = 14.098075; + +// NW corner +private _NW_lat = 50.753409; +private _NW_lon = 14.036654; + +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