2022-01-19 16:43:00 +01:00
|
|
|
|
// XAML Map Control - https://github.com/ClemensFischer/XAML-Map-Control
|
|
|
|
|
|
// © 2022 Clemens Fischer
|
|
|
|
|
|
// Licensed under the Microsoft Public License (Ms-PL)
|
|
|
|
|
|
|
|
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
public class MapProjectionFactory
|
|
|
|
|
|
{
|
2022-12-13 18:22:18 +01:00
|
|
|
|
public virtual MapProjection GetProjection(int epsgCode)
|
2022-01-19 16:43:00 +01:00
|
|
|
|
{
|
|
|
|
|
|
MapProjection projection = null;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
switch (epsgCode)
|
2022-01-19 16:43:00 +01:00
|
|
|
|
{
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case WorldMercatorProjection.DefaultEpsgCode:
|
2022-01-19 16:43:00 +01:00
|
|
|
|
projection = new WorldMercatorProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case WebMercatorProjection.DefaultEpsgCode:
|
2022-01-19 16:43:00 +01:00
|
|
|
|
projection = new WebMercatorProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case EquirectangularProjection.DefaultEpsgCode:
|
2022-01-19 16:43:00 +01:00
|
|
|
|
projection = new EquirectangularProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case UpsNorthProjection.DefaultEpsgCode:
|
|
|
|
|
|
projection = new UpsNorthProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case UpsSouthProjection.DefaultEpsgCode:
|
|
|
|
|
|
projection = new UpsSouthProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
|
|
|
|
|
projection = new Etrs89UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 23:25:05 +01:00
|
|
|
|
case var c when c >= Nad27UtmProjection.FirstZoneEpsgCode && c <= Nad27UtmProjection.LastZoneEpsgCode:
|
|
|
|
|
|
projection = new Nad27UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-14 18:02:19 +01:00
|
|
|
|
case var c when c >= Nad83UtmProjection.FirstZoneEpsgCode && c <= Nad83UtmProjection.LastZoneEpsgCode:
|
|
|
|
|
|
projection = new Nad83UtmProjection(epsgCode % 100);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case var c when c >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && c <= Wgs84UtmProjection.LastZoneNorthEpsgCode:
|
|
|
|
|
|
projection = new Wgs84UtmProjection(epsgCode % 100, true);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case var c when c >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && c <= Wgs84UtmProjection.LastZoneSouthEpsgCode:
|
|
|
|
|
|
projection = new Wgs84UtmProjection(epsgCode % 100, false);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return projection;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public virtual MapProjection GetProjection(string crsId)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (crsId.StartsWith("EPSG:") && int.TryParse(crsId.Substring(5), out int epsgCode))
|
|
|
|
|
|
{
|
|
|
|
|
|
return GetProjection(epsgCode);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MapProjection projection = null;
|
|
|
|
|
|
|
|
|
|
|
|
switch (crsId)
|
|
|
|
|
|
{
|
|
|
|
|
|
case Wgs84AutoUtmProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new Wgs84AutoUtmProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-01-19 16:43:00 +01:00
|
|
|
|
case OrthographicProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new OrthographicProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case AutoEquirectangularProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new AutoEquirectangularProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case GnomonicProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new GnomonicProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case StereographicProjection.DefaultCrsId:
|
|
|
|
|
|
projection = new StereographicProjection();
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
2022-12-13 18:22:18 +01:00
|
|
|
|
case "AUTO2:97003": // proprietary CRS ID
|
2022-03-05 18:40:57 +01:00
|
|
|
|
projection = new AzimuthalEquidistantProjection(crsId);
|
2022-01-19 16:43:00 +01:00
|
|
|
|
break;
|
2022-01-22 20:32:17 +01:00
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
break;
|
2022-01-19 16:43:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return projection;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|