作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试计算折线的面积
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.
后来我注意到 dbgeometry 无效的错误原因我在 ms sql 2012 中尝试代码也给了我错误但是当我那样尝试时
SELECT @gm.MakeValid().STArea()
那是在 sql 中工作的我的问题是如何使几何在 .net 中有效谢谢
最佳答案
你绝对不应该为了得到你想要的东西而去数据库。一种简单快速的方法是通过将以下代码添加到您的项目来扩展 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);
}
}
}
创建此代码时有一些假设,因此不要“按原样”使用它。
关于c# - .net 4.5 中是否有类似 dbgeometry makevalid 的东西,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16640565/
我有一个应用程序,用户可以在其中绘制区域,稍后我会检查折线是否穿过它们。 应用程序突然崩溃并出现错误: A .NET Framework error occurred during execution
我正在尝试计算折线的面积 string poly = "POLYGON ((637604.918432772 2230520.64934531, 637622.257266129 223041
我是一名优秀的程序员,十分优秀!