BaşlayınÜcretsiz Başlayın

Grafiğini etkileşimli yap

Shiny içinde etkileşimli grafikler oluşturmak için yaygın kullanılan bir paket olan plotly ile çalışacağız. Etkileşimli görselleştirmeler için başka paketler de var; ancak biz özellikle ggplotly() fonksiyonu sayesinde ggplot2 grafiğini etkileşimli bir grafiğe dönüştürdüğü için plotly kullanacağız.

Bu egzersiz

Vaka Çalışmaları: R ile Shiny Kullanarak Web Uygulamaları Geliştirme

kursunun bir parçasıdır
Kursu Görüntüle

Egzersiz talimatları

Önceki egzersizdeki Shiny uygulamasının kodu verildi. Görevin, ggplot2 grafiğini bir plotly grafiğiyle değiştirmek. Özellikle:

  • plotly paketini yükle.
  • Grafik çıktı fonksiyonunu plotlyOutput ile değiştir (satır 20).
  • Grafik oluşturma (render) fonksiyonunu renderPlotly ile değiştir (satır 29).
  • Mevcut ggplot2 grafiğini bir plotly grafiğine dönüştür (satır 31).

Uygulamalı interaktif egzersiz

Bu örnek kodu tamamlayarak bu egzersizi bitirin.

# Load the plotly package
___

ui <- fluidPage(
  sidebarLayout(
    sidebarPanel(
      textInput("title", "Title", "GDP vs life exp"),
      numericInput("size", "Point size", 1, 1),
      checkboxInput("fit", "Add line of best fit", FALSE),
      colourInput("color", "Point color", value = "blue"),
      selectInput("continents", "Continents",
                  choices = levels(gapminder$continent),
                  multiple = TRUE,
                  selected = "Europe"),
      sliderInput("years", "Years",
                  min(gapminder$year), max(gapminder$year),
                  value = c(1977, 2002))
    ),
    mainPanel(
      # Replace the `plotOutput()` with the plotly version
      plotOutput("plot")
    )
  )
)

# Define the server logic
server <- function(input, output) {
  # Replace the `renderPlot()` with the plotly version
  output$plot <- renderPlot({
    # Convert the existing ggplot2 to a plotly plot
    ___({
      data <- subset(gapminder,
                     continent %in% input$continents &
                       year >= input$years[1] & year <= input$years[2])
      
      p <- ggplot(data, aes(gdpPercap, lifeExp)) +
        geom_point(size = input$size, col = input$color) +
        scale_x_log10() +
        ggtitle(input$title)
      
      if (input$fit) {
        p <- p + geom_smooth(method = "lm")
      }
      p
    })
  })
}

shinyApp(ui = ui, server = server)
Kodu Düzenle ve Çalıştır