plot(NA, xlim=c(0,5), ylim=c(0,5), xlab="X", ylab="Y")
vecs <- data.frame(vname=c("a","b","a+b", "transb"),
x0=c(0,0,0,2),y0=c(0,0,0,1), x1=c(2,1,3,3) ,y1=c(1,2,3,3),
col=1:4)
with( vecs, mapply("arrows", x0, y0, x1,y1,col=col) )
如果将 lwd=3 添加到 arrows 调用中,它看起来会更好一些。 text 函数将允许标记并且可以使用 'srt' 参数进行旋转。
plot(NA, xlim=c(0,5), ylim=c(0,5), xlab="X", ylab="Y", lwd=3)
with( vecs, mapply("arrows", x0, y0, x1,y1,col=col,lwd=3) )
with(vecs, mapply('text', x=x1[1:3]-.1, y=y1[1:3]+.1,
labels=expression(list(a[1],a[2]), list(b[1],b[2]), list(a[1]+b[1],a[2]+b[2]) ) ))
请注意,expression 调用中的 list 函数是一个 plotmath list-调用,不同于常规的 R list,就像 plotmath-paste 不同于常规的 paste。它不会尝试在父框架中评估其参数。为此需要bquote 或substitute,并且可能需要使用sapply 来处理“内部”表达式。