4

这是我的基本闪亮应用程序的代码,它使用plotly_click事件来选择性地显示另一个情节。我希望该侧箱图在模式弹出窗口中呈现,而不是在页面内的一侧。

library(shiny)
library(plotly)

df1 <- data.frame(x = 1:10, y = 1:10)
df2 <- data.frame(x = c(rep('a', 10), rep('b', 10)),
                  y = c(rnorm(10), rnorm(10, 3, 1)))

ui <- fluidPage(
  column(6, plotlyOutput('scatter')),
  column(6, plotlyOutput('box'))
)

server <- function(input, output) {
  output$scatter <- renderPlotly({
    plot_ly(df1, x = x, y = y, mode = 'markers', source = 'scatter')
  })

  output$box <- renderPlotly({
    eventdata <- event_data('plotly_click', source = 'scatter')
    validate(need(!is.null(eventdata),
                  'Hover over the scatter plot to populate this boxplot'))


    plot_ly(df2, x = x, y = y, type = 'box')
  })
}

shinyApp(ui = ui, server = server)

我能够关注这个问题(Shiny: plot results in popup window)和响应,并尝试将它与triggerof一起使用但plotly_click没有成功。知道如何通过巧妙的悬停点击事件来完成同样的事情吗?

更新:我可以清楚地看到可以在模态弹出窗口plotly中呈现绘图,如此代码所示。shinyBS

df1 <- data.frame(x = 1:10, y = 1:10)
ui <- fluidPage(
  actionButton('go', 'Click Go'),
  bsModal('plotlyPlot', 'Here is a Plot', 'go', plotlyOutput('scatter1'))
)

server <- function(input, output) {
  output$scatter1 <- renderPlotly({
    plot_ly(df2, x = x, y = y, mode = 'markers', source = 'scatter1')
  })
}

shinyApp(ui = ui, server = server)

而不是actionButton作为触发器,我想要plotly_clickplotly_hover作为触发器(在原始示例中)。

4

2 回答 2

6

您可以使用toggleModal,只需将其添加到您的服务器:

observeEvent(event_data("plotly_click", source = "scatter"), {
 toggleModal(session, "boxPopUp", toggle = "toggle")
})

并将 box Plot 放在 bsModal 中(标题和触发器为空):

ui <- fluidPage(
  column(6, plotlyOutput('scatter')),
  bsModal('boxPopUp', '', '', plotlyOutput('box'))
)

更新:使用闪亮的内置模态功能(自闪亮 0.14 起),只需要添加服务器:

 observeEvent(event_data("plotly_click", source = "scatter"), {
                showModal(modalDialog(
                        renderPlotly({
                                plot_ly(df2, x = ~x, y = ~y, type = 'box')
                        })
                ))
        })
于 2016-09-15T09:19:12.970 回答
2

使用 CSS

您可以使用HTML builder来包含绘图并使用样式表来添加动态效果。

ui <- fluidPage(
  includeCSS(path_to_css_file),
  div( class='mainchart',
    column(6, plotlyOutput('scatter')),
    div(  class='popup',
        column(6, plotlyOutput('box'))
       )
    )
)

CSS

div.popup {
   display : none;
   position: absolute;
}
div.mainchart : focus > div.popup {
   display : block;
}
div.mainchart {
   position: relative;
}

使用 Javascript

您可以使用 plotly embeded -API来设置边箱的可见性。

闪亮的BS

既然你想坚持使用 shinyBS,你可以用bsPopover一个小技巧来使用这个功能。我假设您已经知道如何使用bsModel类似于下面的示例。

将以下参数传递给fluidPage

bsTooltip(id, title, placement = "bottom", trigger = "click", content=column(6, plotlyOutput('box'))  )

这将使用包装器创建绘图Popover。我还没有测试它。如果出现错误,您也可以尝试

options = list()
options$content = column(6, plotlyOutput('box'))
options$html = T # otherwise the conent will be converted to text
bsTooltip(id, title, placement = "bottom", trigger = "click",  options=options  )

访问这个shinyBS 的源文件 和 popover (options)函数以bootstrap获取更多信息。

于 2016-04-27T19:09:50.803 回答