Manchmal gibt es keine Möglichkeit, die Ausführungszeit zu schätzen. In diesen Fällen wäre es hilfreich, entweder eine radiale Fortschrittsanzeige oder einen sich bewegenden schraffierten Balken zu haben.
https://groups.google.com/d/msg/shiny-discuss/a3TcQ2C_hS0/3H4zocpRD0AJ
Eine andere Möglichkeit besteht darin, die Streifen einfach sichtbarer zu machen und den Fortschrittswert auf 1 zu setzen:
server <- function(input, output) {
output$plot <- renderPlot({
input$goPlot # Re-run when button is clicked
dat <- data.frame(x = rnorm(10), y = rnorm(10))
withProgress(message = 'Making plot', value = 1, {
Sys.sleep(20)
})
plot(dat$x, dat$y)
})
}
ui <- shinyUI(basicPage(
tags$head(tags$style(HTML("
.progress-striped .bar {
background-color: #149bdf;
background-image: -webkit-gradient(linear, 0 100%, 100% 0, color-stop(0.25, rgba(255, 255, 255, 0.6)), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, rgba(255, 255, 255, 0.6)), color-stop(0.75, rgba(255, 255, 255, 0.6)), color-stop(0.75, transparent), to(transparent));
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.6) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0.6) 75%, transparent 75%, transparent);
background-image: -moz-linear-gradient(45deg, rgba(255, 255, 255, 0.6) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0.6) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.6) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0.6) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.6) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0.6) 75%, transparent 75%, transparent);
-webkit-background-size: 40px 40px;
-moz-background-size: 40px 40px;
-o-background-size: 40px 40px;
background-size: 40px 40px;
}
"))),
plotOutput('plot', width = "300px", height = "300px"),
actionButton('goPlot', 'Go plot')
))
shinyApp(ui = ui, server = server)
Ich habe versucht, die obigen Vorschläge zu übernehmen ... aber es schien nicht zu funktionieren ...
Bitte sehen Sie unten für meinen Versuch, jede Hilfe wäre sehr dankbar.
http://stackoverflow.com/questions/38339593/shiny-loading-bar-for-htmlwidgets
Wäre es auch möglich, so etwas zu verwenden?...
Ich denke, Sie könnten https://getbootstrap.com/docs/3.4/components/#progress -animated verwenden.
@jcheng5 schlug vor, den "unbestimmten Modus" zu aktivieren, indem Sie value = NA
festlegen . Aber da dies als "animiert" bezeichnet wird, wäre es vielleicht flexibler, einen animated
Parameter hinzuzufügen, und so könnten Sie withProgress(..., value = 1, animate = TRUE)
Hilfreichster Kommentar
Eine andere Möglichkeit besteht darin, die Streifen einfach sichtbarer zu machen und den Fortschrittswert auf 1 zu setzen: