uni-app 微信小程序中关于 map 地图使用案例分享

简介: uni-app 微信小程序中关于 map 地图使用案例分享

这篇文章,我将带领大家使用微信内置地图详细讲解关于如何配置地图、打开地图和使用地图。

目录

1、配置地图

2、先写页面内,这里我创建了一个 map示例页面 mapDemo.vue

2.1 关于 map 组件各个属性的说明可以详见官方文档。

2.2 在使用 uni.getSetting() 方法来获取用户的当前设置,每次进入程序判断当前是否获得授权,如果没有,就去调起弹窗请求获得授权,如果获得授权,就直接获取当前地理位置。

3、实现调用地图组件方式一

3.1 首先在 onLoad 方法内触发 isGetLocation()方法

3.2 点击右上角确定按钮时,getLocationInfo() 方法会返回具体位置信息。

4、实现调用地图组件方式二

4.1 先去获取当前所在位置的经纬度

4.2 很据纬度获取详细的地址

4.3 再把控件定在地图的中心点,然后手动拖动地图,从而实现手动选择收货地址的功能。

5、完整代码示例 mapDemo.vue 内容如下:

6、结尾

uni-app 官方文档如下:

map | uni-app官网

微信小程序官方文档如下:

wx.openLocation(Object object) | 微信开放文档

个人建议,如果是 uni-app 开发,那就直接按照 uni-app 的文档来做。如果有差异的你可以再去看看微信的文档,因为本身 uni-app 就已经帮我们做好了集成封装。

1、配置地图

打开manifest.json 勾选位置接口,并添加描叙信息:你的位置信息将用于小程序位置接口的效果展示
a4d6a41ac74b4bfebc29bca40a5bf113.png
这里点击保存,切到源码视图就会发现在 mp-weixin 下多了如下内容:

"permission" : {
            "scope.userLocation" : {
                "desc" : "你的位置信息将用于小程序位置接口的效果展示"
            }
        },

2、先写页面内,这里我创建了一个 map示例页面 mapDemo.vue

<template>
    <view class="map_wrap">
        <map id="mapSelected" style="width: 690rpx; height: 300px; margin-left: 30rpx;" :latitude="latitude" :longitude="longitude" :markers="covers" :controls="controls" :scale="18" @controltap="controltap" @tap="clickMap" 
        @regionchange="regionchange">
        </map>
        
        <view class="mform">
            <view class="item">
                <view class="t">当前地址:</view>
                <view class="m">{{address}}</view>
            </view>
            <view class="item">
                <view class="t">推荐地址:</view>
                <view class="m">{{address_info}}</view>
            </view>
        </view>
        
        <!-- 保存按钮这里具体保存事件我没写,根据实际需要调用后台保存地址即可 -->
        <view class="btnbox">
            <button class="btn" @click="saveAddress()" style="width:85%;">保存</button>
        </view>
    </view>
</template>

页面数据项 data 部分

data() {
        return {
            title: 'map',
            latitude: 39.909,// 默认纬度
            longitude: 116.39742,// 默认经度(北京天安门)
            covers: [{
                id: 110, 
                latitude: 39.909,
                longitude: 116.39742,
                iconPath: '    https://hellouniapp.dcloud.net.cn/static/location.png',
                width: "20",
                height: "20"
            }],
            controls: [{ // 控件
                id: 99,
                position: { // 控件位置
                    left: 160,
                    top: 120
                },
                iconPath: 'https://hellouniapp.dcloud.net.cn/static/location.png' // 控件图标
            }],
            address_info :"",
            address_info_recomd:"",
            address :""
        }
    },

地图组件 map | uni-app官网https://uniapp.dcloud.net.cn/component/map.html#地图组件用于展示地图,而定位API只是获取坐标,请勿混淆两者。

2.1关于 map 组件各个属性的说明可以详见官方文档。

latitude::中心纬度
longitude:中心经度
markers:数组类型Array,标记点,用于标记你目前所处的位置。
scale:缩放级别,取值范围为3-20,默认16。高德地图缩放比例与微信小程序不同
controls:控件,可让你手指拖动地图时,它在你指定的位置不动
regionchange:视野发生变化时触发,依据这个函数的回调参数和控件来实时获取你选择的地址

tap:点击地图时触发; App-nvue、微信小程序2.9支持返回经纬度

