首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >闪亮服务器中的动态颜色输入

闪亮服务器中的动态颜色输入
EN

Stack Overflow用户
提问于 2014-10-27 18:09:31
回答 1查看 2.5K关注 0票数 5

我试图创建一个应用程序使用闪亮,在那里,我希望用户能够选择每一行的颜色在一个情节。总的思想是导入应用程序中的数据,然后绘制数据中的每个变量。我尝试使用shinysky包中的色选择器'jscolorInput‘,当将它放在ui.r文件中时,它工作得很好,但是由于我希望我的应用程序对上传的每个数据集都是动态的,所以我需要使用一个反应性函数将色素选择器放到server.R中。当放置在服务器中时,“jscolorInput”无法工作。

我想做的是:

  1. 复制着色器的次数与数据中的变量数一样多。
  2. 从颜色中获取输入,并将其作为颜色参数传递到绘图中。

我是一个非常新的发展和堆叠溢出,所以请原谅我的错误。

这里有一个可重复的例子,它不起作用。

代码语言:javascript
复制
require(shinysky)
require(shiny)

dat <- data.frame(matrix(rnorm(120, 2, 3), ncol=3))

runApp(list(
ui = bootstrapPage(
    # The reactive colorpicker
    uiOutput('myPanel'),
    # The plot
    plotOutput('plot')
),
server = function(input, output) {
    # Print as many colorpickers as the columns in the dataset
    cols <- reactive({
        n <- ncol(dat)
        for(i in 1:n){
            print(jscolorInput(paste("col", i, sep="_")))    
        }
    })

        output$myPanel <- renderPrint({cols()})
    # Put all the input in a vector
    colors <- reactive({
        n <- ncol(dat)
        lapply(1:n, function(i) {
            input[[paste("col", i, sep="_")]]
        })
    })

    output$plot <- renderPlot({
        cols <- ifelse(is.null(input$col_1), rep("000000 ", n), colors()) 
        plot(dat[,1], col= paste0("#", cols[1], ""))
                                for(i in 2:ncol(dat))lines(dat[,i], col=cols[i])
    })

}
))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-06-22 23:40:47

这是你想要做的事情的一个工作版本。看看我们的代码之间的差异,您的代码有一些问题。另外,请注意,我没有使用shinysky,因为它已经没有颜色选择器了(它移到了另一个不活动的包中),所以我使用的是来自shinyjsinputColour

代码语言:javascript
复制
library(shiny)
library(shinyjs)

dat <- data.frame(matrix(rnorm(120, 2, 3), ncol=3))

runApp(shinyApp(
  ui = fluidPage(
    uiOutput('myPanel'),
    plotOutput("plot")
  ),
  server = function(input, output, session) {
    cols <- reactive({
      lapply(seq_along(dat), function(i) {
        colourInput(paste("col", i, sep="_"), "Choose colour:", "black")        
      })
    })

    output$myPanel <- renderUI({cols()})

    # Put all the input in a vector
    colors <- reactive({
      lapply(seq_along(dat), function(i) {
        input[[paste("col", i, sep="_")]]
      })
    })

    output$plot <- renderPlot({
      if (is.null(input$col_1)) {
        cols <- rep("#000000", ncol(dat))
      } else {
        cols <- unlist(colors())
      }
      plot(dat[,1], col = cols[1])
      for(i in 2:ncol(dat)) lines(dat[,i], col = cols[i])
    })
  }
))

免责声明:我是shinyjs的作者

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26594027

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档