improved stratis position converter

This commit is contained in:
Valmo Trindade
2025-02-24 01:39:27 -03:00
parent 0ffdeffef8
commit d863a1fad0

View File

@@ -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; // SW corner (used as origin)
_playerLongitude = _playerPosition select 1; private _SW_lat = 39.456910;
private _SW_lon = 24.940792;
_playerMaxLongitude = 8190; // SE corner
_playerMaxLatitude = 8190; private _SE_lat = 39.459151;
private _SE_lon = 25.083440;
_MapMaxLatitude = 25.080683; // NW corner
_MapMinLatitude = 24.940569; private _NW_lat = 39.567714;
private _NW_lon = 24.937866;
_MapMaxLongitude = 39.569794; private _edgeSE_lat = _SE_lat - _SW_lat;
_MapMinLongitude = 39.456881; private _edgeSE_lon = _SE_lon - _SW_lon;
_LongitudeDifference = _MapMaxLongitude - _MapMinLongitude; private _edgeNW_lat = _NW_lat - _SW_lat;
_LatitudeDifference = _MapMaxLatitude - _MapMinLatitude; private _edgeNW_lon = _NW_lon - _SW_lon;
_RealLongitude = (_playerLongitude / _playerMaxLongitude) * _LongitudeDifference + _MapMinLongitude; private _fx = _longitudeInGame / _mapWidth;
_RealLatitude = (_playerLatitude / _playerMaxLatitude) * _LatitudeDifference + _MapMinLatitude; private _fy = _latitudeInGame / _mapHeight;
[_RealLongitude, _RealLatitude, _playerPosition select 2] private _realLat = _SW_lat + (_fx * _edgeSE_lat) + (_fy * _edgeNW_lat);
private _realLon = _SW_lon + (_fx * _edgeSE_lon) + (_fy * _edgeNW_lon);
[_realLat, _realLon, _altitude]