繁体   English   中英

单击 R Shiny 中的交互式 Plot

[英]Click Interactive Plot in R Shiny

我正在尝试创建一个带有一堆框的 plot ,然后当单击一个框时,它会被着色。 我有两个问题。 1.我想不出一种方法让我点击时动态更新图形。 2. 我不知道如何存储来自 click 输入变量的值,以便我存储所有以前的点击并能够在多个框中着色。 您可以看到我尝试解决和测试这两个问题中的任何一个的几种方法,但我没有任何运气。 对于这两个问题的任何帮助将不胜感激。

ui <- fluidPage(
   
   # Application title
   titlePanel("Boxes"),
   
   sidebarLayout(
      sidebarPanel(
         textOutput("text")),
      
      # Get it it's a pun
      mainPanel(
         plotOutput("boxPlot",click = "test")
      )
   )
)

# Define server logic required to draw a histogram
server <- function(input, output) {
  
  vals <- reactiveValues(x=NA,y=NA,test=NA)
  observeEvent(input$click, {
    vals$x <- c(vals$x,input$test$x)
    vals$y <- c(vals$y,input$test$y)
    vals$test <- input$test$x
  })
  
  output$boxPlot <- renderPlot({
    
    par(mai=c(0,0,0,0))
    plot(1,ylim=c(2,15),xlim=c(2,15),type='n',yaxs='i',xaxs='i',ylab='',xlab='',axes=F)
    for (i in 2:15) {
      abline(v=i)
      abline(h=i)
    }
    observeEvent(input$click, {      rect(floor(input$test$x),floor(input$test$y),ceiling(input$test$x),ceiling(input$test$y),col='blue')})
    # if (length(vals$x) > 0) {
      # rect(floor(vals$x[1]),floor(vals$y[1]),ceiling(vals$x[1]),ceiling(vals$y[1]),col='blue')
    # }
  })
  # output$text <- renderText(vals$x[length(vals$x)])
  output$text <- renderText(vals$test)
  
}
# Run the application 
shinyApp(ui = ui, server = server)

这可能是一个简单的解决方案。

您的点击事件应该只有一个observeEvent 在该observeEvent中,将您的 x 和 y 值存储为当前正在执行的reactiveValues

然后,您的renderPlot应该 plot 网格线并根据您的reactiveValues填充矩形。 通过在renderPlot中包含input$boxPlot_click (我称之为),每次单击都会重绘 plot。

library(shiny)

ui <- fluidPage(
  titlePanel("Boxes"),
  sidebarLayout(
    sidebarPanel(
      textOutput("text")),
    mainPanel(
      plotOutput("boxPlot", click = "boxPlot_click")
    )
  )
)

server <- function(input, output) {
  
  vals <- reactiveValues(x=NA,y=NA)
  
  observeEvent(input$boxPlot_click, {
    vals$x <- c(vals$x,input$boxPlot_click$x)
    vals$y <- c(vals$y,input$boxPlot_click$y)
  })
  
  output$boxPlot <- renderPlot({
    input$boxPlot_click
    par(mai=c(0,0,0,0))
    plot(1,ylim=c(2,15),xlim=c(2,15),type='n',yaxs='i',xaxs='i',ylab='',xlab='',axes=F)
    for (i in 2:15) {
      abline(v=i)
      abline(h=i)
    }
    for (i in seq_along(length(vals$x))) {
      rect(floor(vals$x),floor(vals$y),ceiling(vals$x),ceiling(vals$y),col='blue')
    }
  })
  
  output$text <- renderText(paste0(vals$x, ', ' , vals$y, '\n'))
  
}

shinyApp(ui = ui, server = server)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM