【问题标题】:date vector input for dyEvents in dygraphs: R shinydygraphs中dyEvents的日期向量输入:R闪亮
【发布时间】:2015-01-31 15:58:25
【问题描述】:

我有日期向量,可以从下拉框中选择可以选择多个日期。通过选择这些日期,事件行将出现在已选择的日期。但是我看到 dyEvent 没有采用日期向量。当 dyEvent 中的日期被向量替换时,事件行不会出现。我提供了下面的代码。任何帮助将不胜感激。

ui.R
library(shiny)
library(dygraphs)
shinyUI(fluidPage(
  titlePanel("Tool"),
  sidebarLayout(
    sidebarPanel(
      uiOutput("choosedates")
      ),
    mainPanel(
      dygraphOutput("plot")
      )
  )
  ))


server.R
library(shiny)
library(dygraphs)
shinyServer(function(input, output) {
  Data<-data.frame(Time=seq(as.Date("7/29/2012","%m/%d/%Y"),as.Date("8/7/2012","%m/%d/%Y"),by="1 day"),Volume=c(100,150,120,300,250,50,100,120,80,100))
  output$choosedates<-renderUI({
    selectInput("dates","Choose dates to be marked by event line",as.character(Data$Time),multiple=TRUE)
  })
  library(xts)
  Dataxts<-reactive({
    xts(Data$Volume,order.by=as.Date(Data$Time,"%m/%d/%Y"))
  })
  output$plot<-renderDygraph({
    dygraph(Dataxts(), main = "Visualization")%>%
      dyEvent(date =as.character(input$dates), "Dummy", labelLoc = "bottom",color = "red", strokePattern = "dashed")%>%
      dyAxis("y", label = "Units sold in millions")%>%
      dyOptions(axisLabelColor = "Black",digitsAfterDecimal = 2,drawGrid = FALSE)
  })
  })

【问题讨论】:

  • 看起来问题在于您仍然在 for 循环的主体中时尝试将 dyEvent(...) 的结果转发。如果您提供足够的额外代码和数据来运行您的应用程序,那么帮助您会容易得多。
  • @nrussell 我稍微修改了我的方法并上传了类似的代码。
  • 我认为这是一种更好的方式,至少更短:stackoverflow.com/a/32837723/6253668

标签: r shiny dygraphs


【解决方案1】:

我之前没有使用过 dygraphs 包的任何经验,所以我不能保证这是最简单的方法,但我能够使用下面的代码使应用程序正常运行。


ui.R

library(shiny)
library(dygraphs)
##
shinyUI(fluidPage(

  titlePanel("Tool"),

  sidebarLayout(

    sidebarPanel(
      uiOutput("choosedates")
    ),

    mainPanel(
      dygraphOutput("plot")
    )
  )
))

server.R

library(shiny)
library(dygraphs)
library(xts)
##
shinyServer(function(input, output) {

  Data <- data.frame(
    Time=seq(as.Date("7/29/2012","%m/%d/%Y"),
             as.Date("8/7/2012","%m/%d/%Y"),
             by="1 day"),
    Volume=c(100,150,120,300,250,
             50,100,120,80,100))

  output$choosedates <- renderUI({
    selectInput(
      "dates",
      "Choose dates to be marked by event line",
      as.character(Data$Time),
      multiple=TRUE)
  })

  Dataxts <- reactive({
    xts(
      Data$Volume,
      order.by=as.Date(Data$Time,"%m/%d/%Y"))
  })
  ##
  getDates <- reactive({
    as.character(input$dates)
  })

  addEvent <- function(x,y) {
    dyEvent(
      dygraph=x,
      date=y,
      "Dummy", 
      labelLoc = "bottom",
      color = "red", 
      strokePattern = "dashed")
  }

  basePlot <- reactive({ 
    if (length(getDates()) < 1) {
      dygraph(
        Dataxts(),
        main="Visualization") %>%
        dyAxis(
          "y", 
          label = "Units sold in millions") %>%
        dyOptions(
          axisLabelColor = "Black",
          digitsAfterDecimal = 2,
          drawGrid = FALSE)
    } else {
      dygraph(
        Dataxts(),
        main="Visualization") %>%
        dyAxis(
          "y", 
          label = "Units sold in millions") %>%
        dyOptions(
          axisLabelColor = "Black",
          digitsAfterDecimal = 2,
          drawGrid = FALSE) %>%
        dyEvent(
          dygraph=.,
          date=getDates()[1],
          "Dummy", 
          labelLoc = "bottom",
          color = "red", 
          strokePattern = "dashed")
    }
  })
  ##
  output$plot <- renderDygraph({

    res <- basePlot()
    more_dates <- getDates()
    if (length(more_dates) < 2) {
      res
    } else {
      Reduce(function(i,z){
        i %>% addEvent(x=.,y=z)
      }, more_dates[-1], init=res)
    }

  })

})

主要变化是两个注释行之间的函数 (##)。我做了一个反应函数getDates(),它只返回当前选择的日期——我什至不确定这是否有必要,但这通常是我对用户输入所做的。更重要的是,我创建了一个(非反应性)函数 addEvent,它的定义方式便于与高阶函数 Reduce 一起使用 - 即 x 参数代表先前的状态( dygraph 正在累积的对象),y 参数是我们对先前状态(我们正在添加的行)所做的修改。

basePlot() 主要只是一个帮助函数,以避免在应用程序首次启动时最有可能产生的错误(并且没有选择日期输入)。如果没有选择日期,则输出基数dygraph,如果选择了一个或多个,则输出基图加上仅第一个日期线。

为了返回最终的绘图对象(output$plot),我们创建了基础绘图(res),并检查是否存在多个日期输入。如果用户请求两行或多行,我们使用Reduce 和UDF addEvent 来累积修改(日期行),使用res 作为初始值,第二个到最后一个日期输入作为修改值.


以下是一些正在运行的应用程序的屏幕截图:

启动:


第一个输入:


多个输入:

【讨论】:

  • 太棒了!我收到的最好的答案。谢谢@nrussell。你帮了大忙!
【解决方案2】:

我认为这是一个更好的解决方案,至少更短:

p <- dygraph(df_sub)
for (i in 1:dim(df_sub)[1]){
p <- p %>% dyEvent(date = df_sub$Date[i], label='xyz', labelLoc='bottom')
}

作者:user2996185 2015 年 9 月 29 日 7:06

https://stackoverflow.com/a/32837723/6253668

dynamically add events to dygraph r

【讨论】:

    猜你喜欢
    • 2020-02-03
    • 1970-01-01
    • 2014-05-15
    • 2017-07-25
    • 2016-12-18
    • 2015-05-10
    • 1970-01-01
    • 1970-01-01
    • 2014-04-19
    相关资源
    最近更新 更多