EPSG Codes & CRS IDs

This commit is contained in:
ClemensFischer 2024-07-12 14:14:42 +02:00
parent ce6f190bf1
commit 03c18d5126
9 changed files with 66 additions and 72 deletions

View file

@ -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;

View file

@ -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;
}
}
} }
} }

View file

@ -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;

View file

@ -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;

View file

@ -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;

View file

@ -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);
}
}
} }
} }

View file

@ -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;

View file

@ -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;

View file

@ -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)