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

69 lines
3.5 KiB
C#
Raw Normal View History

2025-02-27 18:46:32 +01:00
using System.Collections.Generic;
2022-01-24 20:43:22 +01:00
2022-01-19 23:40:05 +01:00
namespace MapControl.Projections
{
2026-01-15 11:04:11 +01:00
public class ProjNetMapProjectionFactory : MapProjectionFactory
2022-01-19 23:40:05 +01:00
{
2026-01-13 09:07:44 +01:00
public Dictionary<int, string> CoordinateSystemWkts { get; } = new Dictionary<int, string>
{
2026-01-16 09:45:48 +01:00
{ 2056, WktConstants.ProjCsCh1903Lv95 },
{ 2100, WktConstants.ProjCsGgrs87 },
{ 2180, WktConstants.ProjCsEtrf2000Pl },
{ 3034, WktConstants.ProjCsEtrs89LccEurope },
{ 3035, WktConstants.ProjCsEtrs89LaeaEurope },
{ 4087, WktConstants.ProjCsWgs84 },
2026-01-16 09:45:48 +01:00
{ 4647, WktConstants.ProjCsEtrs89Utm32NzEN },
{ 4839, WktConstants.ProjCsEtrs89LccGermanyNE },
{ 5243, WktConstants.ProjCsEtrs89LccGermanyEN },
{ 21781, WktConstants.ProjCsCh1903Lv03 },
{ 29187, WktConstants.ProjCsSad69Utm17S },
{ 29188, WktConstants.ProjCsSad69Utm18S },
{ 29189, WktConstants.ProjCsSad69Utm19S },
{ 29190, WktConstants.ProjCsSad69Utm20S },
{ 29191, WktConstants.ProjCsSad69Utm21S },
{ 29192, WktConstants.ProjCsSad69Utm22S },
{ 29193, WktConstants.ProjCsSad69Utm23S },
2026-01-13 09:07:44 +01:00
};
2024-07-12 13:57:27 +02:00
2026-01-20 23:05:33 +01:00
public override MapProjection GetProjection(string crsId)
2022-01-19 23:40:05 +01:00
{
2026-01-21 12:08:12 +01:00
return crsId switch
2026-01-20 23:05:33 +01:00
{
MapControl.WebMercatorProjection.DefaultCrsId => new WebMercatorProjection(),
MapControl.WorldMercatorProjection.DefaultCrsId => new WorldMercatorProjection(),
MapControl.Wgs84UpsNorthProjection.DefaultCrsId => new Wgs84UpsNorthProjection(),
MapControl.Wgs84UpsSouthProjection.DefaultCrsId => new Wgs84UpsSouthProjection(),
MapControl.Wgs84AutoUtmProjection.DefaultCrsId => new Wgs84AutoUtmProjection(),
MapControl.OrthographicProjection.DefaultCrsId => new Wgs84OrthographicProjection(),
MapControl.StereographicProjection.DefaultCrsId => new Wgs84StereographicProjection(),
2026-01-21 12:08:12 +01:00
_ => GetProjectionFromEpsgCode(crsId) ?? base.GetProjection(crsId)
2026-01-20 23:05:33 +01:00
};
}
2026-01-21 12:08:12 +01:00
public override MapProjection GetProjection(int epsgCode)
2024-07-12 14:14:42 +02:00
{
2026-01-21 12:08:12 +01:00
if (CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt))
{
return new ProjNetMapProjection(wkt);
}
return epsgCode switch
{
var c when c is >= Ed50UtmProjection.FirstZoneEpsgCode
and <= Ed50UtmProjection.LastZoneEpsgCode => new Ed50UtmProjection(c % 100),
var c when c is >= Etrs89UtmProjection.FirstZoneEpsgCode
and <= Etrs89UtmProjection.LastZoneEpsgCode => new Etrs89UtmProjection(c % 100),
var c when c is >= Nad27UtmProjection.FirstZoneEpsgCode
and <= Nad27UtmProjection.LastZoneEpsgCode => new Nad27UtmProjection(c % 100),
var c when c is >= Nad83UtmProjection.FirstZoneEpsgCode
and <= Nad83UtmProjection.LastZoneEpsgCode => new Nad83UtmProjection(c % 100),
var c when c is >= Wgs84UtmProjection.FirstZoneNorthEpsgCode
and <= Wgs84UtmProjection.LastZoneNorthEpsgCode => new Wgs84UtmProjection(c % 100, Hemisphere.North),
var c when c is >= Wgs84UtmProjection.FirstZoneSouthEpsgCode
and <= Wgs84UtmProjection.LastZoneSouthEpsgCode => new Wgs84UtmProjection(c % 100, Hemisphere.South),
_ => base.GetProjection(epsgCode)
};
}
2022-01-19 23:40:05 +01:00
}
}