谷歌地图地理解析和反解析geocode.geocoder详解 谷歌Geocoder服务 实例代码

地址解析就是将地址(如:贵州省贵阳市)转换为地理坐标(如经度:106.71,纬度:26.57)的过程。

地理反解析和上面的过程相反是将地理坐标(如纬度:26.57,经度:106.71)转换为地址(中国贵州省贵阳市南明区翠微巷7号 邮政编码: 550002)的过程。

受当地法律限制及各方面原因,国内很多地图并不包含地理解析和反解析功能(地理解析和反解析功能功能不够强悍),Google永远是最棒的。

要使用到Google map 地理解析和反解析功能,我们需要了解google.maps.Geocoder类,谷歌地图给我们提供了强大的api

下面我们来实现

1.初始化地图(最基本的,不解释)

  1. //初始化地图
  2. var map = new google.maps.Map(document.getElementById("map_canvas"),{
  3. center : new google.maps.LatLng(26.57, 106.72),
  4. zoom : 8,
  5. mapTypeId : google.maps.MapTypeId.ROADMAP
  6. });

2.实例化谷歌Geocoder服务

  1. //实例化Geocoder服务
  2. var geocoder = new google.maps.Geocoder();

这样我们就可以进行地理解析和反解析了,使用代码:

  1. geocoder.geocode(request:GeocoderRequest, callback:function(Array., GeocoderStatus))

一  请求数据:其中需要进行请求的数据GeocoderRequest可为4种属性:

属性 类型 描述
address string 需要解析的地名. 可选.
bounds LatLngBounds 经纬度搜索范围. 可选.(我没有具体试用过)
location LatLng(注意类型) 需要解析的经纬度. 可选.
region string 国家代码. 可选.(我没有具体试用过)

对于解析我们使用address,反解析使用location(注意传入的类型),请求的话,至少选择一种。

二  结果处理:而对于回掉函数(即解析后返回的处理函数)包含两个内容,GeocoderResult(解析结果,数组类型)和GeocoderStatus(解析状态)

1.解析状态是使用Geocoder()进行解析后返回的状态,包含5种:

ERROR(谷歌地图服务可能出错)
INVALID_REQUEST(GeocoderRequest无效,即输入的请求是错误的,可能是没有选择,或者属性写错)
OK(解析完成,并有相应数据)
OVER_QUERY_LIMIT(响应超时)
REQUEST_DENIED(网页被禁止geocoder解析)
UNKNOWN_ERROR(未知错误)
ZERO_RESULTS(零结果)

我们能用的就是状态为OK的情况

2.解析结果

属性 类型 描述
address_components Array.<GeocoderAddressComponent> GeocoderAddressComponents数组
formatted_address string 格式化后的最佳匹配地址(地名可小到街道)
geometry GeocoderGeometry GeocoderGeometry 对象
types Array. 一个表示返回的地理编码元素的类型的字符串数组

其中每一次解析成功后都会有上面的信息,我们最需要的就两样formatted_address和geometry。而address_components是一个地名数组,包含long_name(比如只返回省市名称),short_name和types,可以自己去试一下。

(a). 格式化后的地名formatted_address,只需直接调用即可

(b).geometry返回一个GeocoderGeometry 对象,其中又包含有4个属性

Properties Type Description
bounds LatLngBounds 解析出来的精确的界限
location LatLng 纬度/经度坐标
location_type GeocoderLocationType 返回的location类型
viewport LatLngBounds 解析结果的视图范围

至此,所有关于地理解析和反解析就差不多说明完了,具体api参见https://developers.google.com/maps/documentation/javascript/reference#Geocoder

感觉说的好晕!基于此我做了一个关于批量解析和反解析的应用,详见:http://map.yanue.net/geo.htmlhttp://map.yanue.net/toLatLng .使用详解:http://www.yanue.net/archives/207.html

下面我们来实例一下实例代码:

(你有必要复制到本地试一下)

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <meta charset="UTF-8">
    5. <script src="http://maps.google.com/maps/api/js?sensor=false&libraries=places" type="text/javascript"></script>
    6. <title>谷歌地图地理解析和反解析geocode.geocoder详解</title>
    7. <meta name="author" content="yanue" />
    8. <meta name="copyright" content="powered by yanue" />
    9. <link rel="site" href="http://map.yanue.net/" />
    10. <script type="text/javascript">
    11. window.onload = function() {
    12. //初始化地图
    13. var map = new google.maps.Map(document.getElementById("map_canvas"),{
    14. center : new google.maps.LatLng(26.57, 106.72),
    15. zoom : 8,
    16. mapTypeId : google.maps.MapTypeId.ROADMAP
    17. });
    18. //实例化Geocoder服务
    19. var geocoder = new google.maps.Geocoder();
    20. //1.地理解析过程
    21. //请求数据GeocoderRequest为address,值为'贵阳'
    22. geocoder.geocode({address:'贵阳'},function geoResults(results, status){
    23. //这里是回掉函数(即结果处理函数)
    24. //状态为Ok说明有结果
    25. if (status == google.maps.GeocoderStatus.OK) {
    26. //一般情况下会有多个结果
    27. //第一个结果为最佳匹配的结果(匹配地名最全的结果),这里只去第一个,其他的可以根据需要自己循环出来
    28. //格式化过后的地址
    29. alert('地理解析结果:'+results[0].formatted_address);
    30. //geometry是一个包含bounds(界限),location(纬度/经度坐标),location_type和viewport(视图范围)
    31. //获取解析后的经纬度
    32. alert('地理解析结果:'+results[0].geometry.location);
    33. }else{
    34. alert(":error " + status);
    35. }
    36. });
    37. //2.地理反解析过程
    38. //请求数据GeocoderRequest为location,值类型为LatLng因此我们要实例化经纬度
    39. geocoder.geocode({location:new google.maps.LatLng(26.57, 106.72)},function geoResults(results, status){
    40. //这里处理结果和上面一模一样
    41. if (status == google.maps.GeocoderStatus.OK) {
    42. alert('地理反解析结果:'+results[0].formatted_address);
    43. alert('地理反解析结果:'+results[0].geometry.location);
    44. }else{
    45. alert(":error " + status);
    46. }
    47. });
    48. }
    49. </script>
    50. </head>
    51. <body>
    52. <div id="map_canvas" style='width: 300px; height: 200px;'></div>
    53. </body>
    54. </html>

