如何在rgl R中自动移动轴标签

时间:2016-06-03 02:04:26

标签: r plot rgl

首先感谢任何花时间阅读我可怜的英语并帮助我解决问题的人(这是我的第一个问题)。

在rgl中,bbox-function写入的轴会自动移动,这样它们就不会遮挡数据。但轴标签不动。据我所知,title3d()和mtext3d()只能在固定位置写入轴标签。我通过将轴刻度实验室改为轴实验室来强制实现它。但图表很乱,而且该方法无法对待长实验室。有没有办法让自动移动实验室?

以下是我强制方法的示例代码:

library(rgl)
x <- rnorm(10, 3, 1); y <- rnorm(10, 4, 1); z <- rnorm(10, 2, 1)

open3d()
plot3d(x, y, z, type="s", col="red", radius=0.05, xlab="XX", ylab="YY", zlab="ZZ", box=F)
# Axes move automatically, but labels don't.

# My forcibly method's code
my.labaxes <- function(xlab, ylab, zlab, box = T) {
  my.xat <- pretty(par3d("bbox")[1:2])[ 2 : (length(pretty(par3d("bbox")[1:2]))-1) ]
  my.yat <- pretty(par3d("bbox")[3:4])[ 2 : (length(pretty(par3d("bbox")[3:4]))-1) ]
  my.zat <- pretty(par3d("bbox")[5:6])[ 2 : (length(pretty(par3d("bbox")[5:6]))-1) ]
  my.xlab <- my.xat
  my.ylab <- my.yat
  my.zlab <- my.zat
  my.xlab[round( length(my.xat) / 2 + 0.1)] <- xlab 
  my.ylab[round( length(my.yat) / 2 + 0.1)] <- ylab
  my.zlab[round( length(my.zat) / 2 + 0.1)] <- zlab
  if(box) axes3d("bbox", xat = my.xat, yat = my.yat, zat = my.zat, 
                 xlab = my.xlab, ylab = my.ylab, zlab = my.zlab, box = T)
  else axes3d("bbox", xat = my.xat, yat = my.yat, zat = my.zat, 
              xlab = my.xlab, ylab = my.ylab, zlab = my.zlab, box = F)
}

open3d()
plot3d(x, y, z, type="s", col="red", radius=0.05, xlab="", ylab="", zlab="", axes=F)
my.labaxes(xlab="XX", ylab="YY", zlab="ZZ", box=F)

plot

1 个答案:

答案 0 :(得分:1)

不,那是不可能的。只有曲线的标记和背景才会移动。您需要修改src / BBoxDeco.cpp中的代码以添加对移动标签的支持,然后对调用它的R代码进行大量修改。它真的不容易。