米国の 50 州すべてを示すテーマ マップを作成しようとしていますが、信頼できる方法でアラスカとハワイを再配置するのに問題があります。いくつかのアイデアがありますが、どれもうまくいきません。私は今それらを実演します。
まず、データをインポートする必要があります。maps
ハワイとアラスカが含まれていないため、パッケージ内のデータを使用するだけでは不十分です。
setwd(tempdir())
download.file("https://dl.dropbox.com/s/wl0z5rpygtowqbf/states_21basic.zip?dl=1",
"usmapdata.zip",
method = "curl")
# This is a mirror of http://www.arcgis.com/home/item.html?
# id=f7f805eb65eb4ab787a0a3e1116ca7e5
unzip("usmapdata.zip")
require(rgdal)
all_states <- readOGR("states_21basic/", "states")
require(ggplot2); require(maptools); require(rgeos); require(mapproj);
all_states <- fortify(all_states, region = "STATE_NAME")
ここで、いくつかのプロットの美学を定義します。
p <- ggplot() + geom_polygon(
aes(x=long, y=lat, group = group, fill = as.numeric(as.factor(id))),
colour="white", size = 0.25
) + coord_map(projection="azequalarea") +
scale_fill_gradient(limits = c(1,50))
次に、すべての背景などを削除して、隣接していない状態を重ねたときに衝突しないようにします。
p <- p + theme(axis.line=element_blank(),
axis.text.x=element_blank(),
axis.text.y=element_blank(),
axis.ticks=element_blank(),
axis.title.x=element_blank(),
axis.title.y=element_blank(),
panel.background=element_blank(),
panel.border=element_blank(),
panel.grid.major=element_blank(),
panel.grid.minor=element_blank(),
plot.background=element_blank())
ビューポートの使用
私が最初に思いついたのは、ビューポートを使用することでした:
AK <- p %+% subset(all_states, id == "Alaska") + theme(legend.position = "none")
HI <- p %+% subset(all_states, id == "Hawaii") + theme(legend.position = "none")
contiguous <- p %+% subset(all_states, id != "Alaska" & id != "Hawaii")
grid.newpage()
vp <- viewport(width = 1, height = 1)
print(contiguous, vp = vp)
subvp1 <- viewport(width = 0.25, height = 0.25, x = 0.18, y = 0.33)
print(AK, vp = subvp1)
subvp2 <- viewport(width = 0.12, height = 0.12, x = 0.32, y = 0.27)
print(HI, vp = subvp2)
これは見栄えは良いですが、サイズ変更や凡例のサイズと形状の変更など、Figure のわずかな変更に非常に敏感であるため、満足のいくものではありません。
アラスカとハワイを手動で移動する
all_states_AKHImoved <- within(all_states, {
lat[id == "Alaska"] <- lat[id == "Alaska"] - 45
long[id == "Alaska"] <- long[id == "Alaska"] + 40
lat[id == "Hawaii"] <- lat[id == "Hawaii"] + 0
long[id == "Hawaii"] <- long[id == "Hawaii"] + 70
})
p %+% all_states_AKHImoved
これは満足できるものではありません。通常、アラスカはほとんどの米国のマップで縮尺調整されていないため、非常に大きく見えるからです。また、アラスカとハワイを再配置すると、地図投影によって導入された歪みが変化します。
質問
誰もがより良いアプローチを持っていますか?