0

背景 - 我正在尝试创建一个圆形多边形并使用 simpleKML 将其添加到 kml。

kml 知道应该添加一个多边形,并且它具有正确的颜色、宽度和描述,但是每当我缩放到该位置时,它都会引导我到坐标 0,0 并且没有多边形。

我创建多边形的代码如下所示:

pol = kml.newpolygon(name=pnt.name) 
pol.description = ("A buffer for " + pnt.name)
pol.innerboundaryis = [newCoord]
pol.style.linestyle.color = simplekml.Color.green
pol.style.linestyle.width = 5
pol.style.polystyle.color = simplekml.Color.changealphaint(100, simplekml.Color.green)

其中“newCoord”是一个二维数组,其中存储了所有纬度/经度信息。

因为我认为数组可能无法正确格式化数据,所以我尝试使用代码形成一个简单的三角形多边形:

pol1 = kml.newpolygon(name=pnt.name) 
pol1.innerboundaryis = [(46.714,-75.6667),(44.60796,-74.502),(46.13910,-74.57411),(46.714,-75.6667)]
pol1.style.linestyle.color = simplekml.Color.green
pol1.style.linestyle.width = 5
pol1.style.polystyle.color = simplekml.Color.changealphaint(100, simplekml.Color.green)

但它与第一​​个问题相同。

我尝试使用 .innerboundaryis() 和 .outerboundaryis() 形成多边形,但没有成功,而且我的想法已经不多了。

编辑:我应该补充一点,我正在谷歌地球中打开 kml 文件

4

1 回答 1

0

网上几乎没有关于这个问题的文档,所以我想我会为将来遇到这个问题的任何人发布我的问题的答案。

这是我使用的使多边形工作的代码。

    newCoords = []
    pol = kml.newpolygon(name=pnt.name) 
    pol.description = ("A buffer for " + pnt.name)

    if pnt.name in bufferList:
        bufferRange = input('Enter the buffer range. ' )
        for i in range(360):
            newCoords.append( ( math to calculate Lat, math to calculate Long ) )
            pol.outerboundaryis.coords.addcoordinates([newCoords[i]])


        pol.style.linestyle.color = simplekml.Color.green
        pol.style.linestyle.width = 5
        pol.style.polystyle.color = simplekml.Color.changealphaint(100, simplekml.Color.green)

在使用“coords.addcoordinates()”函数将坐标添加到多边形的外边界之前,您需要将它们放入一个列表中。此外,它必须是一维列表,因此纬度和经度坐标必须存储在同一个位置。

您可以使用 '.outerboundaryis()' 直接输入浮点数,例如:

pol.outerboundaryis = [(18.333868,-34.038274), (18.370618,-34.034421),
                       (18.350616,-34.051677),(18.333868,-34.038274)]

但是 '.addcoordinates()' 只接受列表和整数。

于 2018-05-30T15:36:39.727 回答