百度地图API是一套为开发者免费提供的基于百度地图的应用程序接口,包括JavaScript、iOS、Andriod、静态地图、Web服务等多种版本,提供基本地图、位置搜索、周边搜索、...

[html] view plain copy
  1. <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=(百度API key,可免费申请)"></script>
  2. <style type="text/css">
  3. body,html,#allmap {
  4. width: 100%;
  5. height: 100%;
  6. overflow: hidden;
  7. margin: 0;
  8. }
  9. #allmap {
  10. margin-top: 35px;
  11. }
  12. #golist {
  13. display: none;
  14. }
  15. @media ( max-device-width : 780px) {
  16. #golist {
  17. display: block !important;
  18. }
  19. }
  20. .tuijian_listbox1 {
  21. position: fixed;
  22. background: #fff;
  23. height: 35px;
  24. top: 0px;
  25. left: 0px;
  26. width: 100%;
  27. }
  28. ul.tuijian_list2 li {
  29. width: 24%;
  30. height: 35px;
  31. float: left;
  32. text-align: center;
  33. line-height: 35px;
  34. }
  35. </style>
  36. <body>
  37. <div class="tuijian_listbox1">
  38. <ul class="tuijian_list2">
  39. <li val_class="景点">景点</li>
  40. <li val_class="住宿" style="border-left: solid 1px #e4e4e4;">住宿</li>
  41. <li val_class="农家乐" style="border-left: solid 1px #e4e4e4;">农家乐</li>
  42. <li val_class="小吃" style="border-left: solid 1px #e4e4e4;">特色小吃</li>
  43. </ul>
  44. </div>
  45. <div class="map" id="allmap"></div>
  46. <script type="text/javascript">
  47. var map;
  48. var bounds;
  49. var circle;
  50. var local;
  51. var lng='118.792255';
  52. var lat='32.047475';//指定位置的经度纬度可以到百度定位拾取系统去拿 http://api.map.baidu.com/lbsapi/getpoint/index.html
  53. var search= '景区';
  54. var MyMarker;
  55. // 百度地图API功能
  56. $(function(){
  57. map = new BMap.Map("allmap");
  58. GetLocation();
  59. var mPoint = new BMap.Point(lng,lat);
  60. var MyIcon = new BMap.Icon("标记箭头图标路径", new BMap.Size(18,28));
  61. MyMarker = new BMap.Marker(mPoint,{icon:MyIcon});
  62. map.enableScrollWheelZoom();
  63. map.centerAndZoom(mPoint,15);
  64. map.addOverlay(MyMarker);
  65. map.addEventListener("click", function(e){
  66. map.removeOverlay(MyMarker);
  67. mPoint = new BMap.Point(e.point.lng,e.point.lat);
  68. MyMarker = new BMap.Marker(mPoint,{icon:MyIcon});
  69. map.addOverlay(MyMarker);
  70. Search(search,mPoint);
  71. });
  72. $('.tuijian_list2 li').each(function(index) {
  73. $(this).click(function(){
  74. $(this).parents('.tuijian_list2').find('.tuijian_in').removeClass('tuijian_in');
  75. $(this).addClass("tuijian_in");
  76. search = $(this).attr('val_class');
  77. Search(search,mPoint);
  78. });
  79. });
  80. Search(search,mPoint);
  81. });
  82. /**
  83. * 得到圆的内接正方形bounds
  84. * @param {Point} centerPoi 圆形范围的圆心
  85. * @param {Number} r 圆形范围的半径
  86. * @return 无返回值
  87. */
  88. function getSquareBounds(centerPoi,r){
  89. var a = Math.sqrt(2) * r; //正方形边长
  90. var mPoi = getMecator(centerPoi);
  91. var x0 = mPoi.x, y0 = mPoi.y;
  92. var x1 = x0 + a / 2 , y1 = y0 + a / 2;//东北点
  93. var x2 = x0 - a / 2 , y2 = y0 - a / 2;//西南点
  94. var ne = getPoi(new BMap.Pixel(x1, y1)), sw = getPoi(new BMap.Pixel(x2, y2));
  95. return new BMap.Bounds(sw, ne);
  96. };
  97. //根据球面坐标获得平面坐标。
  98. function getMecator(poi){
  99. return map.getMapType().getProjection().lngLatToPoint(poi);
  100. };
  101. //根据平面坐标获得球面坐标。
  102. function getPoi(mecator){
  103. return map.getMapType().getProjection().pointToLngLat(mecator);
  104. };
  105. function Search(search,mPoint){
  106. map.clearOverlays();
  107. circle = new BMap.Circle(mPoint,1000,{stroke:"white",strokeWeight: 1 ,fillOpacity: 0.3, strokeOpacity: 0.3});
  108. map.addOverlay(circle);
  109. local =  new BMap.LocalSearch(map, {renderOptions: {map: map, autoViewport: false}});
  110. bounds = getSquareBounds(circle.getCenter(),circle.getRadius());
  111. local.searchInBounds(search,bounds);
  112. map.addOverlay(MyMarker);
  113. /*
  114. map.centerAndZoom(mPoint, 16);
  115. var local = new BMap.LocalSearch(map, {
  116. renderOptions: {map: map, panel: "r-result"}
  117. });
  118. local.search(search);
  119. */
  120. };
  121. function GetLocation(){
  122. var geolocation = new BMap.Geolocation();
  123. geolocation.getCurrentPosition(function(r){
  124. if(this.getStatus() == BMAP_STATUS_SUCCESS){
  125. lng = r.point.lng;
  126. lat = r.point.lat;
  127. }else{
  128. alert('failed'+this.getStatus());
  129. }
  130. },{enableHighAccuracy: true}
  131. );
  132. };
  133. </script>
  134. </body>
  135. </html>

