Uber 发布了 h3,这是一个用于有效处理地理空间文件中的大数据的框架。使用 h3,我尝试获取如图所示的六边形网格位置的位置。 (https://eng.uber.com/h3/)
我从下面的代码中得到了六边形网格的位置。然后我将它绘制在一张二维地图上,看看它是否覆盖了整个地球。但是,我没有在边界上得到有效的六边形(-90°、90°、-180°、180°)。它似乎并没有覆盖整个地球。 (六边形网格)
from h3 import h3
import folium
# Polyfill a Geo Json with hexagons
geoJson1 = {'type': 'Polygon', 'coordinates': [[[90,-180],[90,0],[-90,0],[-90,-180]]]}
geoJson2 = {'type': 'Polygon', 'coordinates': [[[90,0],[90,180],[-90,180],[-90,0]]]}
hexagons = list(h3.polyfill(geoJson1, 1)) + list(h3.polyfill(geoJson2, 1))
# Plot hexagons
polylines = []
for hex in hexagons:
polygons = h3.h3_set_to_multi_polygon([hex], geo_json=False)
outlines = [loop for polygon in polygons for loop in polygon]
polyline = [outline + [outline[0]] for outline in outlines][0]
polylines.append(polyline)
base = folium.Map([0,0], zoom_start=2, tiles='cartodbpositron')
for polyline in polylines:
m = folium.PolyLine(locations=polyline, weight=1, color='black')
base.add_child(m)
m.save('test.html')
我想要覆盖整个地球的六边形位置。在这种情况下,我使用 h3 接近,但我不在乎只要我能得到这个位置。