国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

Html5如何喚起百度地圖App的方法

2024-08-26 00:21:19
字體:
來源:轉載
供稿:網友

最近接手了一個需求,要求混合式開發,前端做好 h5 后將頁面嵌入到 ios 和 android 中,需要用到百度地圖的地圖導航。具體功能點如下:

如果手機端(ios, android)安裝了百度地圖,點擊導航按鈕,喚起百度地圖 app

否則,打開 web 端百度地圖導航

需要用到的百度地圖的 api 文檔鏈接如下:http://lbsyun.baidu.com/index.php?title=uri/api/ios

最開始的代碼:

  // 嘗試喚起百度地圖 app  window.location.href = scheme;  var timeout = 600;  var startTime = Date.now();  var t = setTimeout(function () {    var endTime = Date.now();    // 當成功喚起百度地圖 app 后,再返回到 h5 頁面,這時 endTime - startTime 一定大于 timeout + 200; 如果喚起失敗, 打開 web 端百度地圖導航    if (!startTime || (endTime - startTime) < (timeout + 200)) {       window.location.href = 'http://api.map.baidu.com/direction' + queryStr + '&output=html';    }  }, timeout);

問題:

上面這段代碼在 android 機器上運行是沒有問題的,可是在 ios 上卻始終執行了 setTimeout 這個計時器,所以如果在 ios 端,即使 app 處于后臺,它的 h5 代碼還是會執行。

所以需要換一種方式,總的思路是:

  1. 采用輪詢的方式
  2. 在 600 ms 內嘗試喚起百度地圖 app, 喚起失敗后, 判斷 h5 是處于前臺還是后臺,如果是前臺,則打開 web 端百度地圖 app。不管喚起成功還是失敗,過 200 ms 后都清除定時器。

修改后的代碼:

  var startTime = Date.now();  var count = 0;  var endTime = 0;  var t = setInterval(function () {    count += 1;    endTime = Date.now() - startTime;    if (endTime > 800) {      clearInterval(t);    }    if (count < 30) return;    if (!(document.hidden || document.webkitHidden)) {      window.location.href = 'http://api.map.baidu.com/direction' + queryStr + '&output=html';    }  }, 20);

完整的代碼:

  function wakeBaidu() {    var geolocation = new BMap.Geolocation();    geolocation.getCurrentPosition(function (result) {      if (this.getStatus() == BMAP_STATUS_SUCCESS) {        var latCurrent = result.point.lat; //獲取到的緯度        var lngCurrent = result.point.lng; //獲取到的經度        if (latCurrent && lngCurrent) {          var scheme = '';                    // urlObject 是我這邊地址欄查詢參數對象          var queryStr = '?origin=name:我的位置|latlng:' + latCurrent + ',' + lngCurrent + '&destination=' + urlObject.lat + ',' + urlObject.lng + '&region=' + urlObject.city + '&coord_type=bd09ll&mode=driving';          if (isIOS()) {            // ios 端            scheme = 'baidumap://map/direction' + queryStr;          } else {            // android 端            scheme = 'bdapp://map/direction' + queryStr;          }          // 主要實現代碼          window.location.href = scheme;                    var startTime = Date.now();          var count = 0;          var endTime = 0;                    var t = setInterval(function () {            count += 1;            endTime = Date.now() - startTime;            if (endTime > 800) {              clearInterval(t);            }            if (count < 30) return;            if (!(document.hidden || document.webkitHidden)) {              window.location.href = 'http://api.map.baidu.com/direction' + queryStr + '&output=html';            }          }, 20);          window.onblur = function () {            clearInterval(t);          };        } else {          alert('獲取不到定位,請檢查手機定位設置');        }      }    });  }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 始兴县| 平湖市| 湘潭市| 榆树市| 滦南县| 子长县| 彰化县| 长宁县| 二手房| 宁陕县| 防城港市| 惠安县| 循化| 青神县| 资源县| 麻阳| 峨边| 甘泉县| 始兴县| 绥芬河市| 明溪县| 当雄县| 眉山市| 珠海市| 监利县| 汤阴县| 慈溪市| 兴宁市| 山西省| 荣成市| 陕西省| 芷江| 林芝县| 安吉县| 体育| 鸡泽县| 宜州市| 甘德县| 光泽县| 丹凤县| 丹凤县|