Ich musste ungefähr zwei Stunden aufwenden, um die Lösung von @nibot zu erarbeiten. Ich brauchte lediglich eine Methode, um eine Begrenzungsbox zu erstellen, deren Mittelpunkt und Breite / Höhe (oder Radius) in Kilometern angegeben sind:
Ich verstehe die Lösung mathematisch / geografisch nicht. Ich habe die Lösung (durch Versuch und Irrtum) optimiert, um die vier Koordinaten zu erhalten:
Norden:
private static Position FromKmToNPosition(Position p, double km)
{
double r_earth = 6378;
var pi = Math.PI;
var new_latitude = p.Lat + (km / r_earth) * (180 / pi);
return new Position(new_latitude, p.Long);
}
Osten:
private static Position FromKmToEPosition(Position p, double km)
{
double r_earth = 6378;
var pi = Math.PI;
var new_longitude = p.Long + (km / r_earth) * (180 / pi) / Math.Cos(p.Lat * pi / 180);
return new Position(p.Lat, new_longitude);
}
Süden:
private static Position FromKmToSPosition(Position p, double km)
{
double r_earth = 6378;
var pi = Math.PI;
var new_latitude = p.Lat - (km / r_earth) * (180 / pi);
return new Position(new_latitude, p.Long);
}
Westen:
private static Position FromKmToWPosition(Position p, double km)
{
double r_earth = 6378;
var pi = Math.PI;
var new_longitude = p.Long - (km / r_earth) * (180 / pi) / Math.Cos(p.Lat * pi / 180);
return new Position(p.Lat, new_longitude);
}