R 中有吸引力的 3D 绘图 [英] Attractive 3D plot in R

查看:28
本文介绍了R 中有吸引力的 3D 绘图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在写一个提案,需要一个像这样的 3D 绘图:

I am writing a proposal and need a 3D plot something like this:

但最好更有吸引力.我需要每个点的大小来反映物种的丰富程度,以及通过连接点创建的体积轮廓.

but preferably more attractive. I need the size of each point to reflect the abundance of the species and an outline of the volume created by connecting the points.

示例数据:

input<-data.frame(
label=c("sp1","sp2","sp3","sp4"),
trait_x=c(6,6,6,1),
trait_y=c(7,7,7,1),
trait_z=c(8,8,8,1),
point_size=c(6,7,8,1)
)
input
  label trait_x trait_y trait_z point_size
1   sp1       6       7       8        6
2   sp2       6       7       8        7
3   sp3       6       7       8        8
4   sp4       1       1       1        1

关于如何使这样的图表更具吸引力的任何建议(也许包括网格线?但是我不希望轴上有任何数字)

Any suggestion on how to make such a graph more attractive (perhaps including gridlines? I do not want any numbers on the axes however)

我玩过 scatterplot3d,但它没有绘制我所有的点,而且我个人发现立方体的外观很奇怪......好像它不太准确.......

I have played around with scatterplot3d, but it doesn't plot all my points and I personally find that the cube has a strange look to it... like it is not quite accurate...

library(scatterplot3d)
x<-input$trait_x
y<-input$trait_y
z<-input$trait_z
scatterplot3d(x,y,z,xlim=c(0,10),ylim=c(0,10),zlim=c(0,10))

推荐答案

这应该会让您开始使用 rgl 包.注意:重新阅读时,我发现我使用的 xyz 坐标与您使用的略有不同,但概念是相同的.

This should get you started using package rgl. Note: On re-read I see I am using your xyz coords a little different than you did, but the concept is the same.

input<-data.frame( # I adjusted the values for better appearance in demo
label=c("sp1","sp2","sp3","sp4"),
trait_x=c(6,7,11,1),
trait_y=c(10,7,9,1),
trait_z=c(4,7,6,1),
point_size=c(6,7,8,1)
)
names(input) <- c("name", "x", "y", "z", "radius")
input$radius <- input$radius*0.2

require("rgl")

spheres3d(input[,2:4], radius = input[,5], col = c("red", "green", "blue", "orange"), alpha = 0.5)
axes3d(box = TRUE)
title3d(xlab = "x_trait", ylab = "y_trait", zlab = "z_trait")
text3d(input[1,2:4], texts = "species X")
# next line is clunky but you can do it more elegantly
segs <- rbind(input[1:2,2:4], input[2:3,2:4], input[3:4,2:4], input[c(4,1),2:4])
segments3d(segs)

现在您可以交互地旋转图表,然后使用 rgl.snapshot 获取硬拷贝(在 spheres3d 中使用抗锯齿参数将改进图表).

Now you can rotate your diagram interactively and then use rgl.snapshot to get a hardcopy (using antialias arguments in spheres3d will improve the diagram).

这篇关于R 中有吸引力的 3D 绘图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