繁体   English   中英

闪亮的复选框

[英]Check box in shiny

我想创建一个闪亮的复选框,使我可以将输入变量之一的符号从正更改为负

来自输入:

sidebarLayout(
sidebarPanel(
  numericInput(inputId = "CE",
               label = "...:",
               min = 0,
               max = 1,
               value = 0.001),
  checkboxInput("CHECKBOX","Checkbox", FALSE), 

....

server <- function(input, output) 
output$Power_dropM <- renderText({
if(input$CHECKBOX=TRUE) {
  bzc <- -(sqrt(abs(input$CE)) * sign(input$CE))    
  bzm <- sqrt(abs(input$ME)) * sign(input$ME)   
}else{
bzc <- sqrt(abs(input$CE)) * sign(input$CE)     
bzm <- sqrt(abs(input$ME)) * sign(input$ME)     
}

生成的这些数字将在以后使用,因此我希望命名保持不变,只是通过选中复选框来更改符号。

这段代码不过给我一个错误:

Error in parse(file, keep.source = FALSE, srcfile = src, encoding = enc) : 
  C:/Users/ghmoen/Documents/SEM/ShinyApp210618.R:76:22: unexpected '='
75:     
76:     if(input$CHECKBOX=
                     ^
Error in sourceUTF8(fullpath, envir = new.env(parent = globalenv())) : 
  Error sourcing C:\Users\ghmoen\AppData\Local\Temp\Rtmp2T3R18\file57b0565138b6

在这种情况下,您的错误是由if(input$CHECKBOX=TRUE) 要检查是否相等,您需要使用double = ,所以if(input$CHECKBOX==TRUE) 在这种情况下,甚至可以简化为if(input$CHECKBOX) ,因为您的变量是布尔值。

顺便说一句,一种稍微简单的更改符号的方法可能是向变量添加+1-1的乘数。 例如,仅更改符号,您可以执行以下操作:

library(shiny)

# Create ui
ui <- fluidPage(
  numericInput('bzc','bzc',value=2),
  numericInput('bzm','bzm',value=2),
  checkboxInput('change_sign','Change sign'),
  textOutput('text')
)

server <- function(input, output) {

  output$text <- renderText({
    bzc = ifelse(input$change_sign,-1,1) * input$bzc
    bzm = input$bzm
    paste0('bzc: ', bzc, ', bzm: ', bzm)
  })

}

shinyApp(ui = ui, server = server)

暂无
暂无

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

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