我正在玩一个空间数据集(主要是城市某个区域的多边形),我希望根据不同的缩放级别生成不同的视图。 当我的绘图边界框大于包含多边形的区域时,一切都很好。但是在放大时,一些多边形会获得位于边界框外部的部分,并且这些多边形的输出会出现问题:边界框外部的多边形点不会显示,从而导致多边形未在边界框限制处被裁剪(正如预期的那样)但不考虑。多边形不完整,多边形只加入绘图上剩余的点(正常行为,但不需要)。
值得所有讨论的一个好例子,这是一个问题的演示:
#initialisation
library(ggmap)
require(MASS)
data(zips)
# overview
ggmap(get_map(maptype = "satellite", zoom = 8), extent = "device") +
geom_polygon(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = NA, fill = "red", alpha = .5) +
geom_path(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = "white", alpha = .7, size = .4)
# problematic view
x11()
ggmap(get_map(maptype = "satellite", zoom = 12), extent = "device") +
geom_polygon(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = NA, fill = "red", alpha = .5) +
geom_path(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = "white", alpha = .7, size = .4)
您是否知道在绘图边界框限制下正确裁剪多边形的好方法? 谢谢你的帮助
帕斯卡
答案 0 :(得分:28)
通常,这种裁剪是由于使用比例限制(在该范围之外的落点)进行缩放而不是使用坐标限制(这是一个真正的缩放,只是绘制内部的部分,范围之外的部分仍在那里)。 ggmap
没有一种简单的方法来指示应该使用第二种缩放类型,但是看一下这个功能,相关的部分可以被拉出并重新组合在一起:
s12 <- get_map(maptype = "satellite", zoom = 12)
ggmap(s12, base_layer=ggplot(aes(x=lon,y=lat), data=zips),
extent = "normal", maprange=FALSE) +
geom_polygon(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = NA, fill = "red", alpha = .5) +
geom_path(aes(x = lon, y = lat, group = plotOrder),
data = zips, colour = "white", alpha = .7, size = .4) +
coord_map(projection="mercator",
xlim=c(attr(s12, "bb")$ll.lon, attr(s12, "bb")$ur.lon),
ylim=c(attr(s12, "bb")$ll.lat, attr(s12, "bb")$ur.lat)) +
theme_nothing()