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

问题描述 投票:0回答:1

我想根据缩放级别显示我的标记标签。 基于(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)
r shiny r-leaflet
1个回答
5
投票

如果您愿意,可以对您的代码进行一些注释。 如果将缩放包装在反应函数中,请像

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
)
© www.soinside.com 2019 - 2024. All rights reserved.