1

为什么在下面的代码示例中renderImage()无法识别:input

library(d3heatmap)
library(shiny)
library(ggplot2)


    ui <- fluidPage(
      h1("A heatmap demo"),
      selectInput("palette", "Palette", c("YlOrRd", "RdYlBu", "Greens", "Blues")),
      checkboxInput("cluster", "Apply clustering"),
      downloadButton('downloadPlot', 'Download Heatmap'),
      d3heatmapOutput("heatmap")
)

    server <- function(input, output, session) {

      output$heatmap <- renderD3heatmap({
        d3heatmap(
          scale(mtcars),
          colors = input$palette,
          dendrogram = if (input$cluster) "both" else "none"
) })

    output$downloadPlot <- renderImage(
        d3heatmap(scale(mtcars), colors = input$palette, dendrogram = if (input$cluster) "both" else "none"), 
        env = parent.frame(), 
        quoted = FALSE, 
        deleteFile = FALSE
        )

    }

shinyApp(ui = ui, server = server)

这是我的错误:

Error in match.arg(dendrogram) : object 'input' not found

当我删除该dendrogram = if (input$cluster) "both" else "none"行时,我input再次收到以下错误:

Error in toPaletteFunc(pal) : object 'input' not found

input找不到该对象似乎有点违反直觉,因为我已经在楼上明确定义了它: server <- function(input, output, session)

我已经检查了生成类似错误消息的现有 Stack Overflow 帖子(例如,R Shiny error: object input not found)。

上面的代码示例的灵感来自:https ://cran.r-project.org/web/packages/d3heatmap/d3heatmap.pdf

4

1 回答 1

3

d3heatmap()产生htmlwidgets类对象。我们可以使用包中saveWidget()的函数htmlwidgets来保存绘图。

library(d3heatmap)
library(shiny)
library(htmlwidgets)

ui <- fluidPage(
    h1("A heatmap demo"),
    selectInput("palette", "Palette", c("YlOrRd", "RdYlBu", "Greens", "Blues")),
    checkboxInput("cluster", "Apply clustering"),
    downloadButton('download', 'Download Heatmap'),
    d3heatmapOutput("heatmap")
)
server <- function(input, output, session) {
    plot <- reactive({
        d3heatmap(
            scale(mtcars),
            colors = input$palette,
            dendrogram = if (input$cluster) "both" else "none"
        )
    })
    output$heatmap <- renderD3heatmap({
        plot()
    })
    output$download <- downloadHandler(
        filename = function() {
            paste0("d3heatmap-", tolower(input$palette), ".html")
        },
        content = function(file) {
            saveWidget(plot(), file)
        }
    )
}

shinyApp(ui = ui, server = server)

如果您需要将绘图保存为 png,请参阅此讨论:https ://github.com/ramnathv/htmlwidgets/issues/95 。简而言之:现在htmlwidgets不支持将绘图导出为 png 或 svg。您可以将exportwidgetwebshot包视为工作区。

于 2015-12-27T09:44:47.440 回答