MYa*_*208 26 r heatmap ggplot2
我想在ggplot2中制作热图.我的玩具数据和代码是:
set.seed(12345)
dat <-
data.frame(
Row = rep(x = LETTERS[1:5], times = 10)
, Col = rep(x = LETTERS[1:10], each = 5)
, Y = rnorm(n = 50, mean = 0, sd = 1)
)
library(ggplot2)
p <- ggplot(data = dat, aes(x = Row, y = Col)) +
geom_tile(aes(fill = Y), colour = "white") +
scale_fill_gradient(low = "white", high = "steelblue")
p
Run Code Online (Sandbox Code Playgroud)
我希望为这样的范围值设置颜色方案:
-3 <= Y < -2 ---> Dark Blue
-2 <= Y < -1 ---> Blue
-1 <= Y < 0 ---> Light Blue
0 <= Y < 1 ---> Light Green
1 <= Y < 2 ---> Green
2 <= Y <= 3 ---> Dark Green
Run Code Online (Sandbox Code Playgroud)
任何帮助将受到高度赞赏.谢谢
Bri*_*ggs 43
目前尚不清楚您是否需要离散颜色,或者您列出的颜色是否只是标记范围内的标记Y.我会同时展示.
对于离散颜色,请使用Y1joran定义它
dat$Y1 <- cut(dat$Y,breaks = c(-Inf,-3:3,Inf),right = FALSE)
Run Code Online (Sandbox Code Playgroud)
然后,您可以使用手动刻度获得具有您列出的特定颜色的绘图
p <- ggplot(data = dat, aes(x = Row, y = Col)) +
geom_tile(aes(fill = Y1)) +
scale_fill_manual(breaks=c("\[-Inf,-3)", "\[-3,-2)", "\[-2,-1)",
"\[-1,0)", "\[0,1)", "\[1,2)",
"\[2,3)", "\[3, Inf)"),
values = c("white", "darkblue", "blue",
"lightblue", "lightgreen", "green",
"darkgreen", "white"))
p
Run Code Online (Sandbox Code Playgroud)

我不知道你想要的超过-3和3的颜色,所以我用白色.
如果你想要一个连续的颜色,从负片上的蓝色到0上的白色到正片上的绿色,scale_fill_gradient2都可以.
ggplot(data = dat, aes(x = Row, y = Col)) +
geom_tile(aes(fill = Y)) +
scale_fill_gradient2(low="darkblue", high="darkgreen", guide="colorbar")
Run Code Online (Sandbox Code Playgroud)

如果你想要对颜色进行精细的细节控制,那么映射是3的"深蓝",2处的"蓝色",1处的"浅蓝",0处的"白色"等等,那么scale_fill_gradientn将适用于你:
library("scales")
ggplot(data = dat, aes(x = Row, y = Col)) +
geom_tile(aes(fill = Y)) +
scale_fill_gradientn(colours=c("darkblue", "blue", "lightblue",
"white",
"lightgreen", "green", "darkgreen"),
values=rescale(c(-3, -2, -1,
0,
1, 2, 3)),
guide="colorbar")
Run Code Online (Sandbox Code Playgroud)

jor*_*ran 21
对于像这样的东西你有几种选择,但这里有一个作为起点.
首先,使用cut从Y适当的范围创建一个因子:
dat$Y1 <- cut(dat$Y,breaks = c(-Inf,-3:3,Inf),right = FALSE)
Run Code Online (Sandbox Code Playgroud)
然后使用RColorBrewer中的调色板绘制:
ggplot(data = dat, aes(x = Row, y = Col)) +
geom_tile(aes(fill = Y1), colour = "white") +
scale_fill_brewer(palette = "PRGn")
Run Code Online (Sandbox Code Playgroud)

这个配色方案在低端比紫色更蓝,但它是我在Brewer调色板中找到的最接近的颜色.
如果你想构建自己的,你可以简单地使用scale_fill_manual并为values参数指定所需的颜色向量.