我这样创建一个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的信息进行编辑。