用 R 画中国分省市地图

用 R 画中国分省市地图

  (2010-11-18 16:25:34)
标签: 

中国地图

 

营销

 

杂谈

分类: 数据分析

用R 也可以做出漂亮的依参数变化的中国地图。

主要参考(http://cos.name/author/yixuanq/用 <wbr>R <wbr>画中国分省市地图

 

library(maptools)

axx<-readShapePoly("bou2_4p.shp", proj4string=CRS("+proj=longlat +ellps=clrk66"))

x=axx
#plot(x,col=gray(924:0/924));#using col instead of fg!

 

getColor=function(mapdata,provname,provcol,othercol)
{
 f=function(x,y) ifelse(x %in% y,which(y==x),0);
 colIndex=sapply(mapdata$NAME,f,provname);
 col=c(othercol,provcol)[colIndex+1];
 return(col);
}


provname=c("北京市","天津市","河北省","山西省","内蒙古自治区",
  "辽宁省","吉林省","黑龙江省","上海市","江苏省",
  "浙江省","安徽省","福建省","江西省","山东省",
  "河南省","湖北省","湖南省","广东省",
  "广西壮族自治区","海南省","重庆市","四川省","贵州省",
  "云南省","西藏自治区","陕西省","甘肃省","青海省",
  "宁夏回族自治区","新疆维吾尔自治区","台湾省",
  "香港特别行政区");
pop=c(1633,1115,6943,3393,2405,4298,2730,3824,1858,7625,
  5060,6118,3581,4368,9367,9360,5699,6355,9449,
  4768,845,2816,8127,3762,4514,284,3748,2617,
  552,610,2095,2296,693);
provcol=rgb(red=1-pop/max(pop)/1,green=1-pop/max(pop)/1,blue=1/1.5);
plot(x,col=getColor(x,provname,provcol,"white"),border = "grey",xlab="",ylab="")

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值