转载于:https://www.cnblogs.com/telwanggs/p/6484732.html

百度API获取位置范围内的周边服务相关推荐

  1. 百度地图Geolocation的getStatus状态值(百度API获取当前位置[经纬度])

    //关于状态码 //BMAP_STATUS_SUCCESS 检索成功.对应数值"0". //BMAP_STATUS_CITY_LIST 城市列表.对应数值"1" ...

  2. 全球地区资料json 含中英文 经纬度_爬虫实战(三)使用百度API获取经纬度/地址...

    点击上方"蓝字"关注我们百度API获取经纬度/地址Mar 28, 2020 本期介绍给定地址/经纬度,使用百度API来获取经纬度/地址. 本文约3k字,预计阅读18分钟. 本次是第 ...

  3. 【转】百度API获取城市名地名(附源码)

    在做一个软件时,用到了定位功能.网上有很多关于google 的GPS定位,但网上关于google定位都没有用, 搜索下原因:(这里建议大家在中国就尽量不使用系统自带的定位) 因为Google的服务器不 ...

  4. 百度api获取经纬度以及经纬度的转换

    vue根据百度api获取到自己所在位置的经纬度以及具体的位置名称 <group class="site" label-width="5.5em" labe ...

  5. vue使用百度地图获取位置信息

    vue使用百度地图获取位置信息 最近再做H5页面,就一个单页面,进来的时候,要获取地理位置,上代码 1.使用srcipt不受同源策略的影响,来获取百度api 写在了一个bmap.js里面,onBMap ...

  6. 使用百度API获取地名坐标信息

    使用百度API获取地名坐标信息 百度API使用前需要申请AK 申请地址:http://lbsyun.baidu.com/apiconsole/key 在这里,http://lbsyun.baidu.c ...

  7. 微信小程序使用百度api获取天气信息 —— 微信小程序教程系列(16)

    之前已经介绍过,如何使用百度地图api来获取地理位置信息 微信小程序的百度地图获取地理位置 -- 微信小程序教程系列(15) 下面介绍使用百度api来获取天气信息. 1> 第一步:先到百度开放平 ...

  8. python 获取天气_Python实现从百度API获取天气的方法

    本文实例讲述了Python实现从百度API获取天气的方法.分享给大家供大家参考.具体实现方法如下: __author__ = 'saint' import os import urllib.reque ...

  9. Android开发:基于原生API获取位置信息、卫星信号个数及参与定位的卫星个数

    目录 概述 权限申请及开启GPS 调用原生API进行定位 获取设备收到的卫星信号个数 获取用于定位的卫星信号个数 成果图 概述 最近在做室内外无缝定位的相关demo,室外定位中,GNSS定位方法具有精 ...

最新文章

  1. KVM调整cpu和内存
  2. Mysql错误:服务名无效。 请键入 NET HELPMSG 2185 以获得更多的帮助。
  3. 《转载》POI导出excel日期格式
  4. python处理excel案例_python操作excel例子
  5. python finally语句里面出现异常_Python异常处理中的else和finally
  6. (四)为深度伪造预处理数据集
  7. c++描述将一个2进制数转化成10进制数(用到初始化栈,进栈,入栈)
  8. 线性回归和逻辑回归的区别_Spark实现线性回归与逻辑回归算法
  9. SDN的机遇与挑战 让宽带利用率与硬件不再是难题
  10. 拓端tecdat|R语言分段线性回归分析预测车辆的制动距离
  11. CSS 子元素铺满整个父元素、CSS + JQuery 实现遮罩层
  12. 订阅机票时要注意的几个教训
  13. 基于OpenCV及Python的数独问题识别与求解(一)图像预处理
  14. 如何使用AForge调用本机摄像头
  15. Linux-v10-01天-授课
  16. 四叉树与八叉树原理 / AABB OBB / 碰撞检测优化
  17. make: 对“all”无需做任何事
  18. 第十三届蓝桥杯省赛 JAVA A组 - 蜂巢
  19. Gentoo USE参数清单中文详解
  20. 怎样设置网页中的文字样式

热门文章

  1. (44)FPGA时序逻辑与组合逻辑(组合逻辑)
  2. stm32 hal 串口只可以接收到一包数据数据
  3. 【UCOSIII】一、任务创建、删除、挂起、恢复、任务管理
  4. magento 优化 php.ini,PHP.ini配置文件(中文) | Magento UI
  5. Linux 异步通知
  6. mysql 利用触发器(Trigger)让代码更简单
  7. [MFC] CDialog::DoModal()函数用法
  8. maven服务器项目,Maven项目搭建
  9. linux写文件操作同步,linux 可执行文件与写操作的同步问题(文件读写操作产生的锁机制)...
  10. 虚拟内存的作用、分页系统实现虚拟内存原理