一个震撼的交互型3D可视化R包 – rayshader
虽然3D
的plot见得比较多了,但是看见这样的R包
,我的心还是砰了一下,这个简直不能再好看了!
关键是!!!敲黑板,这个R
包超简单!!!对于刚学习R语言的同学们来说,会被圈粉哒!
该包的主要功能就是将ggplot2画出来的2D
图像变为3D
图像,不说废话,直接上代码。
# 安装rayshader包
install.packages("remote")
remotes::install_github("tylermorganwall/rayshader")
library(rayshader)
library(ggplot2)# 查看数据格式
head(diamonds)# 绘制二维密度图
gg = ggplot(diamonds, aes(x, depth)) +stat_density_2d(aes(fill = stat(nlevel)), #绘制密度等高线图geom = "polygon",n = 100,bins = 10, contour = TRUE) +facet_wrap(clarity~.) + # 按clarity分类scale_fill_viridis_c(option = "A") # 将map颜色设置为“岩浆”色,简称为“A”,共有“A”,“B”,“C”,“D”和“E”五种;gg # 绘制2D图# 转成3D图,只需要plot_gg函数即可
plot_gg(gg,multicore=TRUE,width=5,height=5,scale=250)
打开后,可以像任何其他光线图一样操作绘图 – 可以调用render_camera()
以编程方式更改摄像机位置,render_snapshot()
可以保存或输出当前视图,甚至可以使用render_depth()
来渲染光滑深度场效应。还可以更改甚至删除光源,并将任何参数传递给plot_gg()
,绘制为plot_3d()
。
# 如果缺失sf包,建议先安装
library(sf)nc = st_read(system.file("shape/nc.shp", package="sf"), quiet = TRUE) #加载包自带的数据
gg_nc = ggplot(nc) + # 加载North Carolina地图geom_sf(aes(fill = AREA)) + # 绘制地理数据模型,sf对象,全称Simple featurescale_fill_viridis("Area") + # 按区域上色ggtitle("Area of counties in North Carolina") + # 绘制题目theme_bw()plot_gg(gg_nc, multicore = TRUE, width = 6 ,height=2.7, fov = 70) #加载图形
render_depth(focallength=100,focus=0.72)
# 随机取三组数字,并且对其进行合并,两列,一列X,一列Y
a = data.frame(x=rnorm(20000, 10, 1.9), y=rnorm(20000, 10, 1.2) )
b = data.frame(x=rnorm(20000, 14.5, 1.9), y=rnorm(20000, 14.5, 1.9) )
c = data.frame(x=rnorm(20000, 9.5, 1.9), y=rnorm(20000, 15.5, 1.9) )
data = rbind(a,b,c)
class(data) #其实如果我们有相同类型的数据,也可以仿照该组织方式进行合并;# Lines
pp = ggplot(data, aes(x=x, y=y)) +geom_hex(bins = 20, size = 0.5, color = "black") + # 绘制六边形图scale_fill_viridis_c(option = "C")
plot_gg(pp, width = 4, height = 4, scale = 300, multicore = TRUE)# No lines
pp_nolines = ggplot(data, aes(x=x, y=y)) +geom_hex(bins = 20, size = 0) +scale_fill_viridis_c(option = "C")
plot_gg(pp_nolines, width = 4, height = 4, scale = 300, multicore = TRUE)
# 该数据摘自1974年“美国汽车趋势”杂志,包括32种汽车(1973-74型号)的燃油消耗和10个汽车设计和性能方面。#该数据是我们常见的R中的模拟数据
head(mtcars)mtcars_gg = ggplot(mtcars) +geom_point(aes(x=mpg,color=cyl,y=disp),size=2) +scale_color_continuous(limits=c(0,8)) +ggtitle("mtcars: Displacement vs mpg vs # of cylinders") +theme(title = element_text(size=8),text = element_text(size=12))plot_gg(mtcars_gg, height=3, width=3.5, multicore=TRUE, pointcontract = 0.7, soliddepth=-200)
准备开始了吗?
点击链接 https://github.com/tylermorganwall/rayshader
!该网站包含所有rayhader
功能的文档和示例,可以在Github
页面上找到实际的存储库。就让你静静的看我有多美!
想把其它图也用3D
展示,可以拿下面的ggplot2
系列绘图做例子。
-
ggplot2高效实用指南 (可视化脚本、工具、套路、配色)
-
ggplot2学习笔记之图形排列
-
12个ggplot2扩展包帮你实现更强大的可视化
作者:张虎 协和
你可能还想看
-
文章用图的修改和排版 (1)
-
文章用图的修改和排版 (2)
-
简单强大的在线绘图
-
简单强大的在线绘图-升级版
-
简单强大的在线绘图-第3版
-
论文图表基本规范
-
学术图表的基本配色方法
-
数据可视化基本套路总结
往期精品(点击图片直达文字对应教程)
机器学习
后台回复“生信宝典福利第一波”或点击阅读原文获取教程合集