微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

R:将文本添加到绘图区域外的右下角的图中

我正在绘制baseR中的多个图形,我试图在我的图形的下部右下角绘制一个文本.我尝试使用mtext(),但这并没有给我想要的结果.你会怎么做?最终的想法是生成如下图所示的内容.我怎么能这样做?

这是我用来生成图的代码.

xy <- data.frame(NAME=c("NAME1","NAME1","NAME2","NAME2"),ID=c(47,47,259,259),YEAR=c(1932,1942,1965,1989,2007,2008,2014),VALUE=c(0,NA,-6,-16,-9,-28),test=c("text1","text1","text2","text2"))

# split data by index 
ind <- split(x = xy,f = xy[,'ID'])

plot1 <- function(x) {
  fname <- paste0(x[1,'ID'],'.png')
  png(fname,width=1679,height=1165,res=150)
  par(mar=c(6,8,6,5))
  plot(x = c(1946,y = range(x$VALUE,na.rm=TRUE),type='n',main=x[1,'NAME'],xlab="Time [Years]",ylab="Value [m]")
  axis(2,at = seq(-100000,100000,100),cex.axis=1,labels=FALSE,tcl=-0.3)
  points(x[,c('YEAR','VALUE')],type="l",lwd=2)
  points(x[,type="p",lwd=1,cex=0.5,pch=21,bg='white')
  abline(h=0)
  mtext(x$test,side=1,)

  dev.off()
}

plot2 <- function(x) {
  fname <- paste0(x[1,res=150)    
  par(mar=c(6,5))
  plot(x[,ylab="value [m]")
  axis(2,side=1)
  dev.off() 
}

lapply(ind,function(x) ifelse(any(x$YEAR < 1946 & x$YEAR < 2014),plot2(x),plot1(x)))

解决方法

plot(1)
title(sub="hallo",adj=1,line=3,font=2)

原文地址:https://www.jb51.cc/html/223811.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