前言

近来由于工作需要,需要提取某些城市的经纬度坐标,稍微搜索了一下,发现百度地图和高德地图都提供了相关的函数和例子.那么剩余的工作也就比较简单了,保存坐标,然后转换为WGS坐标,这样才能和现有的GPS数据以及地图匹配.

主要问题和解决方法

本地保存文件跨浏览器支持

由于安全的原因,JavaScript本地保存文件的方式通常都只有IE支持的ActiveXObject/Open方法,每次都要提示不安全和允许运行,非常麻烦.好在其他浏览器目前都支持标签实现文件下载的方法.经测试最新的Google Chrome, Mozilla Firefox,百度浏览器,360浏览器下都可以运行.不说废话,直接上代码:

function Download() {

// IE

if(/msie/i.test(navigator.userAgent)) {

var w = window.open("", "导出", "height=0,width=0,toolbar=no,menubar=no,scrollbars=no,resizable=on,location=no,status=no");

var filename = document.getElementById("filename").value ;

var content = document.getElementById("content").value;

w.document.charset = "UTF-8";

w.document.write(content);

w.document.execCommand("SaveAs", false, filename+'.txt');

w.close();

}

// Firefox/Chrome/Safari/Opera

else {

var filename = document.getElementById("filename").value ;

var content = document.getElementById("content").value;

str = encodeURIComponent(content);

document.getElementById("SaveChrome").download = filename+'.txt';

var aLink = document.getElementById("SaveChrome") ;

aLink.href = "data:text/csv;charset=utf-8,"+str;

aLink.click();

}

}

经纬度转换

这个话题感兴趣的朋友可以自己搜索火星坐标相关转换,精度在1m范围的网上提供有服务可以免费使用.自写程序经验证精度在6m 以内.

百度地图方法

关键函数是 BMap.Boundary() 生成的类,调用它的方法get就可以通过名称获得县或市级以上的行政区域.

function getBoundary() {

var bdary = new BMap.Boundary();

var name = document.getElementById("districtName").value;

bdary.get(name, function (rs) { //获取行政区域

var fileName = "";

var newFileObject = fso.CreateTextFile(folderName + "\\" + name + ".txt", true);

map.clearOverlays(); //清除地图覆盖物

var count = rs.boundaries.length; //行政区域的点有多少个

for (var i = 0; i < count; i++) {

var ply = new BMap.Polygon(rs.boundaries[i], { strokeWeight: 2, strokeColor: "#ff0000" }); //建立多边形覆盖物

map.addOverlay(ply); //添加覆盖物

map.setViewport(ply.getPath()); //调整视野

}

newFileObject.write(rs.boundaries[0]);

newFileObject.Close();

});

}

高德地图

关键代码通过阅读示例文件可以发现在下拉列表返回里面有边界值的出现.

