Я пытаюсь shiny
, включая некоторые plotly
графики. Я хочу использовать реактивные события, поэтому при нажатии на график другой график обновляется на основе отфильтрованных данных. Дело в том, что на графике, для которого я хочу иметь событие click, есть фасеты, и я хочу отфильтровать данные на основе фасета, по которому щелкнули. Но, насколько я могу судить, информация о фасете не отправляется обратно в данные события.
Я упростил пример блестящих сюжетных событий , чтобы включить фасеты (см. Рисунок ниже), но ни одно из событий не получает информацию о фасете. В частности, event_data("plotly_click")
, который мне интересен, нигде не получает фасет, по которому щелкают.
library(plotly)
library(shiny)
ui <- fluidPage(
plotlyOutput("plot"),
verbatimTextOutput("hover"),
verbatimTextOutput("click"),
verbatimTextOutput("brush"),
verbatimTextOutput("zoom")
)
server <- function(input, output, session) {
output$plot <- renderPlotly({
# use the key aesthetic/argument to help uniquely identify selected observations
key <- row.names(mtcars)
p <- ggplot(mtcars, aes(x = mpg, y = wt, colour = factor(vs), key = key)) +
geom_point() +
facet_grid(rows = "gear")
ggplotly(p) %>% layout(dragmode = "select")
})
output$hover <- renderPrint({
d <- event_data("plotly_hover")
if (is.null(d)) "Hover events appear here (unhover to clear)" else d
})
output$click <- renderPrint({
d <- event_data("plotly_click")
if (is.null(d)) "Click events appear here (double-click to clear)" else d
})
output$brush <- renderPrint({
d <- event_data("plotly_selected")
if (is.null(d)) "Click and drag events (i.e., select/lasso) appear here (double-click to clear)" else d
})
output$zoom <- renderPrint({
d <- event_data("plotly_relayout")
if (is.null(d)) "Relayout (i.e., zoom) events appear here" else d
})
}
shinyApp(ui, server)
Я гуглял и не могу найти решение. Могу ли я передать что-нибудь, например, функции рендеринга, чтобы она получила фасет и могла отправить его назад в данные события?