mirror of
https://github.com/ClemensFischer/XAML-Map-Control.git
synced 2025-12-06 07:12:04 +01:00
MapProjection.Factory
This commit is contained in:
parent
c2a0fd836e
commit
616b2bf3f7
|
|
@ -194,7 +194,7 @@ namespace MapControl
|
||||||
{
|
{
|
||||||
var epsgCode = geoKeyDirectory[i + 3];
|
var epsgCode = geoKeyDirectory[i + 3];
|
||||||
|
|
||||||
return MapProjectionFactory.Instance.GetProjection($"EPSG:{epsgCode}");
|
return MapProjection.Parse($"EPSG:{epsgCode}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -31,6 +31,14 @@ namespace MapControl
|
||||||
public const double Wgs84Flattening = 1d / 298.257223563;
|
public const double Wgs84Flattening = 1d / 298.257223563;
|
||||||
public static readonly double Wgs84Eccentricity = Math.Sqrt((2d - Wgs84Flattening) * Wgs84Flattening);
|
public static readonly double Wgs84Eccentricity = Math.Sqrt((2d - Wgs84Flattening) * Wgs84Flattening);
|
||||||
|
|
||||||
|
private static MapProjectionFactory factory;
|
||||||
|
|
||||||
|
public static MapProjectionFactory Factory
|
||||||
|
{
|
||||||
|
get => factory ??= new MapProjectionFactory();
|
||||||
|
set => factory = value;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets the type of the projection.
|
/// Gets the type of the projection.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
@ -147,7 +155,7 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static MapProjection Parse(string crsId)
|
public static MapProjection Parse(string crsId)
|
||||||
{
|
{
|
||||||
return MapProjectionFactory.Instance.GetProjection(crsId);
|
return Factory.GetProjection(crsId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,14 +4,6 @@ namespace MapControl
|
||||||
{
|
{
|
||||||
public class MapProjectionFactory
|
public class MapProjectionFactory
|
||||||
{
|
{
|
||||||
private static MapProjectionFactory instance;
|
|
||||||
|
|
||||||
public static MapProjectionFactory Instance
|
|
||||||
{
|
|
||||||
get => instance ??= new MapProjectionFactory();
|
|
||||||
set => instance = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual MapProjection GetProjection(string crsId)
|
public virtual MapProjection GetProjection(string crsId)
|
||||||
{
|
{
|
||||||
MapProjection projection = null;
|
MapProjection projection = null;
|
||||||
|
|
@ -75,28 +67,14 @@ namespace MapControl
|
||||||
return projection ?? throw new NotSupportedException($"MapProjection \"{crsId}\" is not supported.");
|
return projection ?? throw new NotSupportedException($"MapProjection \"{crsId}\" is not supported.");
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual MapProjection GetProjection(int epsgCode)
|
public virtual MapProjection GetProjection(int epsgCode) => epsgCode switch
|
||||||
{
|
{
|
||||||
switch (epsgCode)
|
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),
|
||||||
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
var code when code >= Nad83UtmProjection.FirstZoneEpsgCode && code <= Nad83UtmProjection.LastZoneEpsgCode => new Nad83UtmProjection(epsgCode % 100),
|
||||||
return new Etrs89UtmProjection(epsgCode % 100);
|
var code when code >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && code <= Wgs84UtmProjection.LastZoneNorthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, true),
|
||||||
|
var code when code >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && code <= Wgs84UtmProjection.LastZoneSouthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, false),
|
||||||
case var c when c >= Nad27UtmProjection.FirstZoneEpsgCode && c <= Nad27UtmProjection.LastZoneEpsgCode:
|
_ => null
|
||||||
return new Nad27UtmProjection(epsgCode % 100);
|
};
|
||||||
|
|
||||||
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);
|
|
||||||
|
|
||||||
default:
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,64 +4,25 @@ namespace MapControl.Projections
|
||||||
{
|
{
|
||||||
public class GeoApiProjectionFactory : MapProjectionFactory
|
public class GeoApiProjectionFactory : MapProjectionFactory
|
||||||
{
|
{
|
||||||
public static GeoApiProjectionFactory GetInstance()
|
public Dictionary<int, string> CoordinateSystemWkts { get; } = [];
|
||||||
|
|
||||||
|
public override MapProjection GetProjection(string crsId) => crsId switch
|
||||||
{
|
{
|
||||||
if (!(Instance is GeoApiProjectionFactory factory))
|
MapControl.WebMercatorProjection.DefaultCrsId => new WebMercatorProjection(),
|
||||||
|
MapControl.WorldMercatorProjection.DefaultCrsId => new WorldMercatorProjection(),
|
||||||
|
MapControl.Wgs84AutoUtmProjection.DefaultCrsId => new Wgs84AutoUtmProjection(),
|
||||||
|
_ => base.GetProjection(crsId)
|
||||||
|
};
|
||||||
|
|
||||||
|
public override MapProjection GetProjection(int epsgCode) => epsgCode switch
|
||||||
{
|
{
|
||||||
factory = new GeoApiProjectionFactory();
|
var code when code >= Ed50UtmProjection.FirstZoneEpsgCode && code <= Ed50UtmProjection.LastZoneEpsgCode => new Ed50UtmProjection(epsgCode % 100),
|
||||||
Instance = factory;
|
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),
|
||||||
return factory;
|
var code when code >= Wgs84UtmProjection.FirstZoneNorthEpsgCode && code <= Wgs84UtmProjection.LastZoneNorthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, true),
|
||||||
}
|
var code when code >= Wgs84UtmProjection.FirstZoneSouthEpsgCode && code <= Wgs84UtmProjection.LastZoneSouthEpsgCode => new Wgs84UtmProjection(epsgCode % 100, false),
|
||||||
|
_ => CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt) ? new GeoApiProjection(wkt) : base.GetProjection(epsgCode)
|
||||||
public override MapProjection GetProjection(string crsId)
|
};
|
||||||
{
|
|
||||||
switch (crsId)
|
|
||||||
{
|
|
||||||
case MapControl.WebMercatorProjection.DefaultCrsId:
|
|
||||||
return new WebMercatorProjection();
|
|
||||||
|
|
||||||
case MapControl.WorldMercatorProjection.DefaultCrsId:
|
|
||||||
return new WorldMercatorProjection();
|
|
||||||
|
|
||||||
case MapControl.Wgs84AutoUtmProjection.DefaultCrsId:
|
|
||||||
return new Wgs84AutoUtmProjection();
|
|
||||||
|
|
||||||
default:
|
|
||||||
return base.GetProjection(crsId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override MapProjection GetProjection(int epsgCode)
|
|
||||||
{
|
|
||||||
switch (epsgCode)
|
|
||||||
{
|
|
||||||
case int c when c >= Ed50UtmProjection.FirstZoneEpsgCode && c <= Ed50UtmProjection.LastZoneEpsgCode:
|
|
||||||
return new Ed50UtmProjection(epsgCode % 100);
|
|
||||||
|
|
||||||
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
|
||||||
return new Etrs89UtmProjection(epsgCode % 100);
|
|
||||||
|
|
||||||
case var c when c >= Nad27UtmProjection.FirstZoneEpsgCode && c <= Nad27UtmProjection.LastZoneEpsgCode:
|
|
||||||
return new Nad27UtmProjection(epsgCode % 100);
|
|
||||||
|
|
||||||
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);
|
|
||||||
|
|
||||||
default:
|
|
||||||
return CoordinateSystemWkts.TryGetValue(epsgCode, out string wkt)
|
|
||||||
? new GeoApiProjection(wkt)
|
|
||||||
: base.GetProjection(epsgCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Dictionary<int, string> CoordinateSystemWkts { get; } = new Dictionary<int, string>();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFrameworks>net9.0-windows;net462</TargetFrameworks>
|
<TargetFrameworks>net9.0-windows;net462</TargetFrameworks>
|
||||||
<LangVersion Condition="'$(TargetFramework)'=='net462'">8.0</LangVersion>
|
<LangVersion Condition="'$(TargetFramework)'=='net462'">12.0</LangVersion>
|
||||||
<UseWPF>true</UseWPF>
|
<UseWPF>true</UseWPF>
|
||||||
<DefineConstants>WPF</DefineConstants>
|
<DefineConstants>WPF</DefineConstants>
|
||||||
<RootNamespace>MapControl.Projections</RootNamespace>
|
<RootNamespace>MapControl.Projections</RootNamespace>
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue