環(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)前位置,和地圖中央位置。

添加定位功能
修改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ā)。
新聞熱點(diǎn)
疑難解答
圖片精選