每当一个情节对象由R在闪亮中创建(或仅在R中)时,窗口小部件将完全重新创建。对于小数据集,这不是问题,但我正在处理包含数千个散点的图,这使得在我的shinyapp中重建一个图需要10-20秒。
我正在寻找一种通过javascript解决方案更新数据的方法,该解决方案不会触发要重建的小部件,而只是替换它的数据。
这是一个虚拟应用程序,有2个小数据集,应用程序可以在这两个数据集之间切换。 在虚拟应用程序中,它通过重新创建窗口小部件来完成。由于数据点有限,这里相当快,但不适合海量数据集。
如果有人知道如何实现这一点,那将是我的应用程序的重大改进。
要澄清: 像这样的答案:enter link description here对我来说不会有诀窍。关键是,在我的应用程序数据在构建绘图之后多次更改,因此我无法预加载数据框列表。
我觉得解决方案必须是一个javascript解决方案,可以抓取数据来覆盖当前绘制的数据,但不知道如何或是否可以这样做。
library("shiny")
library("plotly")
ui <- fluidPage(
selectInput("dataset", "Choose a dataset:", choices = c("rock", "mtcars")),
plotlyOutput("Plot1")
)
server <- function(input, output, session) {
dataSource <- reactive({switch(input$dataset,"rock" = rock,"mtcars" = mtcars)})
output$Plot1 <- renderPlotly({plot_ly(data = dataSource(), x = dataSource()[,1],
y =dataSource()[,2], mode = 'markers', type = 'scatter')})
}
shinyApp(ui, server)
答案 0 :(得分:2)
查看可能对您的案例有用的这些资源:
这是让您入门的代码。你需要做一些工作来调整轴标签,但这不应该那么困难。
希望这有帮助!
代码:
library("shiny")
library("plotly")
ui <- fluidPage(
selectInput("dataset", "Choose a dataset:", choices = c("rock", "mtcars")),
plotlyOutput("Plot1")
)
server <- function(input, output, session) {
dataSource <- reactive({switch(input$dataset,"rock" = rock,"mtcars" = mtcars)})
output$Plot1 <- renderPlotly({plot_ly(data = rock, x = ~area,
y =~peri, mode = 'markers', type = 'scatter')})
observeEvent(input$dataset, {
f <- list(
family = "Courier New, monospace",
size = 18,
color = "#7f7f7f"
)
x <- list(
title = "x Axis",
titlefont = f,
range = c(0, 1000)
)
y <- list(
title = "y Axis",
titlefont = f,
range = c(0, 100)
)
plotlyProxy("Plot1", session) %>%
plotlyProxyInvoke("addTraces", list(x = dataSource()[,1],
y = dataSource()[,2],
type = 'scatter',
mode = 'markers')) %>%
plotlyProxyInvoke("deleteTraces", list(as.integer(0))) %>%
plotlyProxyInvoke("relayout", list(xaxis = x, yaxis = y))
})
}
shinyApp(ui, server)