2.2在使用 uni.getSetting() 方法来获取用户的当前设置,每次进入程序判断当前是否获得授权,如果没有,就去调起弹窗请求获得授权,如果获得授权,就直接获取当前地理位置。

3、实现调用地图组件方式一

3.1首先在 onLoad 方法内触发 isGetLocation()方法

onLoad(){
  this.isGetLocation();
},

methods内调用判断是否获取授权方法和触发弹窗获得授权方法

isGetLocation(a = "scope.userLocation") { //检查当前是否已经授权访问scope属性
            var _this = this;
                uni.getSetting({
                    success(res) {
                        console.log(res)
                        if (!res.authSetting[a]) { //每次进入程序判断当前是否获得授权,如果没有就去获得授权,如果获得授权,就直接获取当前地理位置
                            _this.getAuthorizeInfo()
                        } else {
                             //方式一
                             _this.getLocationInfo();
                            // 方式二
                            //_this.getLocation();
                        }
                    }
                });
        },
        getAuthorizeInfo(a = "scope.userLocation") { // uniapp弹窗弹出获取授权(地理,个人微信信息等授权信息)弹窗
            var _this = this;
            uni.authorize({
                scope: a,
                success() { //允许授权
                    //方式一
                     _this.getLocationInfo();
                    // 方式二
                    //_this.getLocation();
                }
            })
        },

效果如下:
c0e863361e564ba4ba63f1f8c9313623.png

点击允许即可调用地图组件选择地址:
f08cca5ced234bcebcb7999f06dfbc4a.png

3.2点击右上角确定按钮时,getLocationInfo() 方法会返回具体位置信息。

getLocationInfo () {
            uni.chooseLocation({
                success: (res) => {
                    console.log(res)
                    if(res.errMsg == "chooseLocation:ok"){
                        this.address_info = res.name + res.address;
                        this.latitude= res.latitude;
                        this.longitude = res.longitude;
                    }
                }
            })
        },

67cc5f9c609b4bf189331ca7f2c6c9f2.png
86459dc4567a4fba89707e5309bddc51.png
这种方式我们在获取用户授权后是直接通过 uni.chooseLocation() 方法选择的地理位置,相对简单。

4、实现调用地图组件方式二

通过 uni.getLocation() 获取地理位置,就相对复杂一点儿。

4.1先去获取当前所在位置的经纬度

getLocation(){
            uni.getLocation({
                type: 'gcj02',
                success: (res) => {
                    console.log(res)
                    this.latitude = res.latitude.toString()
                    this.longitude = res.longitude.toString()
                                    
                    // 获取地理位置详情信息
                    this.getLocationDetail()
                }
            });
        },

91cae73771064a6985c9a297dbb7e525.png
getLocation 返回参数如上图所示。

4.2很据纬度获取详细的地址

//根据经纬度获取详细的地址
        getLocationDetail () {
            uni.request({
                header: {
                    "Content-Type": "application/text"
                },
                url: 'https://apis.map.qq.com/ws/geocoder/v1/?location=' + this.latitude + ',' + this.longitude +
                                '&key=XOXBZ-MZWWD-CDX4H-PONXN-UA5PJ-D7FJN',
                success:(re)=> {
                    //成功获取到经纬度
                    console.log(re)
                    if (re.statusCode == 200) {
                        this.address_info_recomd = re.data.result.formatted_addresses.recommend
                        this.address_info = re.data.result.address_reference.town.title + re.data.result.address_reference.street.title + re.data.result.address_reference.landmark_l2.title
                        this.address = re.data.result.address
                                    
                    } else {
                        uni.showToast({
                            title: '获取地理位置失败,请重试',
                            icon: "none"
                        })
                    }
                }
            });
        }

b85412b68a074adcb41a451dd13486f3.png
获取地理位置成功返回参数内容如上图所示。

4.3再把控件定在地图的中心点,然后手动拖动地图,从而实现手动选择收货地址的功能。

regionchange (e) {
            console.log(e)
            if (e.type == 'end' && (e.causedBy == 'scale' || e.causedBy == 'drag')) {
                this.mapCtx = uni.createMapContext("mapSelected"); // 创建map的上下文对象, 从而操控map组件
                this.mapCtx.getCenterLocation({
                    success: (res) => {
                        console.log(res)
                        this.latitude = res.latitude;
                        this.longitude = res.longitude;
                        this.getLocationDetail();
                    }
                })
            }
        },

26b79e3b88f94025baf6620cc0bc6d01.png
当你手动拖动地图时,效果图如上。

