XAML-Map-Control/MapProjections/Shared/GeoApiProjectionFactory.cs

86 lines
2.9 KiB
C#
Raw Normal View History

2022-01-19 23:40:05 +01:00
// XAML Map Control - https://github.com/ClemensFischer/XAML-Map-Control
// <20> 2022 Clemens Fischer
// 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
{
private const int WorldMercator = 3395;
private const int WebMercator = 3857;
private const int Ed50UtmFirst = 23028;
private const int Ed50UtmLast = 23038;
private const int Etrs89UtmFirst = 25828;
private const int Etrs89UtmLast = 25838;
private const int Wgs84UtmNorthFirst = 32601;
private const int Wgs84UtmNorthLast = 32660;
private const int Wgs84UtmSouthFirst = 32701;
private const int Wgs84UtmSouthLast = 32760;
2022-01-21 00:17:01 +01:00
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
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
if (CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt))
2022-01-24 20:43:22 +01:00
{
projection = new GeoApiProjection(wkt);
}
else
{
switch (epsgCode)
2022-01-19 23:40:05 +01:00
{
case WorldMercator:
projection = new WorldMercatorProjection();
break;
case WebMercator:
projection = new WebMercatorProjection();
break;
case int c when c >= Ed50UtmFirst && c <= Ed50UtmLast:
projection = new Ed50UtmProjection(epsgCode % 100);
break;
case int c when c >= Etrs89UtmFirst && c <= Etrs89UtmLast:
projection = new Etrs89UtmProjection(epsgCode % 100);
break;
case int c when c >= Wgs84UtmNorthFirst && c <= Wgs84UtmNorthLast:
projection = new Wgs84UtmProjection(epsgCode % 100, true);
break;
case int c when c >= Wgs84UtmSouthFirst && c <= Wgs84UtmSouthLast:
projection = new Wgs84UtmProjection(epsgCode % 100, false);
break;
default:
break;
2022-01-19 23:40:05 +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
}
}