我有一个包含自定义函数的库,我需要在一个闪亮的应用程序中使用它。这个函数里面有一个for循环,我想在那个循环中使用变量来更新进度条(而不是将函数复制到服务器文件,因为我想保持一切分开并清理)。到目前为止,我已经设法在函数运行时使用“withProgress()”弹出一条消息,但我想让它更好地显示已完成的工作的百分比,所以最终用户不要垃圾邮件运行按钮。 这是一个可重复的问题示例:
library(shiny)
# Library in separate file
snail_function <- function(){
for (i in 1:100){
Sys.sleep(1)
}
}
# ui.R
ui <- shinyUI(fluidPage(
tabsetPanel(
tabPanel("1. Load Files"
, fluidRow(actionButton("analysis", "Run analysis"))
, fluidRow(
plotOutput("bar")
)
)
)
))
# server.R
server <- shinyServer(function(input, output, session) {
observeEvent(input$analysis, {
output$bar <- renderPlot({
withProgress(message = 'Running... (this may take a while)',
detail = 'Go get some coffee...', value = 0, {
snail_function()
})
# do stuff
})
})
})
shinyApp(ui = ui, server = server)
所以,我想问题是:有什么方法可以使用snail_function循环来设置栏中的进度吗? (使用全局变量或类似的东西)
谢谢!
答案 0 :(得分:1)
保持干净解决方案的一种可能性是向函数添加参数progress
,指示我们是否要增加进度,并仅在incProgress
设置为{{}时调用TRUE
1}}。因此,当我们想要独立运行此函数时,我们可以将其称为snail_function(FALSE)
。下面显示了一个工作示例,希望这会有所帮助。
library(shiny)
# Library in separate file
snail_function <- function(progress=FALSE){
for (i in 1:100){
Sys.sleep(1)
if(progress)
incProgress(1/100)
}
}
# ui.R
ui <- shinyUI(fluidPage(
tabsetPanel(
tabPanel("1. Load Files"
, fluidRow(actionButton("analysis", "Run analysis"))
, fluidRow(
plotOutput("bar")
)
)
)
))
# server.R
server <- shinyServer(function(input, output, session) {
observeEvent(input$analysis, {
output$bar <- renderPlot({
withProgress(message = 'Running... (this may take a while)',
detail = 'Go get some coffee...', value = 0, {
snail_function(progress=TRUE)
})
# do stuff
})
})
})
shinyApp(ui,server)