我正在一个闪亮的应用程序中渲染一个和弦网络。我想做的是提供两种不同的网络表示。一个基于谁受谁影响,另一个基于谁影响谁。简而言之,我所代表的是一个版本中的数据集,以及该数据集在另一个版本中的转置。
我的问题是,当我渲染网络并切换输入时,新版本的图只是简单地覆盖在旧版本的图上。在显示下一个图之前,我需要以某种方式擦除上一个图。
这个最小的例子展示了默认的展示方式:
这就是我选择绘制转置数据时发生的情况(即我更改数据集)
如果我切换回原来的选择,它只会再次叠加。
我相信这个问题有一个简单的答案,我只是无法用谷歌搜索正确的词。
下面的最小可重现代码
library(shiny)
library(networkD3)
Data <- matrix(c(NA, 1951, 8010, 1013,
5871, NA, 16145, 990,
8916, 2060, NA, 940,
2868, 6171, 8045, NA), nrow = 4)
ui <- fluidPage(
titlePanel("Chord network"),
mainPanel( htmlOutput("inputDataChoice"),
chordNetworkOutput(outputId = "chord_network", width = "600px", height = "600px")
)
)
server <- function(input, output) {
#Choose the data type
output$inputDataChoice <- renderUI({
selectInput(inputId = "dataChoice", label = "Choose data shape",
choices=c("Influenced", "Influences"),
width = "450px"
)})
#Dataset shape based on choice
chordData <- reactive({
switch(input$dataChoice,
"Influenced" = Data,
"Influences" = t(Data))
})
#Plot
observe ({
output$chord_network <- renderchordNetwork({
chordNetwork(chordData(),
padding = 0.1,
colourScale = c("#000000",
"#FFDD89",
"#957244",
"#F26223"),
labels = c("Bob", "Brenda", "Barry", "Belinda"))
})})
}
shinyApp(ui = ui, server = server)