2025-02-27 18:46:32 +01:00
|
|
|
|
using System.Collections.Generic;
|
2022-01-24 20:43:22 +01:00
|
|
|
|
|
2022-01-19 23:40:05 +01:00
|
|
|
|
namespace MapControl.Projections
|
|
|
|
|
|
{
|
|
|
|
|
|
public class GeoApiProjectionFactory : MapProjectionFactory
|
|
|
|
|
|
{
|
2025-09-20 14:01:51 +02:00
|
|
|
|
public Dictionary<int, string> CoordinateSystemWkts { get; } = [];
|
2024-07-12 13:57:27 +02:00
|
|
|
|
|
2025-09-20 14:01:51 +02:00
|
|
|
|
public override MapProjection GetProjection(string crsId) => crsId switch
|
2022-01-19 23:40:05 +01:00
|
|
|
|
{
|
2025-09-20 14:01:51 +02:00
|
|
|
|
MapControl.WebMercatorProjection.DefaultCrsId => new WebMercatorProjection(),
|
|
|
|
|
|
MapControl.WorldMercatorProjection.DefaultCrsId => new WorldMercatorProjection(),
|
|
|
|
|
|
MapControl.Wgs84AutoUtmProjection.DefaultCrsId => new Wgs84AutoUtmProjection(),
|
|
|
|
|
|
_ => base.GetProjection(crsId)
|
|
|
|
|
|
};
|
2022-12-13 18:22:18 +01:00
|
|
|
|
|
2025-09-20 14:01:51 +02:00
|
|
|
|
public override MapProjection GetProjection(int epsgCode) => epsgCode switch
|
2024-07-12 14:14:42 +02:00
|
|
|
|
{
|
2025-09-20 14:01:51 +02:00
|
|
|
|
var code when code >= Ed50UtmProjection.FirstZoneEpsgCode && code <= Ed50UtmProjection.LastZoneEpsgCode => new Ed50UtmProjection(epsgCode % 100),
|
|
|
|
|
|
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),
|
|
|
|
|
|
_ => CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt) ? new GeoApiProjection(wkt) : base.GetProjection(epsgCode)
|
|
|
|
|
|
};
|
2022-01-19 23:40:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|