R语言ggplot在一张图里同时画散点图和折线图

R语言ggplot在一张图里同时画散点图和折线图

前言

ggplot画出的一张图中通常只有一种类型,比如纯粹的散点图或折线图。如果将两种不同类型图画一张图,则没有办法添加图例。比如同时画散点图geom_point()和折线图geom_line(),而这种类型的图经常用于展示模型校准结果。
个人理解ggplot可以使用两种类型的数据,一种是面板数据(二维数据列表),就是一列x值,若干列变量值,可以将变量用视觉映射表示,比如大小/形状/颜色。
一种是融合后的数据(一维数据列表),一列x值,一列变量名称,一列y值。也可以将变量用视觉映射表示,比如大小/形状/颜色。
接下来将从这两种数据表分别画图

面板数据
在这里插入图片描述

一维数据列表
一维数据列表

前处理

library("readxl")#读取excel数据
library(reshape2)#转化两种数据列表
library(ggplot2)
getwd()#获取当前文件路径
setwd("C:/3 PROJECT/2021 缅甸")#设置路径
workbook="C:/3 PROJECT/2021 缅甸/出图.xlsx"#读取文件
data_level=read_xlsx(workbook,sheet="潮位")#读取数据
data_level1=data_level[c("TIME","C3","C3模拟")]#二维数据
levelC3=melt(data_level1,id="TIME")#一维数据 使用melt转化数据

二维数据列表

这个方法是知乎weiya提供的。具体我也没搞明白,但是能用。即使用geom分别画点和线,然后手动自定义离散的度量
链接: link

p1=ggplot(data_level1)+
  geom_point(aes(x=TIME,y=C3, color = "#D1484F", shape = "A", linetype = "A"), size=2 )+
  geom_line(aes(TIME,C3模拟, color = "#3398CC", shape = "B", linetype = "B"),size=1)+
  scale_y_continuous('C3潮位(m)')+
  labs(x = "时间",y='C3潮位(m)')+
  theme_bw()+
  theme(legend.title=element_blank(),legend.position = c(0.9, 0.1))+
  scale_color_manual(name = "group",
                     values = c('#D1484F' = '#D1484F', "#3398CC" = '#3398CC'), 
                     breaks = c("#D1484F", "#3398CC"),
                     labels = c('实测值', '模拟值')) + 
  scale_shape_manual(name = "group",
                     values = c("A" = 16, "B" = NA), 
                     labels = c('实测值', '模拟值')) + 
  scale_linetype_manual(name = "group",
                        values = c("A" = 0, "B" = 1), 
                        labels = c('实测值', '模拟值'))
p1

p1

一维数据列表绘图

将variable分别映射到填充颜色fill,颜色color,大小size,同时画点和线,通过调整度量达到同时绘图的目的。

p11=ggplot(levelC3,aes(x=TIME,y=value,fill=variable,color=variable,size=variable))+
  geom_point(aes(shape=variable),color="#D1484F") +
  scale_size_manual(values=c(3,1))+
  scale_shape_manual(values=c(15,NA))+
  geom_line(aes(linetype=variable), size=1,color = "#3398CC") +
  scale_linetype_manual(values = c(0,1))+ 
  scale_y_continuous('C3潮位(m)')+
  labs(x = "时间")+
  theme_bw()+
  theme(legend.title=element_blank(),legend.position = c(0.9, 0.1))+
  scale_x_datetime(date_labels = "%H:%M")
p11

p11
到此结束!

  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值