怎样注册微信小程序_微信小程序开发之map地图组

2021-01-07 11:55

微信小程序开发之map地图组件定位并手动修改位置偏差       这篇文章主要介绍了微信小程序开发之map地图组件,定位,并手动修改位置偏差,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

打开微信web开发者工具,扫码登录,新建小程序,输入APPID,勾选创建quick start项目。

工程结构

可以看到工程根目录中有个app.js,这里可以定义全局变量,通过getApp()获取。

项目中有了一些示例,已经有了获取用户信息的方法等。

开发地图定位,选择位置功能

我们直接修改index页面来做这个功能。

准备

新建imgs目录,加入2个图标(ic_location和ic_position),用于标记当前位置,和地图中央位置。


添加定位功能

修改app.js,加入定位功能,获取当前位置。

//app.js
App({
 onLaunch: function () {
 //调用API从本地缓存中获取数据
 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{
 //调用登录接口
 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', // 默认为 wgs84 返回 g凡科抠图 坐标,gcj02 返回可用于 wx.openLocation 的坐标
 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标签,如下

 map id="map4select"
 longitude="{{longitude}}" latitude="{{latitude}}" 
 markers="{{markers}}"
 scale="20" 
 bindregionchange="regionchange"
 controls="{{controls}}" 
 /map 

需要给地图指定一个id,后面可以通过id获取地图的上下文。

监听bindregionchange事件,地图变化的时候可以监听到。

地图的大小不要写死,动态设置,我这里打算设置为宽高都是屏幕宽度。

controls是固定在map组件上面的。一开始我想用image替代,但是设置z-index也不能在地图上面,毕竟不是H5开发。

逻辑代码编写

编辑index.js

var app = getApp()
Page({
 data:{
 map_width: 380
 ,map_height: 380
 //show current position
 ,onLoad: function(){
 var that = this;
 // 获取定位,并把位置标示出来
 app.getLocationInfo(function(locationInfo){
 console.log('map',locationInfo);
 that.setData({
 longitude: locationInfo.longitude
 ,latitude: locationInfo.latitude
 ,markers:[
 id: 0
 ,iconPath: "../../imgs/ic_position.png"
 ,longitude: locationInfo.longitude
 ,latitude: locationInfo.latitude
 ,width: 30
 ,height: 30
 //set the width and height
 // 动态设置map的宽和高
 wx.getSystemInfo({
 success: function(res) {
 console.log('getSystemInfo');
 console.log(res.windowWidth);
 that.setData({
 map_width: res.windowWidth
 ,map_height: res.windowWidth
 ,controls: [{
 id: 1,
 iconPath: '../../imgs/ic_location.png',
 position: {
 left: res.windowWidth/2 - 8,
 top: res.windowWidth/2 - 16,
 width: 30,
 height: 30
 clickable: true
 //获取中间点的经纬度,并mark出来
 ,getLngLat: function(){
 var that = this;
 this.mapCtx = wx.createMapContext("map4select");
 this.mapCtx.getCenterLocation({
 success: function(res){
 that.setData({
 longitude: res.longitude
 ,latitude: res.latitude
 ,markers:[
 id: 0
 ,iconPath: "../../imgs/ic_position.png"
 ,longitude: res.longitude
 ,latitude: res.latitude
 ,width: 30
 ,height: 30
 ,regionchange(e) {
 // 地图发生变化的时候,获取中间点,也就是用户选择的位置
 if(e.type == 'end'){
 this.getLngLat()
 ,markertap(e) {
 console.log(e)
})

展示

这样,就OK啦,用户可以看到自己的定位,如果觉得有偏差,可以移动地图,把中央点放到自己认为的准确位置上。






扫描二维码分享到微信

在线咨询
联系电话

020-66889888