在R中更改ggplot geom_polygon的配色方案

10

我正在使用地图库和ggplot的geom_polygon创建地图。我想简单地将默认的蓝色、红色、紫色配色方案更改为其他颜色。我对ggplot非常陌生,如果我使用的数据类型不正确,请谅解。以下是我使用的数据的样子:

> head(m)
region      long      lat group order subregion Group.1 debt.to.income.ratio.mean    ratio total
17 alabama -87.46201 30.38968     1     1      <NA> alabama                   12.4059   20.51282    39
18 alabama -87.48493 30.37249     1     2      <NA> alabama                   12.4059 20.51282    39
19 alabama -87.52503 30.37249     1     3      <NA> alabama                   12.4059 20.51282    39
20 alabama -87.53076 30.33239     1     4      <NA> alabama                   12.4059 20.51282    39
21 alabama -87.57087 30.32665     1     5      <NA> alabama                   12.4059 20.51282    39
22 alabama -87.58806 30.32665     1     6      <NA> alabama                   12.4059 20.51282    39

> head(v)
          Group.1 debt.to.income.ratio.mean    ratio     region total
alabama       alabama                  12.40590 20.51282    alabama    39
alaska         alaska                  11.05333 33.33333     alaska     6
arizona       arizona                  11.62867 25.55556    arizona    90
arkansas     arkansas                  11.90300  5.00000   arkansas    20
california california                  11.00183 32.59587 california   678
colorado     colorado                  11.55424 30.43478   colorado    92

以下是代码:

library(ggplot2)
library(maps)

states <- map_data("state")
m <- merge(states, v, by="region")
m <- m[order(m$order),]

p<-qplot(long, lat, data=m, group=group, fill=ratio, geom="polygon")

我已经尝试了以下方法和更多:

cols <- c("8" = "red","4" = "blue","6" = "darkgreen", "10" = "orange") 
p + scale_colour_manual(values = cols)
p + scale_colour_brewer(palette="Set1")
p + scale_color_manual(values=c("#CC6666", "#9999CC"))
1个回答

20
问题在于您正在使用颜色比例尺,但在图表中使用了填充美学。您可以使用 scale_fill_gradient() 来设置两种颜色,使用 scale_fill_gradient2() 来设置三种颜色:
p + scale_fill_gradient(low = "pink", high = "green") #UGLY COLORS!!!

在使用scale_fill_brewer()时,我遇到了问题,提示需要离散变量但提供的却是连续变量。一种简单的解决方法是使用cut()创建离散区间,然后将其用作填充美学属性:

m$breaks <- cut(m$ratio, 5) #Change to number of bins you want

p <- qplot(long, lat, data = m, group = group, fill = breaks, geom = "polygon")
p + scale_fill_brewer(palette = "Blues")

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接