rglwidget:无法替换以前的 3D 绘图

Die*_*nne 5 3d r rgl shiny

包中的例子rglwidget相当复杂;我shiny/rglwidget在下面创建了一个简单的示例。该图显示正常,但每次我切换复选框时,浏览器窗口中都会附加一个新图像。

如何替换/覆盖第一个图?

options(rgl.useNULL = TRUE)
library(shiny)
library(rglwidget)
library(rgl)

app = shinyApp(
  ui = bootstrapPage(
      checkboxInput("rescale", "Rescale"),
      rglwidgetOutput("rglPlot")
  ),
  server = function(input, output) {
    output$rglPlot <- renderRglwidget({
      try(rgl.close()) # added following @user2554330
      if (input$rescale) aspect3d(1,1,10) else aspect3d(1,1,1)
      # High level function following @user2554330: same effect
      # plot3d(rnorm(100), rnorm(100), rnorm(100,sd = 0.1), 
      #     col = rainbow(1000))
      spheres3d(rnorm(100), rnorm(100), rnorm(100,sd = 0.1), col = "red",
                radius = 0.1)
      axes3d()
      rglwidget()

    })
  })
runApp(app)
Run Code Online (Sandbox Code Playgroud)

会议信息:

R version 3.2.2 (2015-08-14)
Platform: i386-w64-mingw32/i386 (32-bit)
Running under: Windows 7 x64 (build 7601) Service Pack 1

locale:
[1] LC_COLLATE=German_Germany.1252  LC_CTYPE=German_Germany.1252   
[3] LC_MONETARY=German_Germany.1252 LC_NUMERIC=C                   
[5] LC_TIME=German_Germany.1252    

attached base packages:
[1] stats     graphics  grDevices utils     datasets  methods   base     

other attached packages:
[1] rgl_0.95.1429      rglwidget_0.1.1431 shiny_0.12.2      

loaded via a namespace (and not attached):
 [1] htmlwidgets_0.5.1 R6_2.1.1          rsconnect_0.4.1.9 htmltools_0.2.7  
 [5] tools_3.2.2       yaml_2.1.13       Rcpp_0.12.2       knitr_1.11       
 [9] jsonlite_0.9.19   digest_0.6.8      xtable_1.8-0      Cairo_1.5-9      
[13] httpuv_1.3.3      mime_0.4     
Run Code Online (Sandbox Code Playgroud)

use*_*330 2

它的作用就像 rgl ——当您使用低级命令(spheres3d、axes3d)时,它们会添加到现有绘图中。如果你想替换它,最简单的方法是先调用rgl.close()。next3d() 是另一种可能性,尽管略有不同。

或者,调用高级函数,如plot3d 或persp3d。他们在绘画前清理窗户。

编辑添加:我上面描述的是应该发生的事情。我看到重复的输出;他们是一个错误。我已经在 R-forge 的 0.1.1433 版本中修复了它。