我有一个关于 R Shiny 应用程序的一般性问题:我有一个最终用户可以在下拉菜单 ( selectInput) 中选择的 ID 列表,我希望根据这个 ID 制作相应的绘图。换句话说,所选变量将作为参数传递到绘图函数中,并且每次我选择不同的 ID 时,绘图也会发生变化。我可以知道这在 Shiny 中是否可行?如果有人可以提供有关类似问题的工作示例,我将不胜感激。谢谢!
			
			10139 次
		
1 回答
            15        
        
		
这是一个以下拉列表作为参数的示例工作示例。该程序的输出可以在http://glimmer.rstudio.com/bishwamitrad/ggplot2browser/上查看:
用户界面
library(shiny)
library(ggplot2)
## Define UI for miles per gallon application
dataset <- diamonds
title <- "Diamonds data Analysis"
## Define UI for application that plots random distributions
shinyUI(pageWithSidebar(
  ## Application title
  headerPanel(title),
  ## Sidebar with a slider input for number of observations
  sidebarPanel (
    sliderInput('sampleSize','Sample Size', min=1, max=nrow(dataset),
                value=min(1000,nrow(dataset)),
                step=500,
                round=0),
    selectInput('x','X',names(dataset)),
    selectInput('y','Y',names(dataset),
                names(dataset)[[2]]),
    selectInput('color','Color',c('None',names(dataset))),
    selectInput('shape','Shape',c('None',names(dataset))),
    checkboxInput('jitter','Jitter'),
    checkboxInput('smooth','Smooth'),
    selectInput('facet_col','Facet Column',
                c(None='.',names(dataset))),
    selectInput('facet_row','Facet Row',
                c(None='.',names(dataset)))
  ),
  ## Show a plot of the generated distribution
  mainPanel(plotOutput('plot',height="700px"))
)
)
服务器.R
library(shiny)
library(ggplot2)
## Define server logic required to generate and plot a random distribution
shinyServer(function(input,output) {
  dataset <- reactive(function(){
    diamonds[sample(nrow(diamonds),input$sampleSize),]
  })
output$plot <- renderPlot(function(){
  p <- ggplot(dataset(),aes_string(x=input$x, y=input$y))+geom_point()
  if(input$color != 'None')
    p <- p + aes_string(color=input$color)
  if (input$shape != 'None')
    p <- p + aes_string(shape=input$shape)
  facets <- paste(input$facet_row, '~', input$facet_col)
  if (facets != '. ~ .')
    p <- p + facet_grid(facets)
  if (input$jitter)
    p <- p + geom_jitter()
  if (input$smooth)
    p <- p + geom_smooth()
  print(p)
})
})
于 2013-07-14T01:23:34.983   回答