python - 使用plotly在mapbox上绘制多边形

标签 python plotly

我正在尝试使用 scattermapbox 绘制 geojson 几何图形。

这段代码成功地将 geopandas 中的数据转换为可用于绘图的数据:

from plotly.offline import download_plotlyjs, init_notebook_mode, 
plot, iplot
import plotly.graph_objs as go

mapbox_access_token = 'mykey'

import json

from_json = geopandas_gdf.to_json()
geoJSON = json.loads(from_json)

pts=[]#list of points defining boundaries of polygons
for  feature in geoJSON['features']:
    if feature['geometry']['type']=='Polygon':
        pts.extend(feature['geometry']['coordinates'][0])    
        pts.append([None, None])#mark the end of a polygon   

    elif feature['geometry']['type']=='MultiPolygon':
        for polyg in feature['geometry']['coordinates']:
            pts.extend(polyg[0])
            pts.append([None, None])#end of polygon
    else: raise ValueError("geometry type irrelevant for map") 

X, Y=zip(*pts)

我可以使用以下代码在白色图形上绘制这些数据:

axis_style=dict(showline=False, 
            mirror=False, 
            showgrid=False, 
            zeroline=False,
            ticks='',
            showticklabels=False)
layout=dict(title='map',
            width=700, height=700, 
            autosize=False,
            xaxis=axis_style,
            yaxis=axis_style,
            hovermode='closest')
fig=dict(data=data, layout=layout)
plot(fig, filename='map')

但我无法在 scattermapbox 上绘制它。尝试这样:

data = [
go.Scattermapbox(
    lat=X,
    lon=Y,
    line = go.scattermapbox.Line(width=5,
                                 color='red'))
    ]

layout = go.Layout(
autosize=True,
hovermode='closest',
mapbox=go.layout.Mapbox(
    accesstoken=mapbox_access_token,
    bearing=0,
    center=go.layout.mapbox.Center(
        lat=53,
        lon=0
    ),
    pitch=0,
    zoom=5
    ),
)

fig = go.Figure(data=data, layout=layout)
plot(fig, filename='Montreal Mapbox')

谢谢!

最佳答案

我已经成功地通过以下方式做到了这一点:

layout = go.Layout(
    height=1500,
    autosize=True,
    hovermode='closest',
    mapbox=dict(
        layers=[
            dict(
                sourcetype = 'geojson',
                source = geoJSON,
                type = 'fill',
                color = 'rgba(163,22,19,0.8)'
            )
        ],
        accesstoken=mapbox_access_token,
        bearing=0,
        center=dict(
            lat=53,
             lon=0
        ),
        pitch=0,
        zoom=5.2,
        style='light'
     ),
)

但是另一个问题出现了:如何从json提供数据给hover?

关于python - 使用plotly在mapbox上绘制多边形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56201040/

相关文章:

python - 使用 Python 编写 Unison 脚本时出现问题

python - Plotly:如何以根样式绘制直方图,仅显示直方图的轮廓?

python - 如何叠加不同日期的图?

python - 我需要定义 __setattr__ 来分配没有属性的字段,但对定义了属性的字段使用 setter/getter 函数

python - 允许在 conda env 中使用系统 python?

python - Django 测试运行程序未找到测试方法

python - 结合两个机器学习模型的结果

r - 抑制警告 "' 热图'对象没有这些属性 : 'mode' "

R 绘制地返回 map 上选定线路的 event_data 信息

python - 无法使用 Kaleido 将绘图图像导出为 png