考虑数据框 "dfc":
dfc <- structure(list(lag = c(-5L, -4L, -3L, -2L, -1L, 0L, 1L, 2L, 3L,
4L, 5L, -5L, -4L, -3L, -2L, -1L, 0L, 1L, 2L, 3L, 4L, 5L), variable = structure(c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L), .Label = c("var1", "var2"), class = "factor"),
value = c(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 0.6, 1.2, 1.8,
2.4, 3, 3.6, 4.2, 4.8, 5.4, 6, 6.6), size = c(2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1)), .Names = c("lag",
"variable", "value", "size"), row.names = c(NA, -22L), class = "data.frame")
看起来像这样:
head(dfc)
lag variable value size
1 -5 var1 1 2
2 -4 var1 2 2
3 -3 var1 3 2
4 -2 var1 4 2
5 -1 var1 5 2
6 0 var1 6 2
我希望能够根据“变量”使用不同的线条样式并根据“大小”使用不同的线条宽度绘制“滞后”与“值”的图形。我用这段代码实现了这个功能:
ggplot(dfc) +
geom_line(aes(x = lag, y = value, linetype = variable, size = size)) +
scale_size(range=c(1, 2), guide=FALSE) +
scale_linetype_manual(values = 1:2, labels = c("Name of var1 ", "Name of var2")) +
theme(legend.title = element_blank(), legend.position = "bottom",
legend.direction = "horizontal")
给出了这个图:
![enter image description here](https://istack.dev59.com/jSHks.webp)
var2
应该是 1,而不是 2。正如所说,我不需要改变键的宽度。 - user3710546guide_legend
中,使用list(size = c(2,1))
即可正常工作。 - user3710546legend.key.width
改变图例符号(在本例中为线条)的宽度,而list(size = 2)
则增加了图例中线条的粗细(或高度)。 - theforestecologistsize
更改为linewidth
。但是在guide_legend()
函数中没有关于此的警告。正确的调用应该是guide_legend(override.aes = list(linewidth = 2))
。 - drmariod