This R Markdown document is made interactive using Shiny. Unlike the more traditional workflow of creating static reports, you can now create documents that allow your readers to change the assumptions underlying your analysis and see the results immediately.
To learn more, see Interactive Documents.
You can embed Shiny inputs and outputs in your document. Outputs are automatically updated whenever inputs change. This demonstrates how a standard R plot can be made interactive by wrapping it in the Shiny renderPlot
function. The selectInput
and sliderInput
functions create the input widgets used to drive the plot.
inputPanel( selectInput("n_breaks", label = "Number of bins:", choices = c(10, 20, 35, 50), selected = 20), sliderInput("bw_adjust", label = "Bandwidth adjustment:", min = 0.2, max = 2, value = 1, step = 0.2) ) renderPlot({ hist(faithful$eruptions, probability = TRUE, breaks = as.numeric(input$n_breaks), xlab = "Duration (minutes)", main = "Geyser eruption duration") dens <- density(faithful$eruptions, adjust = input$bw_adjust) lines(dens, col = "blue") })
It's also possible to embed an entire Shiny application within an R Markdown document using the shinyAppDir
function. This example embeds a Shiny application located in another directory:
shinyAppDir( system.file("examples/06_tabsets", package="shiny"), options=list( width="100%", height=550 ) )
Note the use of the height
parameter to determine how much vertical space the embedded application should occupy.
You can also use the shinyApp
function to define an application inline rather then in an external directory.
In all of R code chunks above the echo = FALSE
attribute is used. This is to prevent the R code within the chunk from rendering in the document alongside the Shiny components.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.