アプリが起動すると起動するアプリがobserveEvent
であり、ボタンがクリックされるのを待たない。この例では違いはありませんが、実際のアプリケーションではbusyIndicatorが最初の負荷で2回表示されます。 options(shiny.trace = TRUE)
を使用してアプリの起動時に光沢のあるobserveEventトリガー
name<-sample(c('a','b','c'),replace=T,5)
LAT<-runif(5,min=-26, max=-22)
LONG<-runif(5,min=-54, max=-48)
data<-data.frame(name,LAT,LONG)
ui <- shinyUI(fluidPage(
selectInput('muni',label='Select city',
choices=c('Show all',sort(levels(data$name)),selected=NULL)),
htmlOutput('box'),
leafletOutput('map')
))
server <- function (input, output, session) {
data1<-reactive({
if (input$muni!='Show all') {
data<-data[which(data$name==input$muni),]
}
return(data)
})
output$box <- renderUI({
data<-data1()
num<-as.integer(nrow(data))
lapply(1:num, function(i) {
bt <- paste0('go_btn',i)
fluidRow(
HTML(paste0('<div style="border: 1px solid #00000026;
border-radius: 10px; padding: 10px;">
<span style="font-size:14px font-weight:bold;">',
data$name[i],' - areas: a1, a2, a3</span></br>',
actionButton(bt,'See map',icon=icon('map-marker',lib='font-awesome')),
HTML('</div></br>')
)))
})
})
output$map<-renderLeaflet({
data<-data1()
rownames(data)<-seq(1:nrow(data))
leaflet(data) %>%
addProviderTiles("Esri.WorldTopoMap") %>%
setView(-51.5,-24.8,zoom=7) %>%
addMarkers(lng=~data$LONG,lat=~data$LAT)
})
lapply(1:nrow(data), function(i) {
observeEvent(input[[paste0('go_btn',i)]], {
data<-data1()
rownames(data)<-seq(1:nrow(data))
leafletProxy('map',data=data,session=session) %>%
clearMarkers() %>%
setView(data$LONG[i],data$LAT[i],zoom=15) %>%
addMarkers(lng=data$LONG[i],lat=data$LAT[i])
},ignoreInit = T)
})
}
shinyApp(ui, server)
私は、プロセスが二回実行されることを参照してください。 SEND { "忙しい": "ビジー"}、{ "忙しい": "アイドル"}送信します。 誰でも私のアプリがこのような動作をしている理由を教えてもらえますか?私はあなたの例を実行することができませんでした
再現可能な例を掲載することはできますか?コードには、実行を妨げるいくつかの問題があります。 –
申し訳ありません!私はデータフレームからいくつかの変数を削除し、宣言しないことを忘れてしまった!今、私はそれが動作すると思う... –