4

私は 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

理想的には、凡例のビンの数を約 8 ~ 10 に増やし、グラデーションに別の色を追加して詳細を表示したいと考えています。私は ggplot2 関数を試しましたが、うまくいきません。

4

1 に答える 1

5

あなたが抱えている問題は、あなたのsales列が数値ではなく因子であるという事実に関連しています。以下はそれを改善します:

D = merge(all_states, state_data, by = "region")
D = D[with(D,order(D$group,D$order)),] 
D$sales= as.numeric(D$sales) # this is the important bit...

p = ggplot(data=D) + 
     geom_polygon(aes(x=long, y=lat, 
                      group = group, fill=sales), 
                  colour = "white" ) + # Do not use D$, by use the column name
     xlab("") + ylab("") + labs(title = "sales") + theme(legend.position="bottom")
p

ここに画像の説明を入力してください

...または2色のスケールで:

p + scale_fill_gradient2(midpoint = 20)

ここに画像の説明を入力してください

いくつかのスタイルノート:

  • D$sales美学としてベクトル()を使用せず、列名( sales)のみを使用してください。
  • 私はコンスタントp = p + ...スタイルが嫌い+です。行の終わりで使用して次の行に移動します。
于 2012-10-15T18:33:51.910 に答える