How to hide/toggle legends based on addLayerControl() in Leaflet for R

前端 未结 2 1234
甜味超标
甜味超标 2021-01-02 20:17

I\'m wondering how to hide/toggle legends based on addLayerControl() in Leaflet for R? When option layer a is toggled, then the data of option layer b is not showed by addPo

相关标签:
2条回答
  • 2021-01-02 20:38

    In case anyone is looking at this in the future, there's a new viable method.

    If you're using the development/Github version of the leaflet package, addLegend() now supports the group and layerId arguments.

    (Run the command devtools::install_github('rstudio/leaflet') to install)

    Even the latest CRAN version (1.1.0) supports layerID.

    Assuming you go with the development version, the following code should work:

    leaflet() %>%
        #Polygon Layers
        addPolygons(data = exampleDataOne, group = "Group A") %>%
        addPolygons(data = exampleDataTwo, group = "Group B") %>%
    
        #Legend Layers
        addLegend(values = exampleValuesOne, group = "Group A", 
                  position = "bottomright") %>%
        addLegend(values = exampleValuesTwo, group = "Group B",
                  position = "bottomright") %>%
    
        #Layers Control
        addLayersControl(overlayGroups = c("Group A","Group B"),
                  options = layersControlOptions(collapsed = FALSE))
    

    This should have the desired effect of only displaying a legend when the corresponding layer is active.

    One potential issue is that by default, all leaflet layers are active. If you have overlapping polygons, this can lead to a less visually appealing map. And, if you have multiple legends, this will also be an issue.

    What you can do is use the hideGroup() function.

    If you wanted to have only Group A from the above example active at start, you could add

    %>% hideGroup("Group B")

    to the end of the code block above.

    0 讨论(0)
  • 2021-01-02 20:45

    This code worked for me:

    observeEvent(input$mymap_groups,{
        mymap <- leafletProxy("mymap", data = SalesMap)
        mymap %>% clearControls()
        if (input$mymap_groups == '1') {
          mymap %>% addLegend(position="bottomright", pal=pal1, values=SalesMap$SALES, title="a")
        }
        else if (input$mymap_groups == '2') {
          mymap %>% addLegend(position="bottomright", pal=pal2, values=SalesMap$Bonnen, title="b")
        }
      })
    

    You can use input$mymap_groups to identify what kind of group is selected.In the observeEvent() you can use an if/else statement to create a legend based on a group.

    0 讨论(0)
提交回复
热议问题