Erstelle dein erstes Dashboard
Die Daten liegen als Data Frame soccer vor. Es gibt 3 vordefinierte Plots:
goals_plot: Die Anzahl der von jedem Team erzielten Toreyellow_plot,red_plot: Die Anzahl der gelben/roten Karten pro Team
Hier werden einige benutzerdefinierte Hilfsfunktionen verwendet:
daytime_fn(): Liefert Datum & Uhrzeit für ein bestimmtes Spielvenue_fn(): Liefert den Austragungsort für ein bestimmtes Spielgrp_fn(): Liefert die Gruppe des Duellsteam1_fn(),team2_fn(): Die Namen von Team 1/2score1_fn(),score2_fn(): Die Anzahl der von Team 1/2 erzielten Tore
Diese Übung ist Teil des Kurses
Dashboards mit shinydashboard erstellen
Anleitung zur Übung
- Fülle die Lücken für die Outputs in der ersten bis dritten Zeile des ersten Tabs/der ersten Seite.
- Fülle die Lücken für die Plot-Outputs auf der zweiten Seite aus; sie heißen „goals“, „yellow“ und „red“.
- Füge UI und Server zusammen, um das shinydashboard zu rendern.
Interaktive Übung
Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.
body <- dashboardBody(tabItems(
tabItem(tabName = "matchtab",
fluidRow(selectInput("match", "Match number", choices = 1:nrow(soccer)),
infoBoxOutput("daytime"), infoBoxOutput("venue"), infoBoxOutput("grp")),
fluidRow(valueBoxOutput("team1", width = 3), valueBoxOutput("score1", width = 3),
valueBoxOutput("team2", width = 3), valueBoxOutput("score2", width = 3)),
fluidRow(plotOutput("histogram"))),
tabItem(tabName = "statstab",
tabBox(tabPanel("Goals", plotOutput("goals", height = "700px")),
tabPanel("Yellow cards", plotOutput("yellow", height = "700px")),
tabPanel("Red cards", plotOutput("red"))))
))
ui <- dashboardPage(header, sidebar, body)
server <- function(input, output) {
# Fill in outputs in first to third rows of the first page
output$daytime <- renderInfoBox(infoBox("Day and time",
daytime_fn(input$match),
icon = icon("calendar"),
color = "green"))
output$venue <- ___(infoBox("Venue",
venue_fn(input$match),
icon = icon("map"),
color = "green"))
output$___ <- ___(___("Group",
grp_fn(input$match),
color = "green"))
output$team1 <- ___(valueBox("Team 1", team1_fn(input$match), color = "blue"))
output$score1 <- ___(___("# of goals", score1_fn(input$match), color = "blue"))
output$___ <- ___(valueBox("Team 2", team2_fn(input$match), color = "red"))
___ <- ___(valueBox("# of goals", score2_fn(input$match), color = "red"))
output$histogram <- renderPlot(plot_histogram(input$match))
# Fill in outputs in the second page
output$goals <- ___(goals_plot)
output$___ <- ___(yellow_plot)
___ <- ___(red_plot)
}
# Put the UI and server together
___