r - Shiny中的和弦网络覆盖自身
问题描述
我正在一个闪亮的应用程序中渲染一个和弦网络。我想做的是提供两种不同的网络表示。一个基于谁受谁影响,另一个基于谁影响谁。简而言之,我所代表的是一个版本中的数据集,以及该数据集在另一个版本中的转置。
我的问题是,当我渲染网络并切换输入时,新版本的图只是简单地覆盖在旧版本的图上。在显示下一个图之前,我需要以某种方式擦除上一个图。
这个最小的例子展示了默认的展示方式:
这就是我选择绘制转置数据时发生的情况(即我更改数据集)
如果我切换回原来的选择,它只会再次叠加。
我相信这个问题有一个简单的答案,我只是无法用谷歌搜索正确的词。
下面的最小可重现代码
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)
解决方案
有趣的错误!看起来问题实际上出在正在使用的包中。我很惊讶这个错误没有被报告,我猜人们并没有使用太多关于闪亮的东西?!
我通过在渲染小部件之前清除画布来修复错误。我不是 d3 专家,但我认为这可以chordNetwork.js
通过使用data().enter()
而不是在包中修复,datum()
但不幸的是我无法让它工作。
相反,它是通过在我们渲染任何绘图之前插入以下代码行来修复的。
d3.select(el).select("g").selectAll("g").remove() //Create a blank canvas
您可以在我的分叉存储库中访问此固定包,https://github.com/sada1993/networkD3。用于devtools::install_github("sada1993/networkD3")
安装包。
也许我们可以为此修复添加 PR?但看起来该软件包不再处于开发阶段。
这是查看更改的差异:https ://github.com/christophergandrud/networkD3/compare/master...sada1993:master
推荐阅读
- java - 如果条件为真,我正在尝试获取一个按钮以转到下一个活动,但它不起作用
- visual-studio-2013 - 按 LINQ 查询结果分组到 DataGridView
- java - 当我取消订阅 Observable 链时会发生什么?
- angular - 如何限制/定义 control.value 的类型(AbstractControl)
- ruby - 如何在 ruby 项目中要求本地库 mysql2
- javascript - 如何在字符串中替换但排除某些单词
- qt - Qt Woocommerce API 返回先前的订单数据
- arrays - 当 $array 仅包含一个 $null 元素时,为什么 $array -eq $null 不计算为 $true?
- sql - 为什么子查询不会产生重复的结果?
- angular - 具有条件显示/隐藏的动态角度形式组数组