我这样创建一个DbGeography点:

String selectedLocation = String.Format("POINT ({0} {1})", lon, lat).Replace(",", ".");
DbGeography selectedLocationGeo = DbGeography.FromText(selectedLocation, 4326);


我也有半径R。

我想创建一个带有从点坐标指定半径的圆形状的curvepolygon。请注意,我使用的是DbGeography,而不是DbGeometry。

如何创建圆弧形?还是有比使用CIRCULARSTRING更好的方法?



大概是这样吗?

String polyString = String.Format("CURVEPOLYGON(CIRCULARSTRING(xx yy, xx yy, xx yy, xx yy, xx yy))");
DbGeography polygon = DbGeography.FromText(polyString, 4326);


谢谢。

最佳答案

通过创建DbGeography创建一个PointFromText圆,然后按半径缓冲该点。对于WGS84坐标系,DbGeography半径单位似乎以千米为单位。

string textPoint = String.Format("POINT ({0} {1})", longitude, latitude);
DbGeography point = DbGeography.PointFromText(textPoint, DbGeography.DefaultCoordinateSystemId); //4326 = [WGS84]
DbGeography targetCircle = point.Buffer(radiusKilometers);


使用adrian中有关DbGeography.DefaultCoordinateSystemId的信息进行编辑。

07-28 05:54