mapSelected:map组件的id,结合以上方法去实时获取你选择位置的经纬度,根据经纬度即可实现实时选择收货地址的功能。

5、完整代码示例 mapDemo.vue 内容如下:

<template>
    <view class="map_wrap">
        <map id="mapSelected" style="width: 690rpx; height: 300px; margin-left: 30rpx;" :latitude="latitude" :longitude="longitude" :markers="covers" :controls="controls" :scale="18" @controltap="controltap" @tap="clickMap" 
        @regionchange="regionchange">
        </map>
        
        <view class="mform">
            <view class="item">
                <view class="t">当前地址:</view>
                <view class="m">{{address}}</view>
            </view>
            <view class="item">
                <view class="t">推荐地址:</view>
                <view class="m">{{address_info}}</view>
            </view>
        </view>
        
        <!-- 保存按钮 -->
        <view class="btnbox">
            <button class="btn" @click="saveAddress()" style="width:85%;">保存</button>
        </view>
    </view>
</template>
 
<script>
export default {
    data() {
        return {
            title: 'map',
            latitude: 39.909,// 默认纬度
            longitude: 116.39742,// 默认经度(北京天安门)
            covers: [{
                id: 110, 
                latitude: 39.909,
                longitude: 116.39742,
                iconPath: '    https://hellouniapp.dcloud.net.cn/static/location.png',
                width: "20",
                height: "20"
            }],
            controls: [{ // 控件
                id: 99,
                position: { // 控件位置
                    left: 160,
                    top: 120
                },
                iconPath: 'https://hellouniapp.dcloud.net.cn/static/location.png' // 控件图标
            }],
            address_info :"",
            address_info_recomd:"",
            address :""
        }
    },
    onLoad(){
        this.isGetLocation();
    },
    methods: {
        isGetLocation(a = "scope.userLocation") { //检查当前是否已经授权访问scope属性
            var _this = this;
                uni.getSetting({
                    success(res) {
                        console.log(res)
                        if (!res.authSetting[a]) { //每次进入程序判断当前是否获得授权,如果没有就去获得授权,如果获得授权,就直接获取当前地理位置
                            _this.getAuthorizeInfo()
                        } else {
                            //方式一
                            _this.getLocationInfo();
                            // 方式二
                            // _this.getLocation();
                        }
                    }
                });
        },
        getAuthorizeInfo(a = "scope.userLocation") { // uniapp弹窗弹出获取授权(地理,个人微信信息等授权信息)弹窗
            var _this = this;
            uni.authorize({
                scope: a,
                success() { //允许授权
                    //方式一
                    // _this.getLocationInfo();
                    // 方式二
                    _this.getLocation();
                }
            })
        },
        //点击地图时
        clickMap(e){
            console.log("点击地图时:"+e);
            this.latitude=e.detail.latitude;
            this.longitude = e.detail.longitude;
        },
        getLocationInfo () {
            //直接调用即可
            uni.chooseLocation({
                success: (res) => {
                    console.log(res)
                    if(res.errMsg == "chooseLocation:ok"){
                        this.address_info = res.name + res.address;
                        this.latitude= res.latitude;
                        this.longitude = res.longitude;
                    }
                }
            })
        },
        //获取当前所在位置的经纬度
        getLocation(){
            uni.getLocation({
                type: 'gcj02',
                success: (res) => {
                    console.log(res)
                    this.latitude = res.latitude.toString()
                    this.longitude = res.longitude.toString()
                                    
                    // 获取地理位置详情信息
                    this.getLocationDetail()
                }
            });
        },
        //根据经纬度获取详细的地址
        getLocationDetail () {
            uni.request({
                header: {
                    "Content-Type": "application/text"
                },
                url: 'https://apis.map.qq.com/ws/geocoder/v1/?location=' + this.latitude + ',' + this.longitude +
                                '&key=XOXBZ-MZWWD-CDX4H-PONXN-UA5PJ-D7FJN',
                success:(re)=> {
                    //成功获取到经纬度
                    console.log(re)
                    if (re.statusCode == 200) {
                        this.address_info_recomd = re.data.result.formatted_addresses.recommend
                        this.address_info = re.data.result.address_reference.town.title + re.data.result.address_reference.street.title + re.data.result.address_reference.landmark_l2.title
                        this.address = re.data.result.address
                                    
                    } else {
                        uni.showToast({
                            title: '获取地理位置失败,请重试',
                            icon: "none"
                        })
                    }
                }
            });
        },
        // 在地图渲染更新完成时触发
        regionchange (e) {
            console.log(e)
            if (e.type == 'end' && (e.causedBy == 'scale' || e.causedBy == 'drag')) {
                this.mapCtx = uni.createMapContext("mapSelected"); // 创建map的上下文对象, 从而操控map组件
                this.mapCtx.getCenterLocation({
                    success: (res) => {
                        console.log(res)
                        this.latitude = res.latitude;
                        this.longitude = res.longitude;
                        this.getLocationDetail();
                    }
                })
            }
        },
    }
}
</script>
<style>
 
