【R语言作图】如何在地图上任意位置画饼图直方图等

N久不分享学习心得的小Q终于有时间冒个泡了,这次分享一个小Q改良后的在地图上任意画饼图,直方图的R代码(其实是摸清了数据结构后自己多加了几行代码+),这里以饼图为例。

画图原理

1.利用R包rworldmap & rworldxtra来作图。
2.已有的map数据中一个国家对应一个坐标,一个国家边界,利用这些已有数据+用户数据构建新的画图数据(其他新添加的图均是如此)。

rworldmap包的介绍

1.如果想查看rworldmap包的情况

help(package="rworldmap")

2.了解high resolution map情况

a<-getMap(resolution = "high")
# Map是一个sp对象,SpatialLinesDataFrame类
# 结构如下:
# a@data
# a@polygons
# a@plotOrder
# a@bbox
# a@proj4string

# 我们主要利用a@data和a@polygons
v<-a@data
colnames(v)
 [1] "ne_10m_adm"   "ScaleRank"   
 [3] "LabelRank"    "FeatureCla"  
 [5] "OID_"         "SOVEREIGNT"  
 [7] "SOV_A3"       "ADM0_DIF"    
 [9] "LEVEL"        "TYPE"        
[11] "ADMIN"        "ADM0_A3"     
[13] "GEOU_DIF"     "GEOUNIT"     
[15] "GU_A3"        "SU_DIF"      
[17] "SUBUNIT"      "SU_A3"       
[19] "NAME"         "ABBREV"      
[21] "POSTAL"       "NAME_FORMA"  
[23] "TERR_"        "NAME_SORT"   
[25] "MAP_COLOR"    "POP_EST"     
[27] "GDP_MD_EST"   "FIPS_10_"    
[29] "ISO_A2"       "ISO_A3"      
[31] "ISO_N3"       "ISO3"        
[33] "LON"          "LAT"         
[35] "ISO3.1"       "ADMIN.1"     
[37] "REGION"       "continent"   
[39] "GEO3major"    "GEO3"        
[41] "IMAGE24"      "GLOCAF"      
[43] "Stern"        "SRESmajor"   
[45] "SRES"         "GBD"         
[47] "AVOIDnumeric" "AVOIDname"   
[49] "LDC"          "SID"         
[51] "LLDC"
# ***这里主要使用***:
# 第11列:类对象属性ID
# 第19列:后期绘图匹配项
# 第33列:绘图时的经度
# 第34列:绘图时的纬度

3.实例操作

1)输入文件格式说明

文件逗号分隔,每列的说明:
1.ID
新的类对象属性ID,自定义,等于原来map中的11列ADMIN
2.Name
后期绘图匹配项,同ID即可,等于原来map中的19列NAME
3.LON
绘图时的经度33列LON
4.LAT
绘图时的纬度34列LAT
注意:这里的经纬度是你自己想要标记饼图的经纬度(起到随意标记点的作用)
5.国家名
和原始map文件中的第11列ADMIN ID对应,每个国家都有一个坐标多边形区域,必须把坐标点画在某个国家内
6.饼图分块-1
7.饼图分块-2
8.legend名字
这里一个饼图只分成2部分,用户可自定义添加更多

2)画图的具体代码如下:
rm(list=ls())
library(rworldmap)
library(rworldxtra)
#---------------------------------
# 读入输入文件
dat<-read.table("test.txt",header = T,sep=",",stringsAsFactors = F)
> dat
        ADMIN        NAME       LON      LAT     rawName  P1  P2 legendName
1 Philippines Philippines 121.41825 15.95318 Philippines 0.5 0.5 legendName
2  Bangladesh  Bangladesh  90.22658 23.88242  Bangladesh 0.4 0.6 legendName
3     Myanmar     Myanmar  96.48873 21.21545     Myanmar 0.2 0.8 legendName
#---------------------------------
# 提取原始high resolution map的数据,作为map对应的新数据
a<-getMap(resolution = "high")
rawData<-a@data[,c(11,19,33,34)]
#---------------------------------
# 注意下面的操作,因为我的饼图只区分2块,所以只需要多增加2列数据
rawData[,5]<-NaN  #  A1_freq  作图时不出现
rawData[,6]<-NaN  #  A2_freq  作图时不出现
colnames(rawData)<-colnames(dat)[c(1:4,6,7)]
IDname<-c()
for(i in 1:length(a@plotOrder)){IDname[i]<-a@polygons[[i]]@ID} 
#---------------------------------
#  将新数据data覆盖原始的数据data
rawData<-rbind(rawData,dat[,c(1:4,6,7)])    #  合并新旧数据
a@data<-rawData  
#---------------------------------
#  添加新加入的城市对应的对象属性polygons,添加一个对象到list中
#  polygons是一个list;每个成员是一个sp
#  每个sp的polygons又是一个list,每个成员是一个sp
#  每个sp都有其自己的对象属性,相同或不同
#
for(i in 1:dim(dat)[1])
{
index<-which(IDname==dat[i,5])              #  获得新坐标点所在国家[第五列]在原有map中的下标
tmpPolygon<-a@polygons[[index]]             #  提取国家的polygon信息{ID=国家名}
tmpPolygon@labpt<-as.numeric(dat[i,3:4])    #  坐标更换为新坐标点的经纬度
tmpPolygon@ID<-dat[i,1]                     #  对象ID更换为新坐标点的名字

a@polygons<-c(a@polygons,list(tmpPolygon))  #  将新生成的polygon添加到原有的polygon List中
                                            #  相当于把新坐标点的polygon信息添加到map中
                                            #  新坐标点的polygon取所在国家的polygon
}
#---------------------------------
#  plot map pie
par(oma=c(0,0,0,0),
    mar=c(0,0,0,0),
    fig=c(0,1,0,1),
    mai=c(0,0,0,0)
    )

# 因为我的饼图只区分2块,所以只需要2个颜色
color_array<-c("black","red")

mapPies(a,
        nameZs = c(colnames(a@data)[5],
                   colnames(a@data)[6]),    #  用作画图的两列
        zColours=color_array,              #  不同比例的颜色
        symbolSize = 0.5,                   #  pie的大小
        addCatLegend=F,                     #  不添加默认的legend
        oceanCol = "lightblue",
        landCol = "wheat")
legend(60,0,                            #  legend所在的横纵坐标/经纬度
       legend = c(colnames(a@data)[5],
                  colnames(a@data)[6]),     #  legend中的指示文字
       fill = color_array,                 #  legend 指示box的颜色,要求顺序同上zColours
       title = dat[1,8],                    #  legend title
       bty="n",                             #  不做legen的背景框
       title.adj = c(1)
       )

成品如下

地图+饼图
转载请标明出处和作者 ^+^

撰文&编辑:VickieQ
校对:HCLO4 & 花毛

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352