中国地图_实用帖之Rggplot2 标准中国地图制作

本文介绍了如何使用R的ggplot2和sf包绘制中国标准地图,包括地图读取、散点标注、cowplot包子图的添加。通过geojson格式的数据,结合geom_sf()绘制地图,并利用ggspatial添加比例尺和指北针。同时,文章展示了如何处理经纬度数据并在地图上展示,以及使用cowplot进行子图组合的技巧。
摘要由CSDN通过智能技术生成

这期涉及空间图表绘制,主要涉及知识点如下:

  • ggplot2 + sf 中国标准地图绘制
  • cowplot 包实现地图子图插入

ggplot2 + sf 中国标准地图绘制

本期的绘图我们是按照如下图表进行绘制的(该图来自朋友公号):cb949c3356c46afb1201f3f7f69e492f.png

其实我很早就想试着用R进行此类图表的绘制了,但由于强大的Arcgis和绘图进度等原因,导致迟迟没有进行,这期就进行此类图表的绘制。注:图中散点的经纬度信息已从朋友那获知,但涉及具体数据则是虚构的。

地图读取和散点标注

这里的中国地图格式为 geojson 格式,还是使用sf包进行灵活读取,具体代码如下:

china_shp "中国省级地图GS(2019)1719号.geojson"
nine "九段线GS(2019)1719号.geojson"
china nine_line 

数据预览如下(部分):c7e6ac8c97c20535c54ff1a2ffe64609.pnga8e73b7147b23bf880f2b207a0717842.png

接下来我们进行探索性绘图,主要使用geom_sf() 进行绘制,代码如下:

library(ggspatial)
ggplot() + 
  geom_sf(data = china,fill="NA",size=1,color="black") + 
  geom_sf(data = nine_line) + 
  coord_sf(crs = "+proj=laea +lat_0=40 +lon_0=104")+
  annotation_scale(location = "bl") +
      # spatial-aware automagic north arrow
       annotation_north_arrow(location = "tl", which_north = "false",
                             style = north_arrow_fancy_orienteering)

这里可以看到,我们没有使用常规的WGS84坐标,而是采用 +proj=laea +lat_0=40 +lon_0=104 进行绘制,可视化结果如下:8e9f526e32082f3453c8dd030e1f11f1.png

比例尺和指北针的添加,则是依靠ggspatial包。

散点数据的读取

由于只获得数据经纬度信息,其他数据均为虚构,数据预览如下:a4603beb7509a2ee931c79e376266037.png

这里注意点,要想使数据绘制在地图上,我们需使用st_as_sf()对其进行转换,处理:

scatter_df_tro "lon", "lat"),crs = 4326)

结果如下:cee20384b0b1750532f83bedbe725d06.png注意红色框中的内容

接下来将数据在地图中显示,具体代码如下:

ggplot() + 
  geom_sf(data = china,fill="NA",size=.5,color="black") + 
  geom_sf(data = nine_line) + 
  geom_sf(data = scatter_df_tro,aes(fill=class,size=data),shape=21,colour='black',stroke=.25)+
  coord_sf(crs = "+proj=laea +lat_0=40 +lon_0=104")+
  scale_fill_manual(values = c("#E21C21","#3A7CB5","#51AE4F"))+
  scale_size(range = c(1,5))+
  annotation_scale(location = "bl") +
      # spatial-aware automagic north arrow
       annotation_north_arrow(location = "tl", which_north = "false",
                             style = north_arrow_fancy_orienteering)+
  theme_linedraw()+
  theme(text = element_text(family = 'Times_New_Roman',size = 12,face = "bold"),
        panel.background = element_rect(fill = NA),
        panel.grid.major = element_line(colour = "grey50"),
        #axis.line = element_line(size = 1, colour = "black"),
        panel.ontop = FALSE
        )

可视化结果如下:dc329913ed6a1c4b4506161546efd065.png

这里还存在如下问题:

(1) 尽量将南海部分放置在右下角(虽然这样也可以)

(2) 图例只是默认的,没有进行定制化操作,影响美观

cowplot包子图添加

cowplot包可是实现对绘图结果的任意组合,很适合绘制地图子图的绘制,这里直接给出绘图代码,如下:

library(cowplot)

map   geom_sf(data = china,fill=NA) + 
  geom_sf(data = nine_line,color='gray50',size=.8)+
  geom_sf(data = scatter_df_tro,aes(fill=class,size=data),shape=21)+
  coord_sf(ylim = c(-2387082,1654989),crs="+proj=laea +lat_0=40 +lon_0=104")+
  scale_fill_manual(values = c("#E21C21","#3A7CB5","#51AE4F"))+
  scale_size(range = c(1,5))+
  annotation_scale(location = "bl",text_face = "bold",
                   text_family = "Times_New_Roman") +
      # spatial-aware automagic north arrow
       annotation_north_arrow(location = "tl", which_north = "false",
                             style = north_arrow_fancy_orienteering,
                            )+
  #定制化图例:这一步可以设计出亮眼的图例哦
  guides(fill = guide_legend(override.aes = list(size = 3),
                             title = "",
                             label.position = "right",
                             ncol=3,
                             ),
         size = guide_legend(
                             title = "",
                             label.position = "right",
                             ncol=5)) +
 labs(
          caption = 'Visualization by DataCharm')+
 #theme_bw()+
 theme(
     text = element_text(family = 'Times_New_Roman',size = 18,face = "bold"),
     
     panel.background = element_rect(fill = NA),
     panel.grid.major = element_line(colour = "grey80",size=.2),
     legend.key = element_rect(fill = "white"),
     legend.position = "bottom",
 )

nine_map   geom_sf(data = china,fill='NA') + 
  geom_sf(data = nine_line,color='gray70',size=1.)+
  #geom_sf(data = scatter_df_tro,aes(fill=class,size=data),shape=21,colour='black',stroke=.25)+
  coord_sf(ylim = c(-4028017,-1877844),xlim = c(117131.4,2115095),crs="+proj=laea +lat_0=40 +lon_0=104")+
  theme(
    #aspect.ratio = 1.25, #调节长宽比
    axis.text = element_blank(),
    axis.ticks = element_blank(),
    axis.title = element_blank(),
    panel.grid = element_blank(),
    panel.background = element_blank(),
    panel.border = element_rect(fill=NA,color="grey10",linetype=1,size=1.),
    plot.margin=unit(c(0,0,0,0),"mm"))


gg_inset_map = ggdraw() +
  draw_plot(map) +
  draw_plot(nine_map, x = 0.8, y = 0.15, width = 0.1, height = 0.3)

可视化效果如下:

191971ce9f5a39c70a34bc9cfb1899b8.png

这里需注意的是xlim和ylim的设置,具体值都是在 +proj=laea +lat_0=40 +lon_0=104 投影坐标系下的值,而常规坐标转不同坐标下的操作也很简单,可使用st_transform进行操作。如下:

df2        lat = c(3,25),
       ) 

df2 %>% 
  st_as_sf(coords = c("lon", "lat"), crs = 4326) -> df2_sf

df2_sf_pre "+proj=laea +lat_0=40 +lon_0=104")
df2_sf_pre

即可获取对应值,进而进行范围设置。

总结

该期推文也是基于自己对地图的喜欢进行绘制,后面还是会以基础图表的绘制为主,希望大家能够喜欢,多多支持。更多想法可以在留言区进行留言告知。

8046244e426b4f0464e6c5ccbbc161df.png

点个在看呗!
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值