</style>

6、结尾

以上就是两种调用地图组件,确定地理位置的方式,如您在使用过程中有所疑惑,可以私信我,咱们共同交流解决问题。这里页面样式我并没有太注意,毕竟我这个只是案例代码分享。

如果感觉小编的分享对您有所帮助的话,还请点赞、收藏 + 关注哦^_^

相关文章
|
20天前
|
运维 小程序 前端开发
结合圈层营销策略,打造稳定可靠的圈子app系统,圈子小程序!
圈子系统是一种社交平台,用户可按兴趣、职业等创建或加入“圈子”,进行内容发布、讨论和资源共享。开发时需考虑需求分析、技术选型(如PHP、MySQL)、页面设计、功能实现(注册、登录、发布、评论等)、测试优化及运维管理。圈层营销则通过精准化、高端化的方式传递品牌信息,增强客户归属感。圈子小程序基于微信等平台,具备跨平台、便捷性和社交性,开发过程中需明确需求、选择技术框架、设计页面并确保稳定性和流畅性。
113 9
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
855 1
|
7天前
|
小程序 数据挖掘
圈子系统兴趣讨论群组的创建,社群运营的重要性及策略制定,同城交友app、小程序方式的创新
### 圈子系统与社群运营简介 圈子系统是社交平台中的功能模块,允许用户创建和管理兴趣小组,设置名称、规则等,吸引志同道合者加入。通过浏览不同圈子,用户可以选择感兴趣的群体参与。社群运营则通过对具有共同需求或兴趣的用户进行组织和管理,提升品牌影响力和商业价值。有效的社群运营策略包括明确定位、制定策略、持续输出有价值内容、定期举办活动、合理分配角色及数据监测优化,从而增强用户粘性和活跃度。 **圈子系统源码获取:** [链接](https://gitee.com/multi-customer-software/qz)
51 9
|
14天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
123 18
|
4天前
|
消息中间件 监控 小程序
电竞陪玩系统架构优化设计,陪玩app如何提升系统稳定性,陪玩小程序平台的测试与监控
电竞陪玩系统架构涵盖前端(React/Vue)、后端(Spring Boot/php)、数据库(MySQL/MongoDB)、实时通信(WebSocket)及其他组件(Redis、RabbitMQ、Nginx)。通过模块化设计、微服务架构和云计算技术优化,提升系统性能与可靠性。同时,加强全面测试、实时监控及故障管理,确保系统稳定运行。
|
21天前
|
移动开发 小程序 前端开发
使用php开发圈子系统特点,如何获取圈子系统源码,社交圈子运营以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP 小程序 H5
开发一个圈子系统(也称为社交网络或社群系统)可以是一个复杂但非常有趣的项目。以下是一些关键特点和步骤,帮助你理解如何开发、获取源码以及运营一个圈子系统。
103 3
|
28天前
|
人工智能 小程序 数据处理
uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。
为什么不加盟线下陪玩APP小程序平台,而是自建平台?
自建线下陪玩APP平台相比加盟,能避免利润抽成,确保所有收益归己,同时提供更高的运营灵活性和稳定性,不受制于合同限制或总平台决策变动,更适合追求长期发展的创业者。
|
2月前
|
人工智能 小程序 搜索推荐
uni app下开发AI运动小程序解决方案
本文介绍了在小程序中实现AI运动识别的解决方案。该方案依托于UNI平台,通过高效便捷的插件形式,实现包括相机抽帧控制、人体识别、姿态识别等在内的多项功能,无需依赖后台服务器,大幅提高识别效率和用户体验。方案内置多种运动模式,支持自定义扩展,适用于AI健身、云上赛事、AI体测等多场景,适合新开发和存量改造项目。
|
2月前
|
移动开发 小程序
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
82 3