谷歌地图地理解析和反解析geocode.geocoder详解(转)的更多相关文章

  1. 谷歌地图地理解析和反解析geocode.geocoder详解

    地址解析就是将地址(如:贵州省贵阳市)转换为地理坐标(如经度:106.71,纬度:26.57)的过程. 地理反解析和上面的过程相反是将地理坐标(如纬度:26.57,经度:106.71)转换为地址(中国 ...

  2. 【001】JS解析,反解析XML的一些问题

    JS解析,反解析 XML 的一些问题 2016-03-25 15:38:28 星期五 文章底部下面有提供把 字符串 变成 XML 对象的方法. 该方法,在 Chrome48 ,FireFox ,IE1 ...

  3. 数据结构图文解析之:二叉堆详解及C++模板实现

    0. 数据结构图文解析系列 数据结构系列文章 数据结构图文解析之:数组.单链表.双链表介绍及C++模板实现 数据结构图文解析之:栈的简介及C++模板实现 数据结构图文解析之:队列详解与C++模板实现 ...

  4. iOS地图 -- 地理编码和反地理编码

    地理编码和反地理编码 用到的类和方法 CLGeocoder --> 地理编码管理器 - (void)geocodeAddressString:(NSString *)addressString ...

  5. 四种生成和解析XML文档的方法详解(介绍+优缺点比较+示例)

    众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 下面首先给出这四种方法的jar包下载地址 DOM:在现在的Java JDK里都自带了,在xml- ...

  6. 四种生成和解析XML文档的方法详解

    众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 下面首先给出这四种方法的jar包下载地址 DOM:在现在的Java JDK里都自带了,在xml- ...

  7. 大杂烩 -- 四种生成和解析XML文档的方法详解

    基础大杂烩 -- 目录 众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J DOM:在现在的Java JDK里都自带了,在xml-apis.jar包 ...

  8. 解析xml的4种方法详解

    1. 介绍 1)DOM(JAXP Crimson解析器)         DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许 ...

  9. Java解析HTML之HTMLParser使用与详解 分类: C_OHTERS 2014-05-19 21:46 2309人阅读 评论(0) 收藏

    转自:http://free0007.iteye.com/blog/1131163 HTMLParser具有小巧,快速的优点,缺点是相关文档比较少(英文的也少),很多功能需要自己摸索.对于初学者还是要 ...

随机推荐

  1. 使用Jenkins和Jmeter搭建性能测试平台

    参考文档:http://blog.csdn.net/liuchunming033/article/details/52186157 jenkins的性能测试结果展现插件:https://wiki.je ...

  2. 使用DBCA工具创建自己的数据库

    ylbtech-Oracle:使用DBCA工具创建自己的数据库  DBCA创建数据库 默认安装的Oracle数据库一般不能满足实际应用的需求,例如数据库名称.数据库块的大小等都需要修改,那么我们应该自 ...

  3. 如何在脚本中执行SQL语句并获得结果输出?

    这里需要用到的工具叫做sqlcmd.exe, 它随SQL server的安装而安装. 该可执行程序的位置在: C:\Program Files\Microsoft SQL Server\xxx\Too ...

  4. 一行代码轻松实现拖动效果[JQuery]

    写JS实现拖动需要一大堆不便维护的代码,实属麻烦,Google了大半天,发现了一个优秀的Jquery插件EasyDrag,只需要一行代码便可轻松在主流浏览器上 实现拖动效果.   $(document ...

  5. android 时间控件概述

    android的自带时间选择控件,是一个让用户既能输入的又能选择的样子.这本来没有太大的问题了. 但是,坑爹的android是开源的.自带的时间控件在某些机型上,早已经是面目全非了,在用以一个普通用户 ...

  6. LCS 算法

    下面的程序分别实现了使用LCS求连续子串和不连续子串的匹配情况! http://beyond316.blog.51cto.com/7367775/1266360

  7. [Algorithm] Count Negative Integers in Row/Column-Wise Sorted Matrix

    // Code goes here function countNegative (M, n, m) { count = ; i = ; j = m - ; && i < n) ...

  8. [Algorithm] How to use Max Heap to maintain K smallest items

    Let's say we are given an array: [,,,,,,] We want to get K = 3 smallest items from the array and usi ...

  9. Oracle综合数据库管理命令集

    sqlplus SANKYU/SANKYU@ORADB_192.168.25.235 cmd: exp .......(最后不要加;号)--sankyuexp SANKYU/SANKYU@SUNNY ...

  10. JDBC的简单操作

    JDBC是一组能够执行SQL语句的API 由于传统的数据库操作方式需要程序员掌握各个不同的数据库的API,极其不便 因此java定义了JDBC这一标准的接口和类,为程序员操作数据库提供了统一的方式 J ...