Есть ли способ добавить html-контент во всплывающие окна в Geojson Leaflet Map, чтобы я мог удалить folium.Markers из кода? - PullRequest
0 голосов
/ 01 мая 2019

Цель: Я пытаюсь нанести маркеры на карту с помощью поиска и всплывающих окон IFrame с содержанием html с помощью Leaflet - folium в Python.Для этого мне пришлось использовать и folium.Markers для html-контента, и маркеры из folium.GeoJson для поиска.

Но я хочу оставить только один тип маркеров либо folium.Markers, либо folium.GeoJson, но сохранить оба поискаи HTML-контент.Как я могу это сделать?

Выполнено :

1) Код в части 1 - Возможность создания карты фолиума

2) Код в части 2 -Способен создавать фолиевые маркеры (использовал это для создания html-контента в нем - текста, изображений и т. Д.).

3) Код в части 3 - Возможность использовать маркеры GeoJson (использовал это, потому что я хотел создать поиск)

4) Код в части 3. Возможность создания поиска по именам.

На изображении два маркера перекрывают друг друга для каждой точки

  • один маркер из фолиума. Маркер

  • Другой маркер из фолиума. Geojson

Примечание. Я знаю, что могу отключить слой маркеров GeoJson с помощью фолиума.LayerControl ()

enter image description here

enter image description here

Вот код:

######################################################################
# Part 1 - Creating map

m_search = folium.Map(location=[28.6003435, 77.21952300000001],zoom_start=11
              )   

#######################################################################
# Part 2 - Creating folium markers on map with html text, images 
# etc dynamically for multiple points using for-loop


for plot_numb in range(gdf.shape[0]):

    icon = folium.Icon(color="blue", icon="cloud", icon_color='white')
    tooltip = 'Click to view more about: '+gdf.iloc[plot_numb,0]

    var_name = gdf.iloc[plot_numb,0] 
    var_loc = gdf.iloc[plot_numb,2] 
    pic = base64.b64encode(open('Images/'+gdf.iloc[plot_numb,5],'rb').read()).decode()    

    html = f'''<img ALIGN="Right" src="data:image/png;base64,{pic}">\
    <strong>Name: </strong>{var_name}<br /><br />\
    <strong>Location: </strong>{var_loc}<br /><br />\
    '''
    html 

    iframe = IFrame(html, width=300+180, height=300)
    popup = folium.Popup(iframe, max_width=650) 

    marker = folium.Marker(location=gdf.iloc[plot_numb,1], popup=popup, tooltip=tooltip, icon=icon).add_to(m_search)


########################################################################
# Part 3 - Creating Markers using GeoJson, creating search  

# creating folium GeoJson objects from out GeoDataFrames
pointgeo = folium.GeoJson(gdf,name='group on map', show=False,
                      tooltip=folium.GeoJsonTooltip(fields=['Name', 'Relation', 'City'], aliases=['Name','Relation', 'City'],
                        localize=True)).add_to(m_search)

# Add some Search boxes to the map that reference the GeoDataFrames with some different parameters passed to the 
# arguments.

pointsearch = Search(layer=pointgeo, geom_type='Point', 
                 placeholder='Search for contacts', collapsed=False,
                 search_label='Name').add_to(m_search)


# To Add a LayerControl add below line
folium.LayerControl().add_to(m_search)

m_search 

Ниже приведен пример фрейма данных gdf:

    Name    Location    City    Relation    Relation Detail Image   Lat Lon geometry
0   abc [28.562193, 77.387073]  Noida   Cousin  Cousin  1.png   28.562193   77.387073   POINT (77.387073 28.562193)
1   def [28.565282027743955, 77.44913935661314] Noida   Cousin  Cousin Brother  2.png   28.565282   77.449139   POINT (77.44913935661314 28.56528202774395)
3   ghi [28.6206996683473, 77.42576122283936]   Noida   Cousin  Cousin Brother  4.png   28.620700   77.425761   POINT (77.42576122283936 28.6206996683473)
...