【发布时间】:2016-05-11 20:35:02
【问题描述】:
我想创建一个可视化二维值的等值线图(= 根据有序对 (v1, v2) 对多边形进行颜色填充,其中 v1 和 v2 是有序因子)。
我认为带有二维的颜色矩阵图例清楚地表明了我想要实现的目标。
我想使用ggplot2::geom_polygon 来实现它。
小例子:
ids <- factor(c("1.1", "2.1", "1.2", "2.2", "1.3", "2.3"))
values <- data.frame(
id = ids,
v1 = factor(c("Hi","Med","Med","Hi","Lo","Lo"),
levels=c("Lo", "Med", "Hi"), ordered=TRUE),
v2 = factor(c("Hi","Lo","Lo","Med","Med","Hi"),
levels=c("Lo", "Med", "Hi"), ordered=TRUE))
positions <- data.frame(
id = rep(ids, each = 4),
x = c(2, 1, 1.1, 2.2, 1, 0, 0.3, 1.1, 2.2, 1.1, 1.2, 2.5, 1.1, 0.3,
0.5, 1.2, 2.5, 1.2, 1.3, 2.7, 1.2, 0.5, 0.6, 1.3),
y = c(-0.5, 0, 1, 0.5, 0, 0.5, 1.5, 1, 0.5, 1, 2.1, 1.7, 1, 1.5,
2.2, 2.1, 1.7, 2.1, 3.2, 2.8, 2.1, 2.2, 3.3, 3.2))
datapoly <- merge(values, positions, by=c("id"))
我想按照上面的示例将以下两个地图合并为一个。 polgons 的颜色填充应该根据有序对 (v1, v2),当然我需要一个颜色矩阵图例。
library("ggplot2")
ggplot(datapoly, aes(x=x, y=y)) + geom_polygon(aes(fill=v1, group=id))
ggplot(datapoly, aes(x=x, y=y)) + geom_polygon(aes(fill=v2, group=id))
【问题讨论】:
-
前段时间我问了一个类似的问题——纯粹关注二维图例的想法:stackoverflow.com/q/20129299/903061