mirror of
https://github.com/ClemensFischer/XAML-Map-Control.git
synced 2025-12-06 07:12:04 +01:00
EPSG Codes & CRS IDs
This commit is contained in:
parent
ce6f190bf1
commit
03c18d5126
|
|
@ -17,9 +17,9 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class EquirectangularProjection : MapProjection
|
public class EquirectangularProjection : MapProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 4326;
|
public const string DefaultCrsId = "EPSG:4326";
|
||||||
|
|
||||||
public EquirectangularProjection(string crsId = "EPSG:4326")
|
public EquirectangularProjection(string crsId = DefaultCrsId)
|
||||||
{
|
{
|
||||||
Type = MapProjectionType.NormalCylindrical;
|
Type = MapProjectionType.NormalCylindrical;
|
||||||
CrsId = crsId;
|
CrsId = crsId;
|
||||||
|
|
|
||||||
|
|
@ -14,46 +14,25 @@ namespace MapControl
|
||||||
set => instance = value;
|
set => instance = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual MapProjection GetProjection(int epsgCode)
|
|
||||||
{
|
|
||||||
switch (epsgCode)
|
|
||||||
{
|
|
||||||
case WorldMercatorProjection.EpsgCode:
|
|
||||||
return new WorldMercatorProjection();
|
|
||||||
|
|
||||||
case WebMercatorProjection.EpsgCode:
|
|
||||||
return new WebMercatorProjection();
|
|
||||||
|
|
||||||
case EquirectangularProjection.EpsgCode:
|
|
||||||
return new EquirectangularProjection();
|
|
||||||
|
|
||||||
case UpsNorthProjection.EpsgCode:
|
|
||||||
return new UpsNorthProjection();
|
|
||||||
|
|
||||||
case UpsSouthProjection.EpsgCode:
|
|
||||||
return new UpsSouthProjection();
|
|
||||||
|
|
||||||
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
|
||||||
return new Etrs89UtmProjection(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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual MapProjection GetProjection(string crsId)
|
public virtual MapProjection GetProjection(string crsId)
|
||||||
{
|
{
|
||||||
switch (crsId)
|
switch (crsId)
|
||||||
{
|
{
|
||||||
|
case WebMercatorProjection.DefaultCrsId:
|
||||||
|
return new WebMercatorProjection();
|
||||||
|
|
||||||
|
case WorldMercatorProjection.DefaultCrsId:
|
||||||
|
return new WorldMercatorProjection();
|
||||||
|
|
||||||
|
case EquirectangularProjection.DefaultCrsId:
|
||||||
|
return new EquirectangularProjection();
|
||||||
|
|
||||||
|
case UpsNorthProjection.DefaultCrsId:
|
||||||
|
return new UpsNorthProjection();
|
||||||
|
|
||||||
|
case UpsSouthProjection.DefaultCrsId:
|
||||||
|
return new UpsSouthProjection();
|
||||||
|
|
||||||
case Wgs84AutoUtmProjection.DefaultCrsId:
|
case Wgs84AutoUtmProjection.DefaultCrsId:
|
||||||
return new Wgs84AutoUtmProjection();
|
return new Wgs84AutoUtmProjection();
|
||||||
|
|
||||||
|
|
@ -78,5 +57,26 @@ namespace MapControl
|
||||||
: null;
|
: null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public virtual MapProjection GetProjection(int epsgCode)
|
||||||
|
{
|
||||||
|
switch (epsgCode)
|
||||||
|
{
|
||||||
|
case var c when c >= Etrs89UtmProjection.FirstZoneEpsgCode && c <= Etrs89UtmProjection.LastZoneEpsgCode:
|
||||||
|
return new Etrs89UtmProjection(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;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -117,9 +117,9 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class UpsNorthProjection : PolarStereographicProjection
|
public class UpsNorthProjection : PolarStereographicProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 32661;
|
public const string DefaultCrsId = "EPSG:32661";
|
||||||
|
|
||||||
public UpsNorthProjection(string crsId = "EPSG:32661")
|
public UpsNorthProjection(string crsId = DefaultCrsId)
|
||||||
{
|
{
|
||||||
CrsId = crsId;
|
CrsId = crsId;
|
||||||
IsNorth = true;
|
IsNorth = true;
|
||||||
|
|
@ -131,9 +131,9 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class UpsSouthProjection : PolarStereographicProjection
|
public class UpsSouthProjection : PolarStereographicProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 32761;
|
public const string DefaultCrsId = "EPSG:32761";
|
||||||
|
|
||||||
public UpsSouthProjection(string crsId = "EPSG:32761")
|
public UpsSouthProjection(string crsId = DefaultCrsId)
|
||||||
{
|
{
|
||||||
CrsId = crsId;
|
CrsId = crsId;
|
||||||
IsNorth = false;
|
IsNorth = false;
|
||||||
|
|
|
||||||
|
|
@ -15,9 +15,9 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class WebMercatorProjection : MapProjection
|
public class WebMercatorProjection : MapProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 3857;
|
public const string DefaultCrsId = "EPSG:3857";
|
||||||
|
|
||||||
public WebMercatorProjection(string crsId = "EPSG:3857")
|
public WebMercatorProjection(string crsId = DefaultCrsId)
|
||||||
{
|
{
|
||||||
Type = MapProjectionType.WebMercator;
|
Type = MapProjectionType.WebMercator;
|
||||||
CrsId = crsId;
|
CrsId = crsId;
|
||||||
|
|
|
||||||
|
|
@ -15,9 +15,9 @@ namespace MapControl
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class WorldMercatorProjection : MapProjection
|
public class WorldMercatorProjection : MapProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 3395;
|
public const string DefaultCrsId = "EPSG:3395";
|
||||||
|
|
||||||
public WorldMercatorProjection(string crsId = "EPSG:3395")
|
public WorldMercatorProjection(string crsId = DefaultCrsId)
|
||||||
{
|
{
|
||||||
Type = MapProjectionType.NormalCylindrical;
|
Type = MapProjectionType.NormalCylindrical;
|
||||||
CrsId = crsId;
|
CrsId = crsId;
|
||||||
|
|
|
||||||
|
|
@ -19,18 +19,28 @@ namespace MapControl.Projections
|
||||||
return factory;
|
return factory;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Dictionary<int, string> CoordinateSystemWkts { get; } = new Dictionary<int, string>();
|
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)
|
public override MapProjection GetProjection(int epsgCode)
|
||||||
{
|
{
|
||||||
switch (epsgCode)
|
switch (epsgCode)
|
||||||
{
|
{
|
||||||
case WorldMercatorProjection.EpsgCode:
|
|
||||||
return new WorldMercatorProjection();
|
|
||||||
|
|
||||||
case WebMercatorProjection.EpsgCode:
|
|
||||||
return new WebMercatorProjection();
|
|
||||||
|
|
||||||
case int c when c >= Ed50UtmProjection.FirstZoneEpsgCode && c <= Ed50UtmProjection.LastZoneEpsgCode:
|
case int c when c >= Ed50UtmProjection.FirstZoneEpsgCode && c <= Ed50UtmProjection.LastZoneEpsgCode:
|
||||||
return new Ed50UtmProjection(epsgCode % 100);
|
return new Ed50UtmProjection(epsgCode % 100);
|
||||||
|
|
||||||
|
|
@ -56,16 +66,6 @@ namespace MapControl.Projections
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override MapProjection GetProjection(string crsId)
|
public Dictionary<int, string> CoordinateSystemWkts { get; } = new Dictionary<int, string>();
|
||||||
{
|
|
||||||
switch (crsId)
|
|
||||||
{
|
|
||||||
case Wgs84AutoUtmProjection.DefaultCrsId:
|
|
||||||
return new Wgs84AutoUtmProjection();
|
|
||||||
|
|
||||||
default:
|
|
||||||
return base.GetProjection(crsId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -18,8 +18,6 @@ namespace MapControl.Projections
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class WebMercatorProjection : GeoApiProjection
|
public class WebMercatorProjection : GeoApiProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 3857;
|
|
||||||
|
|
||||||
public WebMercatorProjection()
|
public WebMercatorProjection()
|
||||||
{
|
{
|
||||||
CoordinateSystem = ProjectedCoordinateSystem.WebMercator;
|
CoordinateSystem = ProjectedCoordinateSystem.WebMercator;
|
||||||
|
|
|
||||||
|
|
@ -45,11 +45,9 @@ namespace MapControl.Projections
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class Wgs84AutoUtmProjection : Wgs84UtmProjection
|
public class Wgs84AutoUtmProjection : Wgs84UtmProjection
|
||||||
{
|
{
|
||||||
public const string DefaultCrsId = "AUTO2:42001";
|
|
||||||
|
|
||||||
private readonly string autoCrsId;
|
private readonly string autoCrsId;
|
||||||
|
|
||||||
public Wgs84AutoUtmProjection(string crsId = DefaultCrsId)
|
public Wgs84AutoUtmProjection(string crsId = MapControl.Wgs84AutoUtmProjection.DefaultCrsId)
|
||||||
: base(31, true)
|
: base(31, true)
|
||||||
{
|
{
|
||||||
autoCrsId = crsId;
|
autoCrsId = crsId;
|
||||||
|
|
|
||||||
|
|
@ -17,8 +17,6 @@ namespace MapControl.Projections
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class WorldMercatorProjection : GeoApiProjection
|
public class WorldMercatorProjection : GeoApiProjection
|
||||||
{
|
{
|
||||||
public const int EpsgCode = 3395;
|
|
||||||
|
|
||||||
public WorldMercatorProjection()
|
public WorldMercatorProjection()
|
||||||
{
|
{
|
||||||
CoordinateSystemWkt
|
CoordinateSystemWkt
|
||||||
|
|
@ -43,7 +41,7 @@ namespace MapControl.Projections
|
||||||
+ "AUTHORITY[\"EPSG\",\"9001\"]],"
|
+ "AUTHORITY[\"EPSG\",\"9001\"]],"
|
||||||
+ "AXIS[\"Easting\",EAST],"
|
+ "AXIS[\"Easting\",EAST],"
|
||||||
+ "AXIS[\"Northing\",NORTH],"
|
+ "AXIS[\"Northing\",NORTH],"
|
||||||
+ $"AUTHORITY[\"EPSG\",\"{EpsgCode}\"]]";
|
+ "AUTHORITY[\"EPSG\",\"3395\"]]";
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Point GetRelativeScale(Location location)
|
public override Point GetRelativeScale(Location location)
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue