0

我正在使用 R 中的 usmaps() 包来创建美国地图。我的数据设置如下:

Ces_State_Only:

状态 1990
阿拉巴马州 0.2
阿拉斯加州 0.31
亚利桑那 0.40

我想创建一个叶绿素图。我想将我的数据分为以下几类:0-0.2、0.2-0.25、0.25-0.3、0.3-0.33、0.33-36、>36。

我的代码是:

plot_usmap(data = Ces_State_only, values = "1990") +   scale_colour_gradientn(colours = "Blues", breaks = c(0,.2, .25, 0.3, 0.33, 0.36, 1),limits = c(0, 100))

此代码有效,但它不会对我的数据进行分类。

我还尝试在映射数据之前对数据进行分箱:

Ces_State_only$Ninety_bin <- cut(Ces_State_only$`1990`,breaks = c(0,0.2, 0.25, 0.3, 0.33, 0.36,1))
    
plot_usmap(data = Ces_State_only, values = "Ninety_bin") +   scale_fill_brewer(palette="Blues",
        aesthetics = "fill",
        na.value = "grey50")+   theme(legend.position = "right")

但是,这只会在美国地图上创建三种不同的颜色(对于以下箱:0-0.2、0.2-0.25 和 0.25-0.3)。

有什么建议或想法吗?

先感谢您!

4

1 回答 1

1

问题是默认情况下使用的因子水平会被丢弃。您可以通过设置来防止这种drop=FALSE情况scale_fill_brewer

library(usmap)
library(ggplot2)

plot_usmap(data = Ces_State_only, values = "Ninety_bin") +
  scale_fill_brewer(
    palette = "Blues",
    aesthetics = "fill",
    na.value = "grey50",
    drop = FALSE
  ) +
  theme(legend.position = "right")

于 2021-10-14T06:44:04.123 回答