Как получить фасетные данные из сюжетного события в Shiny - PullRequest
0 голосов
/ 18 января 2019

Я пытаюсь 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)

Я гуглял и не могу найти решение. Могу ли я передать что-нибудь, например, функции рендеринга, чтобы она получила фасет и могла отправить его назад в данные события?

1 Ответ

0 голосов
/ 18 января 2019

хорошо, вы можете видеть в примере кода, который вы адаптировали, что они «используют эстетику ключа / аргумент, чтобы помочь однозначно идентифицировать выбранные наблюдения».Почему бы вам не использовать его для идентификации фасета?

Вам нужно всего лишь изменить одну строку в вашем коде, изменив key = gear в пределах aes().

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...