H5+百度地图自定义定位控件、调用H5+定位接口
2015-11-05 11:21
555 查看
由于百度地图的定位控件是调用内置的定位接口,想要调用H5+的定位接口就不行,自己改造一下就好了
/** * Author 岳晓 * * 自定义定位控件,调用H5+内置定位API */ (function(BMap){ var control = BMap.Map.XGeolocationControl = function(){ this.defaultAnchor = BMAP_ANCHOR_BOTTOM_LEFT; this.defaultOffset = new BMap.Size(10, 50); } control.prototype = new BMap.Control(); control.prototype.locate=function(cb){ _locate(this.map,this.controlPane.querySelector(".BMap_geolocationContainer"),cb); }; control.prototype.getMap=function(){ return this.map; }; control.prototype.setOnLocateComplete=function(fn){ if(typeof(fn)=="function"){ this.locateComplete = fn; } }; control.prototype.initialize = function(map){ this.map = map; var div = document.createElement("div"); div.innerHTML= '<div class="BMap_geolocationIconBackground" style="height: 32px; background-image: url(http://api0.map.bdimg.com/images/geolocation-control/mobile/gradient-bg-1x64.png); background-size: 1px 32px; background-repeat: repeat-x;">'+ '<div class="BMap_geolocationIcon" style="width: 32px; height: 32px; cursor: pointer; background-image: url(http://api0.map.bdimg.com/images/geolocation-control/mobile/fail-40x40.png); background-size: 20px 20px; background-position: 50% 50%; background-repeat: no-repeat;"></div>'+ '</div>'+ '<div class="BMap_geolocationAddress" style="padding:0 10px 0 10px;background:#FFF;display:-webkit-box;-webkit-box-align:center; box-sizing:border-box;border-left-width: 1px; border-left-style: solid; border-left-color: rgb(217, 215, 213); background-image: url(http://api0.map.bdimg.com/images/geolocation-control/mobile/gradient-bg-1x64.png); background-size: 1px 32px; background-repeat: repeat-x;">'+ ' <div class="BMap_geolocationAddressText" style="text-align:center;font-size: 12px; color: #666666; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; display: block; min-width: 50px; max-width: 400px;"></div>'+ '</div>'; div.className = "BMap_geolocationContainer"; div.setAttribute("style",'-webkit-transition:width 0.2s ease-in;height: 32px;;width:34px;display: -webkit-box; margin: 0px; box-sizing: border-box; border: 1px solid #d9d7d5; border-radius: 3px; -webkit-box-shadow: 1px 1px 1px rgba(0,0,0,.2); overflow: hidden;') var geolocation = div.querySelector(".BMap_geolocationIcon"); var address = div.querySelector(".BMap_geolocationAddress"); var text = div.querySelector(".BMap_geolocationAddressText"); map.getContainer().appendChild(div); var $this = this; geolocation.addEventListener("click", function(e){ _locate(map,div,$this.locateComplete); }); this.controlPane = div.parentElement; return div; }; var mk = null; function _locate(map,div,cb){ if(mk){ map.removeOverlay(mk); mk.disableMassClear(); } var geolocation = div.querySelector(".BMap_geolocationIcon"); var address = div.querySelector(".BMap_geolocationAddress"); var text = div.querySelector(".BMap_geolocationAddressText"); div.style.width= "34px"; text.innerText=""; geolocation.style.backgroundImage = "url(http://api0.map.bdimg.com/images/geolocation-control/mobile/loading-40x40.gif)"; Towery.locate({ success:function(position){ if(cb) cb({ status:0, result:position }); geolocation.style.backgroundImage = "url(http://api0.map.bdimg.com/images/geolocation-control/mobile/success-40x40.png)"; var coords = position.coords; var lon = coords.longitude; var lat = coords.latitude; var point = new BMap.Point(lon,lat); var myIcon = new BMap.Icon(Towery.getFullPath("MobileCRMDistrict/images/location-ico.svg"),new BMap.Size(16, 16)); mk = new BMap.Marker(point,{icon:myIcon}); var label = new BMap.Label("我在这里",{ offset:new BMap.Size(-18,-20) }); label.setStyle({ padding:"0px", border:"solid 1px orangered", background:"rgba(255,255,255,0.5)" }); mk.setTop(true); mk.setLabel(label); map.addOverlay(mk); map.panTo(point); if(position.addresses){ text.innerText=position.addresses; var w = text.offsetWidth; div.style.width=34 +(w +20)+"px" ; } }, error:function(e){ if(cb) cb({ status:-1, result:e }); plus.nativeUI.toast("无法获取您的位置,请打开GPS并授予此应用权限,必要时移至室外或移动、WIFI信号好的位置!",{duration:"long"}); geolocation.style.backgroundImage = "url(http://api0.map.bdimg.com/images/geolocation-control/mobile/fail-40x40.png)"; console.log(Towery.pretty(e)) } },{ provider: "baidu", coordsType:"bd09ll" }); } })(BMap);
相关文章推荐
- Android之获取手机上的图片和视频缩略图thumbnails
- android wifi 无线调试
- HTML5中在客户端验证文件上传的大小
- Canvas 在高清屏下绘制图片变模糊的解决方法
- 手机4大隐藏功能及使用必知常识第1/2页
- 原生js结合html5制作小飞龙的简易跳球
- Android改变手机屏幕朝向的方法
- php实现用手机关闭计算机(电脑)的方法
- 三个不常见的 HTML5 实用新特性简介
- 低版本IE正常运行HTML5+CSS3网站的3种解决方案
- js+HTML5实现canvas多种颜色渐变效果的方法
- js判断手机和pc端选择不同执行事件的方法
- JS判断客户端是手机还是PC的2个代码
- 基于OL2实现百度地图ABCD marker的效果
- javascript+HTML5的Canvas实现Lab单车动画效果
- javascript+html5实现绘制圆环的方法
- HTML5实现微信拍摄上传照片功能
- jQuery+HTML5加入购物车代码分享