首先感谢任何花时间阅读我可怜的英语并帮助我解决问题的人(这是我的第一个问题)。
在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)
答案 0 :(得分:1)
不,那是不可能的。只有曲线的标记和背景才会移动。您需要修改src / BBoxDeco.cpp中的代码以添加对移动标签的支持,然后对调用它的R代码进行大量修改。它真的不容易。