从闪亮的 R 中散点图的多个选择生成多个表

问题描述

我在闪亮的仪表板上有一个散点图,我想通过选择/突出显示散点图的不同区域来生成两个不同的表格。我目前可以通过选择/突出显示一个区域来生成一个表格,但是我不确定如何使这个工作适用于两个表格/选择(或者如果可能的话)。

任何帮助或建议将不胜感激。谢谢你

下面提供了用于生成带有散点图的闪亮仪表板并突出显示/生成单个表格的示例代码(取自 here

更多细节:理想情况下,此过程可以通过在某些点上手动选择/拖动区域,生成一个表格,然后在不同的点子集上手动选择/拖动区域和生成第二个表。在此之后,如果选择了另一个区域,它会重置第一个选择和表格,然后下一个选择将重置第二个选择和表格。

ui <- fluidPage(

  plotOutput("plot",brush = "plot_brush"),tableOutput("data")
)
server <- function(input,output,session) {
  output$plot <- renderPlot({
    ggplot(mtcars,aes(wt,mpg)) + geom_point()
  },res = 96)
  
  output$data <- renderTable({
    brushedPoints(mtcars,input$plot_brush)
  })
}
shinyApp(ui=ui,server=server)

解决方法

也许这可能会有所帮助。您可以跟踪 reactiveValues 中的哪个表(1 或 2)以及每个表的数据。让我知道这是否是您的想法。如果您想保留图中先前的选择,我认为您可能需要手动放置一个矩形。 github issue 允许多选刷点是一个开放的问题(增强)。或者,您可以根据 this approach 为每个表标记点。

library(shiny)

ui <- fluidPage(
  plotOutput("plot",brush = "plot_brush"),h2("Table 1"),tableOutput("data1"),h2("Table 2"),tableOutput("data2")
)

server <- function(input,output,session) {
  
  rv <- reactiveValues(table = 1,data1 = NULL,data2 = NULL)
  
  output$plot <- renderPlot({
    ggplot(mtcars,aes(wt,mpg)) + geom_point()
  },res = 96)
  
  my_data <- eventReactive(input$plot_brush,{
    if (rv$table == 1) {
      rv$table <- 2
      rv$data1 <- input$plot_brush
    } else {
      rv$table <- 1
      rv$data2 <- input$plot_brush
    }
    return(rv)
  })
  
  output$data1 <- renderTable({
    brushedPoints(mtcars,my_data()$data1)
  })
  
  output$data2 <- renderTable({
    brushedPoints(mtcars,my_data()$data2)
  })
  
}

shinyApp(ui=ui,server=server)