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

43 lines
2.6 KiB
C#
Raw Normal View History

2025-02-27 18:46:32 +01:00
using System;
2022-01-19 16:43:00 +01:00
namespace MapControl
{
public class MapProjectionFactory
{
2024-07-12 14:14:42 +02:00
public virtual MapProjection GetProjection(string crsId)
2022-01-19 16:43:00 +01:00
{
2026-01-20 23:05:33 +01:00
MapProjection projection = crsId switch
2022-01-19 16:43:00 +01:00
{
2026-01-20 23:05:33 +01:00
WebMercatorProjection.DefaultCrsId => new WebMercatorProjection(),
WorldMercatorProjection.DefaultCrsId => new WorldMercatorProjection(),
EquirectangularProjection.DefaultCrsId or "CRS:84" or "EPSG:4087" => new EquirectangularProjection(crsId),
Wgs84UpsNorthProjection.DefaultCrsId => new Wgs84UpsNorthProjection(),
Wgs84UpsSouthProjection.DefaultCrsId => new Wgs84UpsSouthProjection(),
Wgs84AutoUtmProjection.DefaultCrsId => new Wgs84AutoUtmProjection(),
Wgs84AutoTmProjection.DefaultCrsId => new Wgs84AutoTmProjection(),
OrthographicProjection.DefaultCrsId => new OrthographicProjection(),
AutoEquirectangularProjection.DefaultCrsId => new AutoEquirectangularProjection(),
GnomonicProjection.DefaultCrsId => new GnomonicProjection(),
StereographicProjection.DefaultCrsId => new StereographicProjection(),
AzimuthalEquidistantProjection.DefaultCrsId => new AzimuthalEquidistantProjection(),
_ => GetProjectionFromEpsgCode(crsId),
};
return projection ?? throw new NotSupportedException($"MapProjection \"{crsId}\" is not supported.");
}
2026-01-20 23:05:33 +01:00
public MapProjection GetProjectionFromEpsgCode(string crsId) =>
crsId.StartsWith("EPSG:") && int.TryParse(crsId.Substring(5), out int epsgCode) ? GetProjection(epsgCode) : null;
2025-09-20 14:01:51 +02:00
public virtual MapProjection GetProjection(int epsgCode) => epsgCode switch
{
2025-09-20 14:01:51 +02:00
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),
2026-01-10 16:21:55 +01:00
var code when code >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && code <= Wgs84UtmProjection.LastZoneNorthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, Hemisphere.North),
var code when code >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && code <= Wgs84UtmProjection.LastZoneSouthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, Hemisphere.South),
2025-09-20 14:01:51 +02:00
_ => null
};
2022-01-19 16:43:00 +01:00
}
}