面对自由尺度,但保持纵横比固定

sea*_*ody 19 gis r ggplot2

我正在使用ggplot绘制分面地图,并且无法弄清楚如何在每个方面允许"自由"比例(以便小区域看起来不会太小)同时保持xy宽高比固定.

这是一个简化的例子:

require(maps)
require(ggplot2)

map_nz <- subset(fortify(map_data('nz')),
                 region %in% c("South.Island ", "North.Island "))
gg_nz <- qplot(long, lat, data=map_nz, geom="polygon", group=group)
Run Code Online (Sandbox Code Playgroud)

我现在有一个新西兰北岛和南岛的情节.我可以面对这个并以固定的宽高比显示它,如下所示:

gg_nz + coord_fixed() + facet_wrap(~region)
Run Code Online (Sandbox Code Playgroud)

结果看起来像这样:

新西兰地图 - 固定纵横比

请注意,北岛小平面浪费了相当多的空间.我希望它占用更多的可用空间.我可以像这样释放比例尺:

gg_nz + facet_wrap(~region, scales="free")
Run Code Online (Sandbox Code Playgroud)

结果如下:

新西兰地图 - 免费比例

问题是每个方面的xy纵横比不再是1:1.我很高兴每个方面都有不同的规模,但在方面我想保留纵横比.

我尝试了以下但没有成功:

gg_nz + facet_wrap(~region, scales="free") + coord_fixed()
Run Code Online (Sandbox Code Playgroud)

大概是覆盖中的scale参数.有什么建议?facet_wrapcoord_fixed

更新:为了给出一个更具戏剧性的插图,这与美国一些州的情况相同:

固定坐标(使用coord_fixedcoord_equal):

美国地图 - 固定方面 免费坐标(使用scales = free):

美国地图 - 免费比例

这些地图都不是理想的:首先,特拉华州很小.在第二种情况下,纵横比非常扭曲.例如,新泽西州是一个狭窄的国家,拉伸得太宽.

Ric*_*rta 7

更新:

我相信你所寻找的是能够裁剪或放大单个方面的能力.换句话说,为每个方面独立调整ylims和xlims.看起来这样的功能已被请求但尚未实现(https://github.com/hadley/ggplot2/issues/187)

如果space=free下面的选项不起作用,另一种方法是废弃构面并使用网格布局和/或视口手动打印每个图.


使用facet_grid而不是facet_wrap添加space=free:

gg_state + facet_grid(~region, scales = "free_x", space="free")
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述


原答案:

也许不是让两个轴自由缩放,只有一个刻度:

map_state <- subset(fortify(map_data('state')),
                 region %in% c("california", "nevada"))
gg_state <- qplot(long, lat, data=map_state, geom="polygon", group=group)
gg_state + facet_wrap(~region, scales="free_x")
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

  • 疑难杂症!基本上你想要**裁剪**一个方面,不要缩放它,也不要拉伸它.刚刚收获. (3认同)

R N*_*oob 5

theme(aspect.ratio = 1) 作品。

gg_nz + facet_wrap(~region, scales="free") + theme(aspect.ratio = 1)


Sim*_*lon 0

coord_equal帮助吗?

 gg_nz + facet_wrap(~region, scales="free") + coord_equal()
Run Code Online (Sandbox Code Playgroud)

编辑

您可以grid.arrange手动将绘图放在页面上,固定宽度和高度。这似乎可以解决问题,但我无法让它与facet()功能一起工作。感谢@mnel 的这篇文章

nz_sth <- qplot(long, lat, data=map_nz[map_nz$region == "South.Island ",], geom="polygon", group=group) + coord_fixed()
nz_nth <- qplot(long, lat, data= map_nz[ map_nz$region == "North.Island " , ] , geom="polygon", group=group) + coord_fixed()


grid.arrange( heights=unit(0.75, "npc") , widths=unit(0.5, "npc") , nz_sth,nz_nth, ncol=2)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述