我想知道是否可以更改用arrows()
绘制的箭头的箭头。我查看了文档,但我发现的是我可以更改一行而不是一行箭头?
plot(c(1:10))
arrows(0,0,10,10)
感谢任何帮助:)
答案 0 :(得分:18)
如?arrow
中所述,您可以使用length
和angle
来更改标准箭头的外观。使用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)
默认是一个充满弯曲的箭头,看起来很舒服:
得爱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
函数绘制一个带有弯曲后部的三角形作为箭头。可以修改这些点以获得不同形状的箭头,或者可以使用另一种方法来形成。