麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > 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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产三级午夜理伦三级 | 欧美1区2区在线观看 | 一区二区三区精品国产 | 色女人在线 | 中文字幕在线观看视频www | 国产一级一国产一级毛片 | 久久国产精品无码网站 | 视频一区二区三区在线播放 | 18欧美性xxxx极品hd | 国产超碰人人做人人爱ⅴa 国产精品久久久久久久hd | 欧美大胆xxxx肉体摄影 | 国产青草视频在线观看视频 | 91精选视频在线观看 | 亚洲精品a级 | 久久亚洲激情 | 黄色片网站免费观看 | 热久久91| 久久久99精品视频 | 毛片大全免费看 | 久久午夜国产 | 国产精品久久久久久久久久久久久久久 | 精品无吗乱吗av国产爱色 | 亚洲国产成人一区 | 国产99免费 | 天天草天天爱 | 黄网免费看 | 一区二区三区欧美在线观看 | 成人在线视频在线观看 | 日韩黄色免费观看 | 黄色片免费看看 | 黄色影院在线观看视频 | 免费在线观看国产精品 | videos高潮| 一级裸体视频 | 在线观看免费污视频 | 一区二区三区黄色 | 国产一级毛片国语版 | 精品久久久久久久久久中文字幕 | 国产99久久精品 | 成人 日韩 | 精品一区二区三区日本 |