amapAdcode.search = function(adcodeLevel, keyword, selectId) {//查询行政区划列表并生成相应的下拉列表

var me = this;

if (adcodeLevel == 'district'||adcodeLevel == 'city') {//第三级时查询边界点

this._district.setExtensions('all');

} else {

this._district.setExtensions('base');

}

this._district.setLevel(adcodeLevel); //行政区级别

this._district.search(keyword, function(status, result) {//注意,api返回的格式不统一,在下面用三个条件分别处理

var districtData = result.districtList[0];

if (districtData.districtList) {

me.createSelectList(selectId, districtData.districtList);

} else if (districtData.districts) {

me.createSelectList(selectId, districtData.districts);

} else {

document.getElementById(selectId).innerHTML = '';

}

map.setCenter(districtData.center);

me.clearMap();

me.addPolygon(districtData.boundaries);

其中的districtData.boundaries 就是我们需要的.调试了一下,大胆猜测果然是实现了Tostring() 方法的一个对象.

"104.639106,26.863388,104.644771,26.861842,104.64767,26.854997,104.647748..." 很明显的就是我们需要的gcj坐标.

总结

至此,基本也就没有什么问题了,剩余的工作就是解析得到的文件.需要提取全国的数据也就是循环读取全国城市列表文件了.(通常搜索cityname,电脑里面都会找到的,原因,呵呵,猜测是迅雷,QQ之类的IP定位需要吧.)

重要的一点,推荐使用高德地图,原因就是百度地图得到的行政规划有问题,不包含县级市.最典型的就是贵州省,很多地市都是分离的,是带岛或洞的复杂多边形.百度在这里完败.关于怎么处理这里复杂的多边形以支持在MapWinGIS显示和处理,下次会写一篇笔记.

根据经纬度确定行政区域_基于JavaScript实现高德地图和百度地图提取行政区边界经纬度坐标...相关推荐

  1. python取省边界_提取行政区边界经纬度坐标(高德+百度)

    前言 近来由于工作需要,需要提取某些城市的经纬度坐标,稍微搜索了一下,发现百度地图和高德地图都提供了相关的函数和例子.那么剩余的工作也就比较简单了,保存坐标,然后转换为WGS坐标,这样才能和现有的GP ...

  2. Windows Store Javascript项目使用高德地图、谷歌地图、百度地图API

    Windows Store Javascript项目使用高德地图.谷歌地图.百度地图API 原文 Windows Store Javascript项目使用高德地图.谷歌地图.百度地图API 在Win8 ...

  3. 百度地图infowindow的close事件_高德地图,百度地图,腾讯地图哪个更准?

    先说结论 高德第一,百度第二,腾讯第三 这些地图商,他们是怎么知道"我家门口新开了一家咖啡店"这一事件的,并且标注上去还拍了照片呢?有些店新开了,有些店倒闭了,10年以前这条街上的 ...

  4. 基于Cesium使高德地图、百度地图、腾讯地图与天地图无偏移叠加

    基于Cesium使高德地图.百度地图.腾讯地图与天地图无偏移叠加 需求的产生 方法的探索 经验总结 需求的产生 在Cesium框架中,可以支持很多ImageryProvider,但是Viewer只用一 ...

  5. 曼哈顿距离java实现_基于javascript实现获取最短路径算法代码实例

    这篇文章主要介绍了基于javascript实现获取最短路径算法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 //A算法 自动寻路 ...

  6. javascript官方文档_基于Javascript编写的开源Markdown和HTML相互转换器——showdown

    介绍 showdown是一个基于Javascript编写的开源Markdown和HTML相互转换器,showdown可以用在客户端(浏览器)或者服务端(nodejs).shodown还支持原始规范中未 ...

  7. 根据经纬度确定行政区域_获取中国指定行政区域内所有POIS(兴趣点)的方法

    本文首发于:获取中国指定行政区域内所有POIS(兴趣点)的方法​xugongli.github.ioGitHub项目源码​github.com 早在2017年5月,曾经在知乎上写过一篇文章获取一个城市 ...

  8. jquery打99乘法表_基于javascript实现九九乘法表

    基于javascript实现九九乘法表 本文实例为大家分享了javascript实现九九乘法表的相关代码,具体内容如下 var sum=0; var wite; for (var i = 1; i & ...

  9. js微信抢红包脚本代码_基于JavaScript实现微信抢红包功能

    金额随机:额度在0.01和(剩余平均值*2)之间. 0){ let num = scramble(remainAmount,remainPeople); remainAmount = remainAm ...

最新文章

  1. MPB:邓晔、王尚等-​环境样本中的细菌总量测定—流式细胞法
  2. python同步异步_python中Tornado的同步与异步I/O的介绍(附示例)
  3. 命令行以及git基础使用
  4. xcode8 升级后注释快捷键不能使用的解决方法
  5. centos 6.0安装杀毒软件clamAV 0.98
  6. 第二章 寄存器基础概念
  7. eclipse终止端处的加载主类错误
  8. 牛逼!这么问 OutOfMemoryError 能让我懵逼!
  9. 【COCOS2DX-LUA 脚本开发之十二】利用AssetsManager实现在线更新资源文件
  10. 二、信号分解 —> 变分模态分解(VMD)学习笔记
  11. 医疗系统流程软件测试用例,医疗管理系统案例测试用例.doc
  12. 智能驾驶浪潮催生车载通信新机遇 移远通信抢占5G+C-V2X+GNSS风口
  13. Verilog实现的格雷码与二进制码的互相转换
  14. 抖音上热门的小技巧你都掌握了吗?
  15. App渠道安装来源识别与匹配
  16. 酷宇宙大学:代币经济学(第四课)如何评估代币的效用?
  17. postfix+dovecot+openldap+extmail+spamassassin+M...
  18. CentOS 7 安装redis过程中gcc: Command not found错误
  19. 老国企如何焕发新势能?致远互联“协同五环”锻造老而弥坚
  20. Cisco® Catalyst® 8000V 边缘软件 (Catalyst 8000V) 17.11.1a 发布 - 虚拟路由器

热门文章

  1. 通用人工智能:我们还有多远?
  2. 华为5500v3多路径linux6,使用Linux自带多路径multipath
  3. Jmeter读取CSV文件
  4. 我的第一个WFF项目
  5. 深入“无人地带”,快递企业能变更“快”吗?
  6. LogLoss的公式演化
  7. ZYT and LBC
  8. CameraPath插件使用
  9. 第一讲:最能入门的爬虫教程(Python实现)
  10. 数据营销“教父”宋星十年倾心之作,让数据真正赋能企业