c# - SqlGeography 从 multipolygon 获取多边形

标签 c# polygon geography sqlgeography

我有一个表 Town,其列 TownBoundary 包含相关城镇的多边形(geography 数据类型)。

对于每个城镇,我都会获得生成 KML(XML) 文件所需的多边形数据,例如:

sqlg = SqlGeography.STPolyFromText(new SqlChars(
town.TownBoundary.WellKnownValue.WellKnownText),
town.TownBoundary.CoordinateSystemId);
for (int i = 1; i <= sqlg.STNumPoints(); i++)
{
    SqlGeography point = sqlg.STPointN(i);
    var pLong = (point.Long).ToString().Replace(",", ".");
    var pLat = (point.Lat).ToString().Replace(",", ".");
    double dLong = double.Parse(pLong, CultureInfo.InvariantCulture);
    double dLat = double.Parse(pLat, CultureInfo.InvariantCulture);
    kmlCoordinates.Add(new Vector(dLat, dLong)); //one point od polygon
}

town.TownBoundary.WellKnownValue.WellKnownText 的值以 POLYGON(..

开头

但最近我意识到有些城镇包含更多多边形,WellKnownTextMULTIPOLYGON(.. 开头,函数 STPolyFromText 以错误结束.

我已将它放在 try{} block 中,但在 catch{} 中 - 如果值是多边形 - 是否有可能以某种方式获得单个多边形?我知道有方法 STMPolyFromText,但我无法访问那里的单个多边形,只能指向方法 STPolyFromText 中的点。

我的目标是将多边形拆分为多边形,然后为每个多边形执行与上述相同的方法。

最佳答案

解决了,在方法 STMPolyFromText 中,我可以使用 STNumGeometries 获取多边形数组。

sqlg = SqlGeography.STMPolyFromText(
new SqlChars(town.TownBoundary.WellKnownValue.WellKnownText),
town.TownBoundary.CoordinateSystemId);
for (int i = 1; i <= sqlg.STNumGeometries(); i++)
{
 SqlGeography poly = sqlg.STGeometryN(i);
 //foreach poly
} 

关于c# - SqlGeography 从 multipolygon 获取多边形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25289221/

相关文章:

sql-server-2008 - 在 F# 中,如何使用 Type Provider 访问 Sql Server Geography 数据类型?

c# - 如何引用解构的值元组而不复制它

c# - C#中的反向广度优先遍历

algorithm - 划分自相交多边形(C代码)

mysql - 从自定义多边形 MySQL 进行纬度经度搜索

algorithm - 如何使用纬度/经度数据进行有效的范围搜索+计数?

c# - 如何在 TreeView 中获取所有展开的节点?

c# - 将 x86 平台更改为 Any CPU for .NET 3.5 抛出 COMException

javascript - 如何在 JavaScript 中找到凹不规则多边形的质心?

algorithm - 六边形内有 6 个等边三角形,给定 x,y 坐标,如何确定坐标在哪个等边三角形中?