从Shiny中删除渲染的传单地图中的缩放控件

时间:2018-02-06 14:57:48

标签: r shiny leaflet

Leaflet提供了一个选项,在设置地图时,隐藏缩放控件

leaflet(options = leafletOptions(zoomControl = FALSE)

但是,我想在创建地图后调用此选项,以便用户可以在没有缩放控件的情况下下载地图,而无需从头开始重新创建不同版本的地图。

此处是我的应用程序的简单版本:

library(shiny)
library(tidyverse)
library(leaflet)
library(mapview)

ui <- fluidPage(
  fluidPage(
    leafletOutput(outputId = "map"),
    downloadButton(outputId = "save")
  )
)

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

  map <- reactive({
    leaflet() %>%
      addTiles()
  })

  output$map <- renderLeaflet({
    map()
  })

  output$save <- downloadHandler(
    filename = "map.jpeg",
    content = function(file){
      latRng <- range(input$map_bounds$north,
                      input$map_bounds$south)
      lngRng <- range(input$map_bounds$east,
                      input$map_bounds$west)
      map() %>%
        setView(lng = (lngRng[1] + lngRng[2])/2,
                lat = (latRng[1] + latRng[1])/2,
                zoom = input$map_zoom) %>%
        ### HERE ###
        mapshot(file = file)
    }
  )

}

shinyApp(ui, server)

我希望能够在我评论### HERE ###的位置添加一行代码来关闭缩放控件。在我的实际代码中,显示的地图非常复杂,有很多选项,我不想只是为了在leaflet()的初始调用中删除缩放控件而将所有代码都包含两次。

由于

1 个答案:

答案 0 :(得分:2)

你可以这样做:

library(shiny)
library(tidyverse)
library(leaflet)
library(mapview)

ui <- fluidPage(
  fluidPage(
    leafletOutput(outputId = "map"),
    downloadButton(outputId = "save")
  )
)

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

  map <- reactive({
    leaflet() %>%
      addTiles()
  })

  output$map <- renderLeaflet({
    map()
  })

  output$save <- downloadHandler(
    filename = "map.jpeg",
    content = function(file){
      latRng <- range(input$map_bounds$north,
                      input$map_bounds$south)
      lngRng <- range(input$map_bounds$east,
                      input$map_bounds$west)
      m = map() %>%
        setView(lng = (lngRng[1] + lngRng[2])/2,
                lat = (latRng[1] + latRng[1])/2,
                zoom = input$map_zoom)
      m$x$options = append(m$x$options, list("zoomControl" = FALSE))
      mapshot(m, file = file)
    }
  )

}

shinyApp(ui, server)

在地图创建后更新传单选项。我将把它合并到mapshot函数中以选择性地删除zoomControl。