日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

在ionic/cordova中使用百度地图插件

發布時間:2023/11/30 编程问答 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在ionic/cordova中使用百度地图插件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ionic項目中,如果想實現定位功能,可以使用ng-cordova提供的cordova-plugin-geolocation。

但由于高墻的緣故,國內andorid環境下,此插件不起作用(ios環境下可用)。

國內比較好的是現實使用百度地圖提供的API,來實現定位,以及地圖的一系列擴展功能。

現在我們使用'Weizhe He'提供的cordova-qdc-baidu-location來嘗試創建簡單的定位app。

?

Stpe1:創建一個項目(此處使用的是tab類型的項目,創建方式可參照我前一篇如何離線創建Ionic1項目)

Stpe2:申請百度地圖API秘鑰

  ????應用類型請選擇:Andorid應用

?????????? 包名:如圖所示的名字(config.xml內?widget節點中id的值)

??????????

Stpe3:在項目中添加cordova-qdc-baidu-location插件

安裝插件命令:ionic plugin add https://github.com/hewz/cordova-baidu-location --variable API_KEY="你的應用秘鑰"
ps:
卸載插件命令:ionic plugin rm com.hewz.plugins.baidu.location
列出所有插件:ionic plugin list????????????

???????????安裝完畢后可見下圖內容:

??????????

Stpe4:在項目中添加百度地圖API的JS引用

???????????打開Index.html

????????? 4.1?在head中添加代碼

<meta http-equiv="Content-Security-Policy" content="script-src * 'unsafe-eval'; connect-src * 'unsafe-eval';object-src 'self'; style-src * 'unsafe-inline'; img-src *" > <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=你應用的秘鑰"></script>

???????? 4.2?編寫插件使用代碼

????????? 4.2.1 打開www->templates->tab-dash.html修改代碼為:

<ion-view view-title="百度地圖測試"><ion-content><ion-list><ion-item><button class="button button-block button-calm" ng-click="getpoint()"> 開始定位 </button></ion-item><ion-item>經度:{{ret.longitude}} 緯度:{{ret.latitude}}</ion-item><ion-item><div id="allmap" style="height: 600px;"></div></ion-item></ion-list></ion-content> </ion-view>

????????? 4.2.2 打開www->js->controllers.js修改[DashCtrl]代碼為:

.controller('DashCtrl', function($scope) {var map = new BMap.Map("allmap"); // 創建Map實例var point = new BMap.Point(104.108164,30.773969); // 創建點坐標$scope.ret = {latitude:30.773969, longitude:104.108164};map.centerAndZoom(point,19); // 初始化地圖,用城市名設置地圖中心點var marker = new BMap.Marker(point); // 創建標注map.addOverlay(marker); // 將標注添加到地圖中 $scope.getpoint = function() {baidu_location.getCurrentPosition(function(data){$scope.ret = {longitude:data.longitude, latitude:data.latitude};var map = new BMap.Map("allmap"); // 創建Map實例var point = new BMap.Point(data.longitude, data.latitude); // 創建點坐標map.centerAndZoom(point,19);var marker = new BMap.Marker(point); // 創建標注map.addOverlay(marker); // 將標注添加到地圖中}, function(err){alert("錯誤:"+ err)});}; })

Stpe5:測試

需要注意的是,我們在瀏覽器測試項目的時候,會提示baidu_location沒有定義,實際需要在手機上體驗完整功能。

手機連接電腦后,使用ionic小助手,打開項目并真機調試,直接將app安裝到手機,注意打開手機USB調試模式,保持手機解鎖并點亮,ionic小助手編譯安裝完成,可能經歷一下幾步:

?

其他:

?百度地圖API示例

?

特別感謝:Weizhe He

轉載于:https://www.cnblogs.com/larryNE/p/6066166.html

總結

以上是生活随笔為你收集整理的在ionic/cordova中使用百度地图插件的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。