DbGeography创建具有中心和半径的圆

时间:2013-11-29 08:29:46

标签: c# sql-server entity-framework sql-server-2012 geo

我创建了一个像这样的DbGeography点:

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

我也有半径R.

我想创建一个曲线多边形,其圆形形状具有指定半径的点坐标。请注意,我使用的是DbGeography,而不是DbGeometry。

如何创建CIRCULARSTRING?或者有比使用CIRCULARSTRING更好的方法吗?


或许这样的事情?

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

感谢。

2 个答案:

答案 0 :(得分:4)

通过创建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的信息进行编辑。

答案 1 :(得分:0)

看看Buffer方法: http://msdn.microsoft.com/en-us/library/hh506085(v=vs.110).aspx

它在点周围创建一个循环缓冲区。 它也可以用于其他类型的几何/地理区域。

如果在使用地理时半径很大(几公里应该没问题),请小心

我不确定它是如何在C#中实现的,但我会定义在其他空间工具中使用它。