国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 熱點(diǎn) > 微信 > 正文

微信小程序開(kāi)發(fā)之map地圖組件定位并手動(dòng)修改位置偏差

2024-07-22 01:17:43
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

環(huán)境搭建

注冊(cè),獲取APPID(沒(méi)有這個(gè)不能真雞調(diào)試)

下載微信web開(kāi)發(fā)者工具(挺多bug,將就用)

打開(kāi)微信web開(kāi)發(fā)者工具,掃碼登錄,新建小程序,輸入APPID,勾選創(chuàng)建quick start項(xiàng)目。

工程結(jié)構(gòu)

可以看到工程根目錄中有個(gè)app.js,這里可以定義全局變量,通過(guò)getApp()獲取。

項(xiàng)目中有了一些示例,已經(jīng)有了獲取用戶信息的方法等。

開(kāi)發(fā)地圖定位,選擇位置功能

我們直接修改index頁(yè)面來(lái)做這個(gè)功能。

準(zhǔn)備

新建imgs目錄,加入2個(gè)圖標(biāo)(ic_location和ic_position),用于標(biāo)記當(dāng)前位置,和地圖中央位置。

ic_location ic_position

添加定位功能

修改app.js,加入定位功能,獲取當(dāng)前位置。

//app.jsApp({ onLaunch: function () {  //調(diào)用API從本地緩存中獲取數(shù)據(jù)  var logs = wx.getStorageSync('logs') || []  logs.unshift(Date.now())  wx.setStorageSync('logs', logs) } ,getUserInfo:function(cb){  var that = this  if(this.globalData.userInfo){   typeof cb == "function" && cb(this.globalData.userInfo)  }else{   //調(diào)用登錄接口   wx.login({    success: function () {     wx.getUserInfo({      success: function (res) {       that.globalData.userInfo = res.userInfo       typeof cb == "function" && cb(that.globalData.userInfo)      }     })    }   })  } } //get locationInfo ,getLocationInfo: function(cb){  var that = this;  if(this.globalData.locationInfo){    cb(this.globalData.locationInfo)  }else{    wx.getLocation({     type: 'gcj02', // 默認(rèn)為 wgs84 返回 gps 坐標(biāo),gcj02 返回可用于 wx.openLocation 的坐標(biāo)     success: function(res){      that.globalData.locationInfo = res;      cb(that.globalData.locationInfo)     },     fail: function() {      // fail     },     complete: function() {      // complete     }    })  } } ,globalData:{  userInfo:null  ,locationInfo: null }})

地圖控件布局

修改pages/index/index.wxml文件,添加map標(biāo)簽,如下

<map id="map4select" longitude="{{longitude}}" latitude="{{latitude}}"  markers="{{markers}}" scale="20"  style="width:{{map_width}}px;height:{{map_height}}px" bindregionchange="regionchange" controls="{{controls}}"></map>

需要給地圖指定一個(gè)id,后面可以通過(guò)id獲取地圖的上下文。

監(jiān)聽(tīng)bindregionchange事件,地圖變化的時(shí)候可以監(jiān)聽(tīng)到。

地圖的大小不要寫(xiě)死,動(dòng)態(tài)設(shè)置,我這里打算設(shè)置為寬高都是屏幕寬度。

controls是固定在map組件上面的。一開(kāi)始我想用image替代,但是設(shè)置z-index也不能在地圖上面,畢竟不是H5開(kāi)發(fā)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 辽源市| 耿马| 福州市| 宜阳县| 镇雄县| 拜泉县| 德化县| 乌拉特后旗| 博罗县| 宣化县| 平邑县| 白河县| 清水河县| 大理市| 天祝| 武城县| 岗巴县| 嘉祥县| 昌黎县| 重庆市| 明星| 平谷区| 三原县| 沧州市| 福清市| 安庆市| 枝江市| 含山县| 行唐县| 安阳县| 平凉市| 绥宁县| 阿拉尔市| 余庆县| 时尚| 无极县| 昌都县| 昭通市| 甘洛县| 大冶市| 大连市|