如何使用c3库闪亮?如何创建一个简单的仪表图表?

时间:2017-08-19 10:17:12

标签: r shiny c3.js gauge

我应该如何使用c3库?我已经安装了它并试图显示一个简单的仪表图表。

以下是ui.Rserver.R的代码:

server.R

library(shiny)
library(c3)
shinyServer(function(input, output) {


observeEvent(input$button, {

output$name <- renderText({
paste("Welcome ",input$name,". This is your Assesment result!")})
output$nl <- renderText({input$nl})

whrs <- input$whrs

if(whrs == 10) {
  point <- 20
} else if (whrs == 8 || whrs == 9) {
  point <- 18
} else if (whrs == 7 || whrs == 6) {
  point <- 12
} else if(whrs == 5) {
  point <- 8
} else {

point <- 0
}

pwhrs <- point
nl <- input$nl

if(nl == 10) {
  point <- 20
} else if (nl == 8 || whrs == 9) {
  point <- 18
} else if (nl == 7 || whrs == 6) {
  point <- 12
} else if(nl == 5) {
  point <- 8
} else {

point <- 0
}
pnl <- point


output$pwhrs <- renderText({pwhrs})
output$pnl <- renderText({pnl})

output$plot <- renderPlot({
gauge.chart <- data.frame(red=20,green=45,blue=10) %>% 
  c3() %>% 
c3_gauge(title= 'Colours')

})
})

})

和我的ui.R

library(shiny)

shinyUI(fluidPage(
  hr(),
titlePanel("Summary"),
hr(),
sidebarLayout(
sidebarPanel(
  textInput("name","Enter your name",""),
numericInput("whrs","How many hours do you work daily?","0",min=0,max=10),
numericInput("nl","How many leaves do you take per month?","0",min= 0,max=20),
numericInput("bhr","How many hours of break do you take daily?","0",min= 0,max=10),
selectInput("wrkdlvr","How often you complete your works?",choices=c("On time","Before Deadline","Delayed")),
selectInput("consleave","How often you leaves are consecutive?",choices=c("Never","Always","Not Applicable")),
actionButton("button", "Calculate")
),
  mainPanel(("About this tool"),
   p(helpText("Try this tool to assess yourself.
    You need to work for a minimum of 9 hrs per day.")),
helpText("This tool will ask for some parameters and based on the input you will 
  be assessed"),
hr(),
  textOutput("name"),
textOutput("pwhrs"),
textOutput("pnl"),
plotOutput("plot"),
  hr()
  )
  ),
hr()
))

根据用户输入生成简单的仪表图需要做些什么?图表的最大限制为100,并根据用户输入设置要显示的值。怎么做到这一点?

是否有必要在ui.Rserver.R中添加c3库? (请告诉我是否需要添加两个文件中使用的任何其他库。)

shinyshinydashboard库几乎相同吗?

1 个答案:

答案 0 :(得分:2)

您需要在服务器中使用renderC3代替renderPlot,并在ui中使用c3Output代替plotOutput

shinydashboardshiny的区别主要在于UI外观(ui脚本也不同),背后的逻辑是相同的。

如果想尝试一下,我写了一个非常类似于c3billboarder的包,你也可以做规范图表,你可以安装它:

devtools::install_github("dreamRs/billboarder")

用你的例子给出(我将输出放在观察者之外,这是一种更好的做法,并使用reactiveValues来存储点数):

library("shiny")
library("billboarder")

ui <- fluidPage(
  fluidPage(
    hr(),
    titlePanel("Summary"),
    hr(),
    sidebarLayout(
      sidebarPanel(
        textInput("name","Enter your name",""),
        numericInput("whrs","How many hours do you work daily?","0", min = 0, max = 10),
        numericInput("nl","How many leaves do you take per month?","0", min = 0, max = 20),
        numericInput("bhr","How many hours of break do you take daily?","0", min = 0,max = 10),
        selectInput("wrkdlvr","How often you complete your works?", choices = c("On time", "Before Deadline", "Delayed")),
        selectInput("consleave", "How often you leaves are consecutive?", choices = c("Never", "Always", "Not Applicable")),
        actionButton("button", "Calculate")
      ),
      mainPanel(
        "About this tool",
        p(helpText("Try this tool to assess yourself.",
                   "You need to work for a minimum of 9 hrs per day.")),
        helpText("This tool will ask for some parameters and based on the input you will",
                 "be assessed"),
        hr(),
        textOutput(outputId = "name"),
        textOutput(outputId = "pwhrs"),
        textOutput(outputId = "pnl"),
        billboarderOutput(outputId = "gauge"),
        hr()
      )
    ),
    hr()
  )
)

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

  output$name <- renderText({
    paste0("Welcome ", input$name, ". This is your Assesment result!")
  })
  output$nl <- renderText({input$nl})

  points <- reactiveValues(pwhrs = 0, pnl = 0)

  observeEvent(input$button, {
    whrs <- input$whrs

    if(whrs == 10) {
      point <- 20
    } else if (whrs == 8 | whrs == 9) {
      point <- 18
    } else if (whrs == 7 | whrs == 6) {
      point <- 12
    } else if(whrs == 5) {
      point <- 8
    } else {

      point <- 0
    }

    points$pwhrs <- point
    nl <- input$nl

    if(nl == 10) {
      point <- 20
    } else if (nl == 8 | nl == 9) {
      point <- 18
    } else if (nl == 7 | nl == 6) {
      point <- 12
    } else if(nl == 5) {
      point <- 8
    } else {
      point <- 0
    }
    points$pnl <- point
  })

  output$pwhrs <- renderText({points$pwhrs})
  output$pnl <- renderText({points$pnl})


  output$gauge <- renderBillboarder({
    billboarder() %>% 
      bb_gaugechart(value = points$pnl + points$pwhrs)
  })

}

shinyApp(ui = ui, server = server)