【发布时间】:2015-07-01 00:00:36
【问题描述】:
我正在尝试使用闪亮构建交互式散点图。使用 iris 数据,我想让用户选择散点图 *petal vs sepal) 的 x 和 y 维度,然后输出所选维度的简单散点图。很简单。
首先,我需要构建一个函数,允许我将表示尺寸的字符串传递给 ggplot。我这样做并用静态数据对其进行了测试。工作正常。
接下来,我为花瓣和萼片尺寸(这些是我的 x 和 y 轴)定义两个下拉列表和两个后续字符串(使用闪亮)。
接下来我使用shiny 的reactive() 函数使用switch 语句设置两个字符串变量。
这似乎是出了问题的地方。
我得到的错误是:错误:无法将“闭包”类型强制转换为“字符”类型的向量
我已经采取了一些步骤来调试我的代码。我首先将硬编码尺寸(例如“Petal.Length”)插入代码的最后一行 output$myplot = renderPlot({myplotfunct( ...
这很好用。情节按照我的预期呈现。
然后我添加了一个调试行来跟踪我正在传递这个绘图函数的字符串的值。答对了。它是空的。为什么它是空??似乎应该从 UI.r 文件中传递一个值。
代码如下。
任何帮助将不胜感激。谢谢!
UI.R
library(shiny)
# Define UI for dataset viewer application
shinyUI(fluidPage(
# Application title
titlePanel("Shiny Text"),
# Sidebar with controls to select a dataset and specify the
# number of observations to view
sidebarLayout(
sidebarPanel(
selectInput("dataset1", "Choose a Sepal Measure:",
choices = c("Sepal Length", "Sepal Width")),
selectInput("dataset2", "Choose a Petal Measure:",
choices = c("Petal Length", "Petal Width"))
),
# Main Scatter Plot
mainPanel(
textOutput("testvar"),
plotOutput("myplot")
)
)
))
Server.R
library(shiny)
library(datasets)
library(ggplot2)
#Define a function to plot passed string variables in ggplot
myplotfunct = function(df, x_string, y_string) {
ggplot(df, aes_string(x = x_string, y = y_string)) + geom_point()
}
shinyServer(function(input, output) {
# Sepal Inputs
datasetInput1 <- reactive({
switch(input$dataset1,
"Sepal Length" = "Sepal.Length",
"Sepal Width" = "Sepal.Width")
})
# Petal Inputs
datasetInput2 <- reactive({
switch(input$dataset2,
"Petal Length" = "Petal.Length",
"Petal Width" = "Petal.Width")
})
#Debug print value of sting being passed
output$testvar = renderText(print(datasetInput1))
# Plot
output$myplot = renderPlot({myplotfunct(iris, datasetInput1, datasetInput2)})
})
【问题讨论】:
-
您需要在
myplotfunct()通话中使用datasetInput1(), datasetInput2()吗?