Kha*_*mar 3 c# sql spatial geospatial .net-4.5
我正在尝试计算折线的面积
string poly = "POLYGON ((637604.918432772 2230520.64934531,
637622.257266129 2230419.44632915, 637279.107128549 2230192.04910755, 636765.470527745 2230179.6468564, 636778.005055813 2229861.77192838, 636529.81646905 2229464.29327025, 635813.486592791 2229523.30345774, 636017.385069448 2229974.32341381, 636267.323659164 2230070.32127916, 637035.026966561 2230404.70764784, 637275.265066307 2230401.13408429, 637604.918432772 2230520.64934531, 637604.918432772 2230520.64934531))";
DbGeometry gm = DbGeometry.FromText(poly, 32637);
double area= gm.Area.Value; // here I got the error Exception has been thrown by the target of an invocation.
Run Code Online (Sandbox Code Playgroud)
我后来注意到dbgeometry无效的错误共鸣我尝试ms sql 2012中的代码也给我错误但是当我尝试那样的时候
SELECT @gm.MakeValid().STArea()
Run Code Online (Sandbox Code Playgroud)
多数民众赞成在sql工作我的问题是,有什么东西使几何有效.net谢谢你
你绝对不应该去DB获得你想要的东西.一种简单快速的方法是通过向项目中添加以下代码来扩展DbGeography:
using System.Data.SqlTypes;
using Microsoft.SqlServer.Types;
namespace System.Data.Spatial
{
public static class DbGeometryExtension
{
public static DbGeometry MakeValid(this DbGeometry geom)
{
if (geom.IsValid)
return geom;
return DbGeometry.FromText(SqlGeometry.STGeomFromText(new SqlChars(geom.AsText()), 4326).MakeValid().STAsText().ToSqlString().ToString(), 4326);
}
}
}
Run Code Online (Sandbox Code Playgroud)
创建此代码时会做出一些假设,因此请不要"按原样"使用它.
除非您使用实体框架,否则我同意Bojan的观点?
SqlGeometry对象有一个MakeValid()函数,所以使用你的例子,允许在DbGeography和SqlGeography之间进行转换:
DbGeography geog;
SqlGeometry geom = SqlGeometry.STGeomFromWKB(new SqlBytes(geog.AsBinary()), 32637);
Run Code Online (Sandbox Code Playgroud)
但是,除非您使用EF,否则我建议您只使用SqlGeometry
希望有所帮助.