将图例添加到scatter3d图中

Bod*_*dha 6 3d plot r

交互式3D图的可能包之一是rgl.我想要做的是根据某个因子变量构建带有颜色编码的3D散点图.3D维度散点图用于从plsr分析得到的加载量.

结果情节看起来像

根据变量组的颜色编码的PLS加载的3D散点图

示例的数据在一个表中给出:

> loadings

      |      Comp 1         |        Comp 2            |    Comp 3           | Class
-------------------------------------------------------------------------------------------                    
TEMP  | -0.0607044182964255 | "0.0437618450165671"     |"0.045124991801441"  | "global"  
MW    | "-0.13414890573833" |   "-0.0970537799069731"  |0.263043734662182"   | "local" 
DM    |"-0.183751529577861" |  "-0.102703237685933"    |"0.0640549385564205" | "global" 
CHG   |"-0.0558781715833019"| "0.125155347350922"      |"-0.119258450107321" | "local"
Run Code Online (Sandbox Code Playgroud)

或者可以生成:

loadings <- data.frame(Comp1 = c(1.2, 3.4, 5.6, 13.1), Comp2 = c(4.3, 1.2, 7.7, 9.8),
                       Comp3 = c(1.2,6.9,15.6,15.0), 
                       row.names = c("TEMP", "MW", "DM", "CHG"), 
                       Class = c("global", "local", "global", "local"))
scatter3d(x=loadings[[1]], y=loadings[[2]], z=loadings[[3]], 
          point.col = as.numeric(as.factor(loadings[,4])), size = 10)
Run Code Online (Sandbox Code Playgroud)

获得的情节具有相同的风格,但更简单,因为只有两个级别的变量"类":"全局"和"本地"

在此输入图像描述

问题是:是否有可能在rgl中添加图例或者某些独立的图例可以附加到图中?在此先感谢您的帮助!

答案是:

scatter3d(x=loadings[[1]], y=loadings[[2]], z=loadings[[3]], 
          point.col = as.numeric(as.factor(loadings[,4])), size = 10, type = 's')
text3d(x=1.1, y=c(.9,1), z=1.1,levels(loadings[[4]]),col="black")
points3d(x=1.2,y=c(.9,1),z=1.1, col=as.numeric(as.factor(loadings[,4])), size=5)
Run Code Online (Sandbox Code Playgroud)

根据类别标注的情节: 在此输入图像描述

42-*_*42- 1

这不是一个plot3d图像(除非您可能加载了另一个包),但看起来像是使用 John Fox 包中的函数scatter3d构建的渲染:scatter3dcar

  require(rgl)
  require(car)
  scatter3d(x=loadings[[1]], y=loadings[[2]], z=loadings[[3]], 
            point.col = as.numeric(as.factor(loadings[,4])), size = 10)
Run Code Online (Sandbox Code Playgroud)

scatter3d函数确实依赖于 rgl 函数,但有很多自定义选项。您没有提供构建“图例”的代码,因此我尝试了 rgl::text3d 中提供的示例:

 text3d(1+ font/8, 1+cex/4, 1+famnum/8, text=paste(family, font), adj = 0.5, 
       color="blue", family=family, font=font, cex=cex)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

使用新数据,这是对文本和点的请求的响应:

 scatter3d(x=loadings[[1]], y=loadings[[2]], z=loadings[[3]], 
             point.col = as.numeric(as.factor(loadings[,4])), size = 10)
 text3d(x=1.1, y=c(.9,1,1.1), z=1.1, names(loadings) ,col="black")
 points3d(x=1.2,y=c(.9,1,1.1),z=1.1, col=as.numeric(as.factor(loadings[,4])), size=5)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述