基于缩放级别的闪亮传单显示标签

时间:2019-06-29 11:41:58

标签: r shiny leaflet

我想基于缩放级别显示标记标签。 基于(https://rstudio.github.io/leaflet/shiny.html),我尝试使用“ input $ MAPID_zoom”。在我的示例中,当缩放级别(location_name低于6时,应该显示存储在mapscale中的标签。

我尝试过的:

library(shiny)
library(leaflet)

 # my data
df <- data.frame(
  location_name = c('S1', 'S2'),
  lng = c(-1.554136,  -2.10401),
  lat = c(47.218637, 47.218637), 
  stringsAsFactors = FALSE)


# UI
 ui <- shinyUI(fluidPage(
  leafletOutput('map')

  ))

# server 

server <- shinyServer(function(input, output, session) {

  mapscale <-  observe({
    input$map_zoom   # get zoom level
  })


  output$map <- renderLeaflet({
    leaflet() %>%
    addTiles() %>% 
    addMarkers(data=df, lng = ~lng, lat = ~lat,
               label =~if(mapscale<6, location_name))
})

})

shinyApp(ui = ui, server = server)

1 个答案:

答案 0 :(得分:2)

您可以根据需要在代码上加一些说明。 如果将缩放包装在反应性函数中,请像mapscale()一样引用它。在R中使用普通的if语句,在变量前使用~。那你应该没事。

可复制的示例:

library(shiny)
library(leaflet)

df <- data.frame(
  location_name = c('S1', 'S2'),
  lng = c(-1.554136,  -2.10401),
  lat = c(47.218637, 47.218637), 
  stringsAsFactors = FALSE
)


ui <- shinyUI(
  fluidPage(
    leafletOutput(outputId = 'map')
  )
)

server <- shinyServer(function(input, output, session) {

  output$map <- renderLeaflet({
    leaflet() %>%
      addTiles()
  })

  observeEvent(
    eventExpr = input$map_zoom, {
      print(input$map_zoom)           # Display zoom level in the console
      leafletProxy(
        mapId = "map", 
        session = session
      ) %>% 
        clearMarkers() %>%
        addMarkers(
          data = df, 
          lng = ~lng,
          lat = ~lat,
          label = if(input$map_zoom < 6) ~location_name
      )
    }
  )


})

shinyApp(
  ui = ui, 
  server = server
)