我正在绘制baseR中的多个图形,我正在尝试在我的图形的下方右下角绘制文本。我尝试使用mtext()
,但这并没有给我想要的结果。你会怎么做?最终的想法是生成如下图所示的内容。我怎么能这样做?
这是我用来生成图表的代码。
xy <- data.frame(NAME=c("NAME1", "NAME1","NAME1","NAME1","NAME2","NAME2","NAME2"),ID=c(47,47,47,47,259,259,259),YEAR=c(1932,1942,1965,1989,2007,2008,2014),VALUE=c(0,NA,-6,-16,0,-9,-28), test=c("text1","text1","text1","text1","text2","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, 2014),
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[,c('YEAR','VALUE')], 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, 'ID'], '.png')
png(fname, width=1679, height=1165, res=150)
par(mar=c(6,8,6,5))
plot(x[,c('YEAR','VALUE')],
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[,c('YEAR','VALUE')], type="p", lwd=1, cex=0.5, pch=21, bg='white')
abline(h=0)
mtext(x$test, side=1)
dev.off()
}
lapply(ind, function(x) ifelse(any(x$YEAR < 1946 & x$YEAR < 2014), plot2(x), plot1(x)))
答案 0 :(得分:9)
使用mtext()
,您可以将文字放在地块边距。在您的情况下,您可以尝试使用参数line
和at
。见help(mtext)
plot(1:10,10:1)
mtext('text is here', side=1, line=3.5, at=9)
答案 1 :(得分:4)
plot(1:10,10:1)
text(c(0,6,9), -0.6, paste('hello world', c(1:3)), xpd=NA)
使用text()
功能,您可以参考定位到绘图的坐标,并且可以在其中绘制多个文本元素。
通过xpd
参数,您可以在要绘制元素的三种可能性之间进行选择(也可用于点和线等其他元素):
FALSE
:仅在情节内TRUE
:在外部绘图区域NA
:绘图设备上的所有位置答案 2 :(得分:1)
plot(1)
title(sub="hallo", adj=1, line=3, font=2)