2023-01-03 15:12:53 +01:00
|
|
|
|
// XAML Map Control - https://github.com/ClemensFischer/XAML-Map-Control
|
|
|
|
|
|
// Copyright © 2023 Clemens Fischer
|
2022-01-19 23:40:05 +01:00
|
|
|
|
// Licensed under the Microsoft Public License (Ms-PL)
|
|
|
|
|
|
|
2022-01-24 20:43:22 +01:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
|
2022-01-19 23:40:05 +01:00
|
|
|
|
namespace MapControl.Projections
|
|
|
|
|
|
{
|
|
|
|
|
|
public class GeoApiProjectionFactory : MapProjectionFactory
|
|
|
|
|
|
{
|
2022-01-24 21:00:20 +01:00
|
|
|
|
public Dictionary<int, string> CoordinateSystemWkts { get; } = new Dictionary<int, string>();
|
2022-01-24 20:43:22 +01:00
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
public override MapProjection GetProjection(int epsgCode)
|
2022-01-19 23:40:05 +01:00
|
|
|
|
{
|
2022-01-21 00:17:01 +01:00
|
|
|
|
MapProjection projection = null;
|
2022-01-19 23:40:05 +01:00
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
if (CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt))
|
2022-01-24 20:43:22 +01:00
|
|
|
|
{
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new GeoApiProjection(wkt);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
switch (epsgCode)
|
2022-01-19 23:40:05 +01:00
|
|
|
|
{
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case WorldMercatorProjection.DefaultEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new WorldMercatorProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case WebMercatorProjection.DefaultEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new WebMercatorProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case int c when c >= Ed50UtmProjection.FirstZoneEpsgCode && c <= Ed50UtmProjection.LastZoneEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new Ed50UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new Etrs89UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case var c when c >= Nad27UtmProjection.FirstZoneEpsgCode && c <= Nad27UtmProjection.LastZoneEpsgCode:
|
|
|
|
|
|
projection = new Nad27UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case var c when c >= Nad83UtmProjection.FirstZoneEpsgCode && c <= Nad83UtmProjection.LastZoneEpsgCode:
|
|
|
|
|
|
projection = new Nad83UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case var c when c >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && c <= Wgs84UtmProjection.LastZoneNorthEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new Wgs84UtmProjection(epsgCode % 100, true);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case var c when c >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && c <= Wgs84UtmProjection.LastZoneSouthEpsgCode:
|
2022-12-13 18:22:18 +01:00
|
|
|
|
projection = new Wgs84UtmProjection(epsgCode % 100, false);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
break;
|
2022-01-19 23:40:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
return projection ?? base.GetProjection(epsgCode);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public override MapProjection GetProjection(string crsId)
|
|
|
|
|
|
{
|
|
|
|
|
|
MapProjection projection = null;
|
|
|
|
|
|
|
|
|
|
|
|
switch (crsId)
|
|
|
|
|
|
{
|
|
|
|
|
|
case Wgs84AutoUtmProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new Wgs84AutoUtmProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-01-22 20:32:17 +01:00
|
|
|
|
return projection ?? base.GetProjection(crsId);
|
2022-01-21 00:17:01 +01:00
|
|
|
|
}
|
2022-01-19 23:40:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|