摘要:最近接手了一個需求,要求混合式開發(fā),前端做好后將頁面嵌入到和中,需要用到百度地圖的地圖導(dǎo)航。所以需要換一種方式,總的思路是采用輪詢的方式在內(nèi)嘗試喚起百度地圖喚起失敗后,判斷是處于前臺還是后臺,如果是前臺,則打開端百度地圖。
最近接手了一個需求,要求混合式開發(fā),前端做好 h5 后將頁面嵌入到 ios 和 android 中,需要用到百度地圖的地圖導(dǎo)航。具體功能點(diǎn)如下:
如果手機(jī)端(ios, android)安裝了百度地圖,點(diǎn)擊導(dǎo)航按鈕,喚起百度地圖 app
否則,打開 web 端百度地圖導(dǎo)航
需要用到的百度地圖的 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(); // 當(dāng)成功喚起百度地圖 app 后,再返回到 h5 頁面,這時 endTime - startTime 一定大于 timeout + 200; 如果喚起失敗, 打開 web 端百度地圖導(dǎo)航 if (!startTime || (endTime - startTime) < (timeout + 200)) { window.location. + queryStr + "&output=html"; } }, timeout);
問題:
上面這段代碼在 android 機(jī)器上運(yùn)行是沒有問題的,可是在 ios 上卻始終執(zhí)行了 setTimeout 這個計時器,所以如果在 ios 端,即使 app 處于后臺,它的 h5 代碼還是會執(zhí)行。
所以需要換一種方式,總的思路是:
采用輪詢的方式
在 600 ms 內(nèi)嘗試喚起百度地圖 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; //獲取到的經(jīng)度 if (latCurrent && lngCurrent) { var scheme = ""; // urlObject 是我這邊地址欄查詢參數(shù)對象 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; } // 主要實(shí)現(xiàn)代碼 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("獲取不到定位,請檢查手機(jī)定位設(shè)置"); } } }); }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/101407.html
摘要:流量封裝渠道微信手和微博等流量入口為了保證流量不流失,對和原生的喚起方案做了屏蔽和封裝。不過這種方案已經(jīng)被微信給封殺了??偨Y(jié)本文泛泛的總結(jié)了市面上常見的喚起方案,羅列了它們的優(yōu)缺點(diǎn)。 其實(shí)H5打開APP本來應(yīng)該是一件很簡單的事,無非是在H5頁面上調(diào)用一個協(xié)議或者接口將APP打開嘛。但是因?yàn)榧夹g(shù)方案的發(fā)展和某些流量APP的封鎖,喚起APP的方案就變得復(fù)雜了起來。本文從介紹喚起APP的諸多...
摘要:糾結(jié)兩天瀏覽器中喚起本地,一直找不到解決方案,今天總算基本搞定。 糾結(jié)兩天(瀏覽器中喚起本地APP),一直找不到解決方案,今天總算基本搞定。 ps:吐槽一下 魔窗那篇文章,為什么就不直接把js代碼開源開源,混淆后的代碼看得我好惱火 參考文章:魔窗解決方案、京東解決方案 首先是判斷瀏覽器 // 判斷瀏覽器 var Navigator = navigator.userAgent; var ...
閱讀 2818·2021-09-23 11:44
閱讀 1705·2021-09-13 10:24
閱讀 2666·2021-09-08 09:36
閱讀 1260·2019-08-30 15:54
閱讀 2285·2019-08-30 13:54
閱讀 3344·2019-08-30 10:57
閱讀 1883·2019-08-29 18:43
閱讀 3652·2019-08-29 15:10