Crea una nuova word cloud su richiesta
Dopo aver isolato il codice di rendering della word cloud per evitare aggiornamenti troppo frequenti, l'ultimo passo è offrire un modo per generarla solo quando l'utente lo desidera. Questo si può ottenere con l'aiuto di un actionButton().
Questo esercizio fa parte del corso
Casi di studio: creare applicazioni web con Shiny in R
Istruzioni dell'esercizio
Il tuo compito è aggiungere un pulsante all'app Shiny e rigenerare la word cloud quando il pulsante viene premuto. In particolare:
- Aggiungi un pulsante di tipo action all'app con ID di input "draw" e etichetta "Draw!" (riga 26).
- Aggiungi il pulsante come dipendenza nella funzione di rendering della word cloud in modo che venga rieseguita quando il pulsante è premuto (riga 56).
Esercizio pratico interattivo
Prova a risolvere questo esercizio completando il codice di esempio.
ui <- fluidPage(
h1("Word Cloud"),
sidebarLayout(
sidebarPanel(
radioButtons(
inputId = "source",
label = "Word source",
choices = c(
"Art of War" = "book",
"Use your own words" = "own",
"Upload a file" = "file"
)
),
conditionalPanel(
condition = "input.source == 'own'",
textAreaInput("text", "Enter text", rows = 7)
),
conditionalPanel(
condition = "input.source == 'file'",
fileInput("file", "Select a file")
),
numericInput("num", "Maximum number of words",
value = 100, min = 5),
colourInput("col", "Background color", value = "white"),
# Add a "draw" button to the app
___(inputId = ___, label = ___)
),
mainPanel(
wordcloud2Output("cloud")
)
)
)
server <- function(input, output) {
data_source <- reactive({
if (input$source == "book") {
data <- artofwar
} else if (input$source == "own") {
data <- input$text
} else if (input$source == "file") {
data <- input_file()
}
return(data)
})
input_file <- reactive({
if (is.null(input$file)) {
return("")
}
readLines(input$file$datapath)
})
output$cloud <- renderWordcloud2({
# Add the draw button as a dependency to
# cause the word cloud to re-render on click
input$___
isolate({
create_wordcloud(data_source(), num_words = input$num,
background = input$col)
})
})
}
shinyApp(ui = ui, server = server)