使用的百度地圖。必須先使用百度地圖獲取目標位置和使用百度地圖獲取目標位置,然后在通過百度地圖的獲取我和目標的位置。由于異步的原因,所以我使用了定時器解決,不過性能肯定不好,如何使用async await或者promise代替定時器呢?
代碼片段如下:
// 獲取目標位置
var myGeo = new BMap.Geocoder();
// 根據(jù)中地址名 查經(jīng)緯度
myGeo.getPoint(scope.targetname, function(point){
if (point) {
scope.target = point;
}else{
toast("您選擇地址沒有解析到結(jié)果!");
}
}, scope.cityname);
// 獲取我的位置
var geolocation = new BMap.Geolocation();
geolocation.getCurrentPosition(function(r){
if(this.getStatus() == BMAP_STATUS_SUCCESS){
// alert('您的位置:'+r.point.lng+','+r.point.lat);
scope.myadd = new BMap.Point(r.point.lng,r.point.lat);
// console.log(scope.myadd,"我的位置")
}
else {
alert("定位失敗");
}
},{enableHighAccuracy: true})
// 獲取我和目標的位置
setTimeout(function(){
if(scope.myadd!=""&&scope.target!=""){
var map = new BMap.Map("l-map");
map.centerAndZoom(new BMap.Point(scope.target.lng,scope.target.lat), 11);
var walking = new BMap.WalkingRoute(map, {renderOptions: {map: map, panel: "r-result", autoViewport: true}});
walking.search(scope.myadd, scope.target);
}
}, 1000);
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;font-family:"微軟雅黑";}
</style>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=百度地圖秘鑰"></script>
<title>地址解析</title>
</head>
<body>
<div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
// 將地址解析結(jié)果顯示在地圖上,并調(diào)整地圖視野
//
var myGeo = new BMap.Geocoder();
let promiseTarget = new Promise((resolve)=>{
myGeo.getPoint("霍營", function(point){
if (point) {
resolve(point)
}else{
alert("您選擇地址沒有解析到結(jié)果!");
}
}, "北京市");
})
var geolocation = new BMap.Geolocation();
let promiseLocation = new Promise((resolve)=>{
geolocation.getCurrentPosition(function(r){
if(this.getStatus() == BMAP_STATUS_SUCCESS){
resolve(r.point)
}
else {
alert('failed'+this.getStatus());
}
},{enableHighAccuracy: true})
})
Promise.all([promiseTarget,promiseLocation]).then(([target,location])=>{
console.log(target,location,5)
// 百度地圖API功能
var map = new BMap.Map("allmap");
map.centerAndZoom("北京",12); //初始化地圖,設(shè)置城市和地圖級別。
alert('從大渡口區(qū)到江北區(qū)的距離是:'+(map.getDistance(target,location)).toFixed(2)+' 米。'); //獲取兩點距離,保留小數(shù)點后兩位
var polyline = new BMap.Polyline([target,location], {strokeColor:"blue", strokeWeight:6, strokeOpacity:0.5}); //定義折線
map.addOverlay(polyline); //添加折線到地圖上
})
</script>
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務機構(gòu),發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。