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

首頁 > 開發 > HTML5 > 正文

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

2024-09-05 07:19:37
字體:
來源:轉載
供稿:網友

最近接手了一個需求,要求混合式開發,前端做好 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. + 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. + 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. + queryStr + '&output=html';            }          }, 20);          window.onblur = function () {            clearInterval(t);          };        } else {          alert('獲取不到定位,請檢查手機定位設置');        }      }    });  }

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通海县| 柳河县| 抚松县| 清丰县| 壤塘县| 宁晋县| 曲阳县| 四会市| 凤凰县| 常熟市| 喜德县| 永川市| 北川| 普定县| 儋州市| 新绛县| 阿巴嘎旗| 泊头市| 理塘县| 德惠市| 西青区| 清流县| 任丘市| 楚雄市| 邻水| 嘉荫县| 清苑县| 惠东县| 贵州省| 遂平县| 米易县| 梅河口市| 湖州市| 武川县| 黑龙江省| 和静县| 岳西县| 晋城| 丰台区| 普格县| 定襄县|