Shiny & networkD3 отвечает на щелчок узла
Я пытаюсь использовать networkD3 и блестящий, чтобы визуализировать некоторые данные. Я хотел бы, чтобы действие происходило при щелчке узла в графике. Я использую diagonalNetwork, как показано в коде ниже.
ForceNetwork имеет возможность сделать "действие клика", чтобы реагировать на нажатие узла. Однако я не могу найти подобную опцию для diagonalNetwork, есть ли другой способ реализовать это?
Спасибо за вашу помощь!
#### Load necessary packages and data ####
library(shiny)
library(networkD3)
data(MisLinks)
data(MisNodes)
hc <- hclust(dist(USArrests), "ave")
URL <- paste0(
"https://cdn.rawgit.com/christophergandrud/networkD3/",
"master/JSONdata//flare.json")
## Convert to list format
Flare <- jsonlite::fromJSON(URL, simplifyDataFrame = FALSE)
#### Server ####
server <- function(input, output) {
output$simple <- renderDiagonalNetwork({
diagonalNetwork(List = Flare, fontSize = 10, opacity = 0.9)
})
output$force <- renderForceNetwork({
forceNetwork(Links = MisLinks, Nodes = MisNodes, Source = "source",
Target = "target", Value = "value", NodeID = "name",
Group = "group", opacity = input$opacity)
})
##
#dendroNetwork(hc, height = 600)
#
# dendroNetwork(hc, height = 500, width = 800, fontSize = 10,
# linkColour = "#ccc", nodeColour = "#fff", nodeStroke = "steelblue",
# textColour = "#111", textOpacity = 0.9, textRotate = NULL,
# opacity = 0.9, margins = NULL, linkType = c("elbow", "diagonal"),
# treeOrientation = c("horizontal", "vertical"), zoom = FALSE)
}
#### UI ####
ui <- shinyUI(fluidPage(
titlePanel("Shiny networkD3 "),
sidebarLayout(
sidebarPanel(
sliderInput("opacity", "Opacity (not for Sankey)", 0.6, min = 0.1,
max = 1, step = .1)
),
mainPanel(
tabsetPanel(
tabPanel("Simple Network", diagonalNetworkOutput("simple")),
tabPanel("Force Network", forceNetworkOutput("force"))
)
)
)
))
#### Run ####
shinyApp(ui = ui, server = server)
1 ответ
Вы могли бы использовать htmlwidgets
"s onRender
функция прикрепить onclick
событие для узлов, как это...
library(shiny)
library(networkD3)
library(htmlwidgets)
URL <- paste0(
"https://cdn.rawgit.com/christophergandrud/networkD3/",
"master/JSONdata//flare.json")
Flare <- jsonlite::fromJSON(URL, simplifyDataFrame = FALSE)
clickJS <- 'd3.selectAll(".node").on("click", function(d){ alert(d.data.name); })'
server <- function(input, output) {
output$simple <- renderDiagonalNetwork({
onRender(diagonalNetwork(List = Flare, fontSize = 10, opacity = 0.9), clickJS)
})
}
ui <- fluidPage(
diagonalNetworkOutput("simple"),
tags$script(clickJS)
)
shinyApp(ui = ui, server = server)