2016-10-23 34 views
1

请注意,此问题已发布at the R Shiny Google Group如何正确clearShapes在传单中一个闪亮的应用

Leaflet for R/ Shiny Integration documentation,我越来越与leafletProxy功能不需要/意​​外行为。

在下面的应用程序中,我希望圆形标记在输入$选项更改时显示/消失。

反应性df'filteredData'似乎正常工作。

我错误地使用leafletProxy()或clearShapes()?

library(shiny) 
library(dplyr) 
library(leaflet) 


my_df <- data.frame(lat = 34.72 + rnorm(1000, sd = .18), 
        lng = -92.5 + rnorm(1000, sd = .33), 
        category = c(rep("A", 300), rep("B", 300), rep("C", 400))) 

ui <- bootstrapPage(
    tags$style(type = "text/css", "html, body {width:100%;height:100%}"), 
    leafletOutput("map", height = '100%', width = '100%'), 
    absolutePanel(top = 10, right = 10, 
       checkboxGroupInput("choices", "Choices", choices =  list("A","B","C"), selected = c("A","B","C")), 
       verbatimTextOutput("my_rows") 


) 
) 


server <- function(input, output) { 

    filteredData <- reactive(my_df %>% filter(category %in% input$choices)) 

    output$map <- renderLeaflet({ leaflet() %>% addTiles() %>% setView(lat =  34.72, lng = -92.5, zoom = 9) }) 

    observe({ 

     leafletProxy("map", data = filteredData()) %>% clearShapes() %>% addCircleMarkers(radius = 6, weight = 1, fillColor = "red", fillOpacity = 0.3) 

    }) 

    output$my_rows <- renderPrint({ filteredData() %>% nrow() }) 
} 

shinyApp(ui = ui, server = server) 

回答

1

你的第一个问题是使用clearMarkers()而不是clearShapes()解决。

至于你指出的另一个问题,leaflet与空(和NA)数据挣扎。当您取消选择所有值时,您的data.frame显然变空。一个简单的检查,以停止leaflet试图绘制它将解决这个问题。

这里我使用的是if - else做的检查。

library(shiny) 
library(dplyr) 
library(leaflet) 

my_df <- data.frame(lat = 34.72 + rnorm(1000, sd = .18), 
        lng = -92.5 + rnorm(1000, sd = .33), 
        category = c(rep("A", 300), rep("B", 300), rep("C", 400))) 

ui <- bootstrapPage(
    tags$style(type = "text/css", "html, body {width:100%;height:100%}"), 
    leafletOutput("map", height = '100%', width = '100%'), 
    absolutePanel(top = 10, right = 10, 
       checkboxGroupInput("choices", "Choices" 
            , choices = list("A","B","C") 
            , selected = c("A","B","C")), 
       verbatimTextOutput("my_rows") 
    ) 
) 

server <- function(input, output) { 

    filteredData <- reactive({ 
     my_df %>% filter(category %in% input$choices) 
     }) 

    output$map <- renderLeaflet({ 
     leaflet() %>% 
      addTiles() %>% 
      setView(lat = 34.72, lng = -92.5, zoom = 9) 
     }) 

    observe({ 

     df <- filteredData() 

     ## check for empty dataframe 
     if(nrow(df) == 0){ 
      leafletProxy("map", data = df) %>% 
      clearMarkers() 
     }else{ 
      leafletProxy("map", data = df) %>% 
       clearMarkers() %>% 
       addCircleMarkers(radius = 6, weight = 1 
           , fillColor = "red", fillOpacity = 0.3) 
     } 

    }) 

    output$my_rows <- renderPrint({ 
     filteredData() %>% 
      nrow() 
     }) 
} 

shinyApp(ui = ui, server = server) 
+0

谢谢,但不幸的是,这种修复方法不起作用。 EG,如果您运行应用程序,删除每个类别(A,B,C),然后重新添加/删除,您将看到不需要的行为。 – WMC

+0

@ user3741038 - 我忘了'空数据问题' - 已更新我的回答 – SymbolixAU

+0

谢谢。空df ...是有道理的。 – WMC

相关问题