摘要:最近接手了一個需求,要求混合式開發,前端做好后將頁面嵌入到和中,需要用到百度地圖的地圖導航。所以需要換一種方式,總的思路是采用輪詢的方式在內嘗試喚起百度地圖喚起失敗后,判斷是處于前臺還是后臺,如果是前臺,則打開端百度地圖。
最近接手了一個需求,要求混合式開發,前端做好 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://m.specialneedsforspecialkids.com/yun/101407.html
摘要:流量封裝渠道微信手和微博等流量入口為了保證流量不流失,對和原生的喚起方案做了屏蔽和封裝。不過這種方案已經被微信給封殺了。總結本文泛泛的總結了市面上常見的喚起方案,羅列了它們的優缺點。 其實H5打開APP本來應該是一件很簡單的事,無非是在H5頁面上調用一個協議或者接口將APP打開嘛。但是因為技術方案的發展和某些流量APP的封鎖,喚起APP的方案就變得復雜了起來。本文從介紹喚起APP的諸多...
摘要:糾結兩天瀏覽器中喚起本地,一直找不到解決方案,今天總算基本搞定。 糾結兩天(瀏覽器中喚起本地APP),一直找不到解決方案,今天總算基本搞定。 ps:吐槽一下 魔窗那篇文章,為什么就不直接把js代碼開源開源,混淆后的代碼看得我好惱火 參考文章:魔窗解決方案、京東解決方案 首先是判斷瀏覽器 // 判斷瀏覽器 var Navigator = navigator.userAgent; var ...
閱讀 2799·2021-09-23 11:44
閱讀 1687·2021-09-13 10:24
閱讀 2638·2021-09-08 09:36
閱讀 1241·2019-08-30 15:54
閱讀 2264·2019-08-30 13:54
閱讀 3323·2019-08-30 10:57
閱讀 1860·2019-08-29 18:43
閱讀 3627·2019-08-29 15:10