From d863a1fad0795ff62c727d1adcfd6e30d7c5f9de Mon Sep 17 00:00:00 2001 From: Valmo Trindade Date: Mon, 24 Feb 2025 01:39:27 -0300 Subject: [PATCH] improved stratis position converter --- .../functions/map/fn_convert_to_stratis.sqf | 37 +++++++++++-------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/addons/main/functions/map/fn_convert_to_stratis.sqf b/addons/main/functions/map/fn_convert_to_stratis.sqf index e62bf69..6968819 100644 --- a/addons/main/functions/map/fn_convert_to_stratis.sqf +++ b/addons/main/functions/map/fn_convert_to_stratis.sqf @@ -1,23 +1,30 @@ -params["_latitude", "_longitude", "_altitude"]; +params ["_longitudeInGame", "_latitudeInGame", "_altitude"]; -_playerPosition = [_latitude, _longitude, _altitude]; +private _mapWidth = 30720; +private _mapHeight = 30720; -_playerLatitude = _playerPosition select 0; -_playerLongitude = _playerPosition select 1; +// SW corner (used as origin) +private _SW_lat = 39.456910; +private _SW_lon = 24.940792; -_playerMaxLongitude = 8190; -_playerMaxLatitude = 8190; +// SE corner +private _SE_lat = 39.459151; +private _SE_lon = 25.083440; -_MapMaxLatitude = 25.080683; -_MapMinLatitude = 24.940569; +// NW corner +private _NW_lat = 39.567714; +private _NW_lon = 24.937866; -_MapMaxLongitude = 39.569794; -_MapMinLongitude = 39.456881; +private _edgeSE_lat = _SE_lat - _SW_lat; +private _edgeSE_lon = _SE_lon - _SW_lon; -_LongitudeDifference = _MapMaxLongitude - _MapMinLongitude; -_LatitudeDifference = _MapMaxLatitude - _MapMinLatitude; +private _edgeNW_lat = _NW_lat - _SW_lat; +private _edgeNW_lon = _NW_lon - _SW_lon; -_RealLongitude = (_playerLongitude / _playerMaxLongitude) * _LongitudeDifference + _MapMinLongitude; -_RealLatitude = (_playerLatitude / _playerMaxLatitude) * _LatitudeDifference + _MapMinLatitude; +private _fx = _longitudeInGame / _mapWidth; +private _fy = _latitudeInGame / _mapHeight; -[_RealLongitude, _RealLatitude, _playerPosition select 2] \ No newline at end of file +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