向闪亮的图添加超链接

Adding hyperlinks to Shiny plots

我制作了一个 Shiny 应用程序,使用不同的绘图解决方案在 Shiny 上渲染来自 ggplot2 的图表(我最喜欢的是 plotly)。
我喜欢用户可以与图表交互的事实:使用 plotly 用户可以放大图表或单击点(例如在散点图上)并访问它们的值。

我想 link 我散点图上的每个点到 URL (不显示它)并允许用户点击一个点,这将触发 hyper link 打开一个新网页。

如果我可以使用 plotly 来做到这一点,那将是惊人的,但我对任何其他类型的技术持开放态度(ggvisdygraph 等)。

Shiny 应用程序使用 plotly's postMessage API or plotly.js,它们都公开了 clickhoverzoom 事件。这些事件尚未作为底层闪亮服务器的回调公开,但可以通过自定义 javascript 访问它们,您可以在闪亮中为自己服务。

这里有一个点击事件的例子:

ui.R

library(shiny)
library(plotly)

shinyUI(fluidPage(
  mainPanel(
    plotlyOutput("trendPlot"),
    tags$head(tags$script(src="clickhandler.js"))
  )
))

server.R

library(shiny)
library(plotly)

x = c(1, 2, 3)
y = c(4, 2, 4)
links = c("https://plot.ly/r/", 
          "https://plot.ly/r/shiny-tutorial", 
          "https://plot.ly/r/click-events")

df = data.frame(x, y, links)

shinyServer(function(input, output) {

  output$trendPlot <- renderPlotly({
    # Create a ggplot
    g = ggplot(data=df, aes(x = x, y = y)) + geom_point()
    # Serialize as Plotly's graph universal format
    p = plotly_build(g)
    # Add a new key, links, that JS will access on click events
    p$data[[1]]$links = links
    p

    # Alternatively, use Plotly's native syntax. More here: https://plot.ly/r
    # plot_ly(df, x=x,y=y,links=links)
  })
})

www/clickhandler.js

$(document).ready(function(){
// boiler plate postMessage plotly code (https://github.com/plotly/postMessage-API)
var plot = document.getElementById('trendPlot').contentWindow;

pinger = setInterval(function(){
    plot.postMessage({task: 'ping'}, 'https://plot.ly')
}, 100);

var clickResponse = function(e) {
     plot = document.getElementById('trendPlot').contentWindow;
    var message = e.data;
     console.log( 'New message from chart', message );
    if(message.pong) {
        // tell the embedded plot that you want to listen to click events
        clearInterval(pinger);
        plot.postMessage({
              task: 'listen', events: ['click']}, 'https://plot.ly');
          plot.postMessage({
            task: 'relayout',
            'update': {hovermode: 'closest'},
        },
        'https://plot.ly');
    }
    else if(message.type === 'click') {
        var curveNumber = message['points'][0]['curveNumber'],
            pointNumber = message['points'][0]['pointNumber'];

        var link;
        var traces = message.points[0].data;
        if(traces !== null && typeof traces === 'object') {
            link = traces.links[pointNumber];
        } else {
            link = traces[curveNumber].links[pointNumber];
        }

        console.log(link);

        var win = window.open(link, '_blank');
        win.focus();
    }
};

window.addEventListener("message", clickResponse, false);

});

这里还有一些可能有用的资源: