我正在帮助一位朋友对康涅狄格州啤酒厂的数量进行一些研究。在这个社区的帮助下,我能够在传单中制作啤酒厂地图,并能够使用闪亮添加滑块。现在我希望能够向我的朋友提供地图,以便他可以将其添加到他正在发布研究的网站上。我对这方面很陌生,想知道是否有人对我有一些想法。这是我用来制作地图的代码(感谢 Ben):
library(shiny)
library(leaflet)
ui <- bootstrapPage(
tags$style(type = "text/css", "html, body {width:100%;height:100%}"),
leafletOutput("map", width = "100%", height = "100%"),
absolutePanel(bottom = 30, right = 10,
textOutput("Counter"),
sliderInput("Year", "Year", 1990, 2000, value = 1995, step = 1, sep = "")
)
)
server <- function(input, output, session) {
sliderData <- reactive({
breweries_subset %>%
filter(YearOpened <= input$Year)
})
output$Counter <- renderText(
paste("Number Breweries: ", nrow(sliderData()))
)
output$map <- renderLeaflet({
leaflet() %>%
addTiles() %>%
fitBounds(min(breweries_subset$Longitude), min(breweries_subset$Latitude),
max(breweries_subset$Longitude), max(breweries_subset$Latitude))
})
observe({
leafletProxy("map", data = sliderData()) %>%
clearMarkers() %>%
addProviderTiles(provider = 'Esri.WorldStreetMap') %>%
addAwesomeMarkers(icon = beer_icon,
group = 'Breweries',
popup = ~ Name)
})
}
shinyApp(ui = ui, server = server)
更新
我采纳了您的建议并尝试发布到shinyapps.io。这是我使用的代码:
对于 ui.R:
library(shiny)
library(leaflet)
ui <- bootstrapPage(
tags$style(type = "text/css", "html, body {width:100%;height:100%}"),
leafletOutput("map", width = "100%", height = "100%"),
absolutePanel(bottom = 30, right = 10,
textOutput("Counter"),
sliderInput("Year", "Year", 1990, 2019, value = 1995, step = 1, sep = "")
)
)
对于服务器。R:
library(shiny)
library(leaflet)
library(leaflet.extras)
library(fontawesome)
library(rsconnect)
function(input, output, session) {
ct_breweries <- read.csv('ct_breweries.csv', header=TRUE, sep=',')
sliderData <- reactive({
ct_breweries %>%
filter(YearOpened <= input$Year)
})
output$Counter <- renderText(
paste('Number of Breweries: ', nrow(sliderData()))
)
output$map <- renderLeaflet({
leaflet() %>%
addTiles() %>%
fitBounds(min(ct_breweries$Longitude), min(ct_breweries$Latitude),
max(ct_breweries$Longitude), max(ct_breweries$Latitude))
})
observe({
leafletProxy('map', data = sliderData()) %>%
clearMarkers() %>%
addProviderTiles(provider = 'Esri.WorldStreetMap') %>%
addAwesomeMarkers(icon = beer_icon,
group = 'Breweries',
popup = ~ Name)
})
}
在本地运行良好。当我尝试发布它时,收到“与服务器断开连接”错误。日志中显示未找到有关“YearOpened”的内容。 .csv 中肯定有一个专栏。我想知道这是否与秋天的召唤有关。你有什么想法吗?
尝试将所有包加载和数据集读取添加到
global.R
文件(在同一应用程序文件夹中),如下所示:
library(shiny)
library(leaflet)
library(leaflet.extras)
library(fontawesome)
library(rsconnect)
ct_breweries <- read.csv('ct_breweries.csv', header=TRUE, sep=',')
然后您可以从
ui.R
和 server.R
中删除它们。
问题似乎是数据集对服务器不可见 - 这应该可以解决这个问题。另外,请确保 csv 文件位于同一文件夹中。
更新
根据我上面的评论,如果这足够了,您可以保存地图的 html 文件,然后将其发送给您的朋友以在浏览器中打开。我尝试在没有您的数据的情况下编写代码,因此这可能不起作用。
library(leaflet)
library(fontawesome)
library(htmlwidgets)
ct_breweries <- read.csv('ct_breweries.csv', header=TRUE, sep=',')
leaflet_map <- leaflet(data = ct_breweries) %>%
addProviderTiles(provider = 'Esri.WorldStreetMap') %>%
addAwesomeMarkers(icon = beer_icon,
group = ~ YearOpened,
popup = ~ Name) %>%
addLayersControl(
overlayGroups = 1990:2000,
options = layersControlOptions(collapsed = FALSE)
) %>% hideGroup(~ YearOpened)
saveWidget(leaflet_map, file="leaflet_map.html")
它确实失去了滑块选项 - 替换为复选框。您可以删除
hideGroup()
和 collapsed = FALSE
以查看其他选项。假设滑块不是必需的,这可能会更容易。
此文件离线保存,但您需要互联网连接才能获取传单地图图块。