更改箭头的箭头()

时间:2011-04-20 13:50:44

标签: r plot

我想知道是否可以更改用arrows()绘制的箭头的箭头。我查看了文档,但我发现的是我可以更改一行而不是一行箭头?

plot(c(1:10))
arrows(0,0,10,10)

感谢任何帮助:)

3 个答案:

答案 0 :(得分:18)

?arrow中所述,您可以使用lengthangle来更改标准箭头的外观。使用lwd,您可以更改厚度,就像在行()中一样。同样lty也可以,但结果往往不太好。

一整套例子:

plot(c(0:10),type="n")

arrows(1,0,2,1,length=0.2,angle=20)
arrows(1,1,2,2,length=0.1,angle=40,lwd=3)

invisible(mapply(arrows,
        rep(c(3,6),each=4),rep(3:6,2),
        rep(c(5,8),each=4),rep(5:8,2),
        angle=seq(10,40,length.out=8),
        length=rep(seq(0.1,0.3,length.out=4),2),
        lwd=rep(1:4,each=2))
)

答案 1 :(得分:15)

Karline Soetaert的软件包shape可用于此目的:

library(shape)
plot(c(0,2),c(-2,2), col=NA)
Arrows(c(0,1.7),c(1.3,-1.8),c(0.8,1.1),c(1.2,-1), lwd=2)

默认是一个充满弯曲的箭头,看起来很舒服:

enter image description here

得爱CRAN!

答案 2 :(得分:6)

如果其他答案使用箭头功能无法对箭头进行足够的控制,则可以使用my.symbols包中的TeachingDemos功能。这允许您创建自己的自定义箭头并绘制它们。

同一个包中的函数ms.arrows显示了一种执行此操作的方法:您可以修改该函数(或其他ms.*函数)以创建您想要的任何类型的箭头,并在以后使用my.symbols绘制它们。

修改

以下是请求的示例:

library(TeachingDemos)

ms.arrowhead <- function(angle, ...) {
  xy <- cbind( c(-1, -0.75, -1, 0), 
               c(-0.5, 0, 0.5, 0) )
  xy <- xy %*% matrix(c(cos(angle),-sin(angle),sin(angle),cos(angle)), 2)
  xspline(xy, shape=c(0, -1, 0, 0), open=FALSE, ...)
}

plot(1:10, 1:10)
my.symbols(1:10, 1:10, ms.arrows, angle=seq(pi, 0, length=10),
           col='blue', adj=1, length=0, symb.plots=TRUE)
my.symbols(1:10, 1:10, ms.arrowhead, angle= seq(pi, 0, length=10), 
           col='green', inches=0.5, lwd=2, symb.plots = TRUE)

这使用xspline函数绘制一个带有弯曲后部的三角形作为箭头。可以修改这些点以获得不同形状的箭头,或者可以使用另一种方法来形成。