我正在创建一个简单的折线图,可以在 Shiny 中正确呈现。
我现在添加了一个 selectInput,其中包含 2 个不同度量的名称,按照它们在我的数据集中出现的方式编写。我希望我的 y 变量能够相应地改变。
p <- plot_ly(data = LineChartData(), x= Calendar.Month, y = input$Measure, type = "line", group = Calendar.Year, col = Calendar.Year)
不幸的是,图表仅显示一个点。它不是采用 input$Measure 并在我的数据集中查找该字段。
我知道使用 ggplot 时,我会将 aes 切换为 aes_string。情节中有类似的解决方案吗?
编辑:这是一些可重现的代码
这是 ui.R 文件
#ui.R
shinyUI(
fluidPage(
titlePanel("Inbound Intermediary Performance"),
sidebarLayout(
sidebarPanel(
h4("Parameters"),
br(),
selectInput("Measure", "Measure", c("Var1","Var2"))
),
mainPanel(
plotlyOutput("lineChart")
)
)
)
)
server.R
#server.R
library(plotly)
library(shiny)
library(ggplot2)
#Create data
data <- data.frame(Month = c(1,2,3,4,5,6,7,8,9,10,11,12), Var1 = c(36,33,30,27,24,21,18,15,12,9,6,3), Var2 = c(4,8,12,16,20,24,28,32,36,40,44,48))
shinyServer(function(input, output) {
#Create plot
output$lineChart <- renderPlotly({
#using ggplot
p <- ggplot(data=data, aes_string(x='Month', y = input$Measure)) +geom_line(size = 1.5) + theme_minimal()
ggplotly(p)
#Using PLotly
#p <- plot_ly(data = data, x= Month, y = input$Measure, type = "line")
})
})
在上面的示例中,我可以使用下拉菜单在 Var1 和 Var2 之间切换。我的情节也随之改变。该代码使用 ggplot 及其 aes_string 函数来获取输入。然后使用 ggplotly 函数将其转换为交互式绘图。
有没有办法可以用情节来本地完成此操作?