2025-02-27 18:46:32 +01:00
|
|
|
|
using System;
|
2024-09-12 15:48:20 +02:00
|
|
|
|
|
2022-01-19 16:43:00 +01:00
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
public class MapProjectionFactory
|
|
|
|
|
|
{
|
2024-07-12 14:14:42 +02:00
|
|
|
|
public virtual MapProjection GetProjection(string crsId)
|
2022-01-19 16:43:00 +01:00
|
|
|
|
{
|
2024-09-12 15:48:20 +02:00
|
|
|
|
MapProjection projection = null;
|
|
|
|
|
|
|
2024-07-12 14:14:42 +02:00
|
|
|
|
switch (crsId)
|
2022-01-19 16:43:00 +01:00
|
|
|
|
{
|
2024-07-12 14:14:42 +02:00
|
|
|
|
case WebMercatorProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new WebMercatorProjection();
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
2024-07-12 14:14:42 +02:00
|
|
|
|
case WorldMercatorProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new WorldMercatorProjection();
|
|
|
|
|
|
break;
|
2024-07-12 14:14:42 +02:00
|
|
|
|
|
|
|
|
|
|
case EquirectangularProjection.DefaultCrsId:
|
2024-08-03 23:42:09 +02:00
|
|
|
|
case "CRS:84":
|
|
|
|
|
|
case "EPSG:4087":
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new EquirectangularProjection(crsId);
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
2024-07-12 14:14:42 +02:00
|
|
|
|
case UpsNorthProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new UpsNorthProjection();
|
|
|
|
|
|
break;
|
2022-12-13 18:22:18 +01:00
|
|
|
|
|
2024-07-12 14:14:42 +02:00
|
|
|
|
case UpsSouthProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new UpsSouthProjection();
|
|
|
|
|
|
break;
|
2022-12-13 18:22:18 +01:00
|
|
|
|
|
2024-09-10 22:04:44 +02:00
|
|
|
|
case Wgs84AutoUtmProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new Wgs84AutoUtmProjection();
|
|
|
|
|
|
break;
|
2024-09-10 22:04:44 +02:00
|
|
|
|
|
2022-01-19 16:43:00 +01:00
|
|
|
|
case OrthographicProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new OrthographicProjection();
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
|
|
|
|
|
case AutoEquirectangularProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new AutoEquirectangularProjection();
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
|
|
|
|
|
case GnomonicProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new GnomonicProjection();
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
|
|
|
|
|
case StereographicProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new StereographicProjection();
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
|
2024-07-12 13:57:27 +02:00
|
|
|
|
case AzimuthalEquidistantProjection.DefaultCrsId:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
projection = new AzimuthalEquidistantProjection();
|
|
|
|
|
|
break;
|
2022-01-22 20:32:17 +01:00
|
|
|
|
|
2024-09-10 22:04:44 +02:00
|
|
|
|
default:
|
2024-09-12 15:48:20 +02:00
|
|
|
|
if (crsId.StartsWith("EPSG:") && int.TryParse(crsId.Substring(5), out int epsgCode))
|
|
|
|
|
|
{
|
|
|
|
|
|
projection = GetProjection(epsgCode);
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
2024-09-10 22:04:44 +02:00
|
|
|
|
}
|
2024-09-12 15:48:20 +02:00
|
|
|
|
|
|
|
|
|
|
return projection ?? throw new NotSupportedException($"MapProjection \"{crsId}\" is not supported.");
|
2024-09-10 22:04:44 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-20 14:01:51 +02:00
|
|
|
|
public virtual MapProjection GetProjection(int epsgCode) => epsgCode switch
|
2024-09-10 22:04:44 +02:00
|
|
|
|
{
|
2025-09-20 14:01:51 +02:00
|
|
|
|
var code when code >= Etrs89UtmProjection.FirstZoneEpsgCode && code <= Etrs89UtmProjection.LastZoneEpsgCode => new Etrs89UtmProjection(epsgCode % 100),
|
|
|
|
|
|
var code when code >= Nad27UtmProjection.FirstZoneEpsgCode && code <= Nad27UtmProjection.LastZoneEpsgCode => new Nad27UtmProjection(epsgCode % 100),
|
|
|
|
|
|
var code when code >= Nad83UtmProjection.FirstZoneEpsgCode && code <= Nad83UtmProjection.LastZoneEpsgCode => new Nad83UtmProjection(epsgCode % 100),
|
|
|
|
|
|
var code when code >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && code <= Wgs84UtmProjection.LastZoneNorthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, true),
|
|
|
|
|
|
var code when code >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && code <= Wgs84UtmProjection.LastZoneSouthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, false),
|
|
|
|
|
|
_ => null
|
|
|
|
|
|
};
|
2022-01-19 16:43:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|