我在使用 ggplot2 在 R 中创建地图方面相对较新,但我已经为这个问题苦苦挣扎了几天。我已经创建了我的情节,但似乎无法增加用于将颜色映射到我的值的箱数。
这是一个问题,因为地图不能很好地显示数据的变化。我不确定我是否正确地解决了这个问题。
这是我的代码:
region=c('alaska','alabama','arkansas','arizona','california','colorado','connecticut','florida','georgia','hawaii','iowa','idaho','illinois','indiana','kansas','kentucky','louisiana','massachusetts','maryland','maine','michigan','minnesota','missouri','mississippi','montana','north carolina','north dakota','nebraska','new hampshire','new jersey','new mexico','nevada','new york','ohio','oregon','pennsylvania','south carolina','south dakota','tennessee','texas','utah','virginia','vermont','washington','wisconsin','west virginia','oklahoma','wyoming')
sales=c(46,1240,471,2292,13427,1574,261,10036,826,1508,184,939,2356,1329,434,271,714,208,2027,21,950,500,1871,147,249,1204,69,175,369,1968,606,656,2369,2422,525,2902,1709,126,1563,12046,931,2271,46,2260,250,122,0,0)
state_data = as.data.frame(cbind(region,sales))
library(ggplot2)
library(maps)
all_states <- map_data("state")
D = merge(all_states, state_data, by = "region")
D = D[with(D,order(D$group,D$order)),]
p = ggplot()
p = p + geom_polygon( data=D, aes(x=long, y=lat, group = group, fill=D$sales),colour="white" )
p = p + xlab("")
p = p + ylab("")
p = p + labs(title = "sales")
p = p + guides(color=FALSE)
p = p + guides(size=FALSE)
p = p + guides(fill=guide_legend() )
p = p + guides(fill= guide_colorbar(title="sales",barheight = 1,barwidth=15,direction="horizontal",nbin=8) )
p = p + theme(legend.position="bottom")
p
理想情况下,我想将图例上的 bin 数量增加到大约 8-10,并可能在渐变中添加另一种颜色以显示更多细节。我已经尝试过 ggplot2 函数,但运气不佳。