国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

H5 如何喚起百度地圖 App

yankeys / 3157人閱讀

摘要:最近接手了一個需求,要求混合式開發,前端做好后將頁面嵌入到和中,需要用到百度地圖的地圖導航。所以需要換一種方式,總的思路是采用輪詢的方式在內嘗試喚起百度地圖喚起失敗后,判斷是處于前臺還是后臺,如果是前臺,則打開端百度地圖。

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

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

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

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

最開始的代碼:

  // 嘗試喚起百度地圖 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 代碼還是會執行

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

采用輪詢的方式

在 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 + "®ion=" + 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("獲取不到定位,請檢查手機定位設置");
        }
      }
    });
  }

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/101407.html

相關文章

  • 一篇文章了解H5打開APP的諸多方案

    摘要:流量封裝渠道微信手和微博等流量入口為了保證流量不流失,對和原生的喚起方案做了屏蔽和封裝。不過這種方案已經被微信給封殺了。總結本文泛泛的總結了市面上常見的喚起方案,羅列了它們的優缺點。 其實H5打開APP本來應該是一件很簡單的事,無非是在H5頁面上調用一個協議或者接口將APP打開嘛。但是因為技術方案的發展和某些流量APP的封鎖,喚起APP的方案就變得復雜了起來。本文從介紹喚起APP的諸多...

    myshell 評論0 收藏0
  • Ios/Android h5 喚起本地APP

    摘要:糾結兩天瀏覽器中喚起本地,一直找不到解決方案,今天總算基本搞定。 糾結兩天(瀏覽器中喚起本地APP),一直找不到解決方案,今天總算基本搞定。 ps:吐槽一下 魔窗那篇文章,為什么就不直接把js代碼開源開源,混淆后的代碼看得我好惱火 參考文章:魔窗解決方案、京東解決方案 首先是判斷瀏覽器 // 判斷瀏覽器 var Navigator = navigator.userAgent; var ...

    shusen 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<