前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >R语言的ggplot2+ggforce包绘制散点图并添加分组边界

R语言的ggplot2+ggforce包绘制散点图并添加分组边界

作者头像
用户7010445
发布2021-03-15 09:58:46
1.8K0
发布2021-03-15 09:58:46
举报
文章被收录于专栏:小明的数据分析笔记本

之前的推文介绍过ggplot2绘图添加椭圆分组边界和圆形分组边界,借助的函数分别是

  • stat_ellipse()
  • ggforce包里的geom_circle()函数

今天查找桑基图的资料的时候发现了一份介绍ggforce这个包的使用方法的文章 https://rviews.rstudio.com/2019/09/19/intro-to-ggforce/ ,发现发现添加分组边界还有其他的实现方法,今天的推文记录一下。

示例数据就直接使用R语言内置的鸢尾花数据集

首先是矩形的分组边界

使用的是 geom_mark_rect() 函数

代码语言:javascript
复制
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_rect(aes(fill=V5),alpha=0.1)+
  theme_bw()

image.png

添加圆形的分组边界

使用到的是geom_mark_circle()函数

代码语言:javascript
复制
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_circle(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(50,50,50,150),
        legend.background = element_blank())

image.png

这里又遇到了一个新的知识点 coord_cartesian(clip = "off") ,如果加上这一行命令,就能够让三个圆圈在最上层,不加的效果如下图,显示不全 参考链接是 https://guangchuangyu.github.io/2018/05/ggplot2-clip/

image.png

添加椭圆分组边界

用到的是geom_mark_ellipse()函数

代码语言:javascript
复制
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_ellipse(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())

image.png

最后是无规则形状的分组边界

用到的是geom_mark_hull()函数

代码语言:javascript
复制
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
#install.packages("concaveman")
library(concaveman)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_hull(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())

这里会遇到一个警告信息Warning message: The concaveman package is required for geom_mark_hull需要安装并加载concaveman这个包 ··· install.packages("concaveman") library(concaveman) ···

image.png

还可以给每个组添加文字标签,加一个label参数就好了
代码语言:javascript
复制
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
#install.packages("concaveman")
library(concaveman)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_ellipse(aes(fill=V5,label=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())

image.png

欢迎大家关注我的公众号

小明的数据分析笔记本

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-02-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 小明的数据分析笔记本 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 示例数据就直接使用R语言内置的鸢尾花数据集
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档