基于 ggplot2 的密封示例,我尝试更改箭头的粗细,以便它们的整体大小更好地反映数据变量。我可以指定长度和厚度,但不知道如何更改箭头的大小。非常感谢任何建议。
require(ggplot2)
require(grid)
d = seals[sample(1:nrow(seals), 100),]
d$size = sqrt(sqrt(d$delta_long^2 + d$delta_lat^2))
ggplot(d, aes(x = long, y = lat, size = size)) +
geom_segment(aes(xend = long + delta_long, yend = lat + delta_lat), arrow = arrow(length = unit(0.1,"cm")))
Run Code Online (Sandbox Code Playgroud)

编辑
解决方案代码:
ggplot(d, aes(x = long, y = lat, size = size)) +
geom_segment(aes(xend = long + delta_long, yend = lat + delta_lat),
arrow = arrow(length = unit(d$size/3, "cm"), type='closed')) +
scale_size(range = c(0, 2))
Run Code Online (Sandbox Code Playgroud)
我不能说这是您问题的完整解决方案,但至少它可以是一个开始。
ggplot(d, aes(x = long, y = lat, size = size)) +
geom_segment(aes(xend = long + delta_long, yend = lat + delta_lat),
arrow = arrow(length = unit(0.7, "cm"))) +
scale_size(range = c(1, 2))
Run Code Online (Sandbox Code Playgroud)
我的变化很小:更大的箭头和大小比例。如果您的目标是避免过度绘图,则大小比例的上限是最重要的。

从现在开始,最好只留下箭头,因为当尺寸较小时,线条是不可见的。这是一个肮脏的黑客:
ggplot(d, aes(x = long, y = lat, size = size)) +
geom_segment(aes(xend = long + delta_long/100, yend = lat + delta_lat/100),
arrow = arrow(length = unit(0.7,"cm"))) +
scale_size(range = c(1, 2))
Run Code Online (Sandbox Code Playgroud)

当然,重要的是要在大小值之间保持适当的视觉关系!否则,您的情节可能会产生误导。但这取决于数据,所以我不能给你进一步的建议。对不起,如果这是一个明显的点。
UPD:事实证明,unit() 函数是矢量化的,所以它来救援了!
ggplot(d, aes(x = long, y = lat, size = size)) +
geom_segment(aes(xend = long + delta_long/100, yend = lat + delta_lat/100),
arrow = arrow(length = unit(d$size * 5,"cm"))) +
scale_size(range = c(1, 2))
Run Code Online (Sandbox Code Playgroud)
