XAML-Map-Control/MapControl/Shared/MapProjectionFactory.cs

107 lines
3.9 KiB
C#
Raw Normal View History

2022-01-19 16:43:00 +01:00
// XAML Map Control - https://github.com/ClemensFischer/XAML-Map-Control
2025-01-01 18:57:55 +01:00
// Copyright © Clemens Fischer
2022-01-19 16:43:00 +01:00
// Licensed under the Microsoft Public License (Ms-PL)
using System;
2022-01-19 16:43:00 +01:00
namespace MapControl
{
public class MapProjectionFactory
{
private static MapProjectionFactory instance;
public static MapProjectionFactory Instance
{
get => instance ?? (instance = new MapProjectionFactory());
set => instance = value;
}
2024-07-12 14:14:42 +02:00
public virtual MapProjection GetProjection(string crsId)
2022-01-19 16:43:00 +01: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:
projection = new WebMercatorProjection();
break;
2022-01-19 16:43:00 +01:00
2024-07-12 14:14:42 +02:00
case WorldMercatorProjection.DefaultCrsId:
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":
projection = new EquirectangularProjection(crsId);
break;
2022-01-19 16:43:00 +01:00
2024-07-12 14:14:42 +02:00
case UpsNorthProjection.DefaultCrsId:
projection = new UpsNorthProjection();
break;
2024-07-12 14:14:42 +02:00
case UpsSouthProjection.DefaultCrsId:
projection = new UpsSouthProjection();
break;
case Wgs84AutoUtmProjection.DefaultCrsId:
projection = new Wgs84AutoUtmProjection();
break;
2022-01-19 16:43:00 +01:00
case OrthographicProjection.DefaultCrsId:
projection = new OrthographicProjection();
break;
2022-01-19 16:43:00 +01:00
case AutoEquirectangularProjection.DefaultCrsId:
projection = new AutoEquirectangularProjection();
break;
2022-01-19 16:43:00 +01:00
case GnomonicProjection.DefaultCrsId:
projection = new GnomonicProjection();
break;
2022-01-19 16:43:00 +01:00
case StereographicProjection.DefaultCrsId:
projection = new StereographicProjection();
break;
2022-01-19 16:43:00 +01:00
2024-07-12 13:57:27 +02:00
case AzimuthalEquidistantProjection.DefaultCrsId:
projection = new AzimuthalEquidistantProjection();
break;
2022-01-22 20:32:17 +01:00
default:
if (crsId.StartsWith("EPSG:") && int.TryParse(crsId.Substring(5), out int epsgCode))
{
projection = GetProjection(epsgCode);
}
break;
}
return projection ?? throw new NotSupportedException($"MapProjection \"{crsId}\" is not supported.");
}
public virtual MapProjection GetProjection(int epsgCode)
{
switch (epsgCode)
{
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
return new Etrs89UtmProjection(epsgCode % 100);
2024-09-12 15:49:10 +02:00
case var c when c >= Nad27UtmProjection.FirstZoneEpsgCode && c <= Nad27UtmProjection.LastZoneEpsgCode:
return new Nad27UtmProjection(epsgCode % 100);
2024-09-11 23:36:21 +02:00
case var c when c >= Nad83UtmProjection.FirstZoneEpsgCode && c <= Nad83UtmProjection.LastZoneEpsgCode:
return new Nad83UtmProjection(epsgCode % 100);
case var c when c >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && c <= Wgs84UtmProjection.LastZoneNorthEpsgCode:
return new Wgs84UtmProjection(epsgCode % 100, true);
case var c when c >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && c <= Wgs84UtmProjection.LastZoneSouthEpsgCode:
return new Wgs84UtmProjection(epsgCode % 100, false);
2024-07-12 14:14:42 +02:00
default:
return null;
}
}
2022-01-19 16:43:00 +01:00
}
}