• 技术文章 >web前端 >uni-app

    利用uniapp开发一个简单的地图导航

    青灯夜游青灯夜游2022-06-09 19:46:41转载426
    怎么利用uniapp开发一个简单的地图导航?本篇文章就来为大家提供一个制作简单地图的思路,希望对大家有所帮助!

    先来看一眼效果图

    1.png

    2.png

    简易map

    在图一的地图中可以看到 a点 连接 到 b点, 基本信息 以及 基本的控件(放大、缩小、回到某个指定的点),接下来我们分开逐步讲解。

    所需配置

    需要先在manifest.json中的 app模块中配置地图,并添加相关地图的key,如果没有可在相关开发者平台进行申请

    3.png

    配置好这一部分就可以开始使用map组件了

    地图标记点

    在uniapp map中想创建标记点就需要使用到一个属性 markers

    我们先来看一下markers的常用属性

    名称说明类型必填
    id标记点idnumbertrue
    latitude纬度numbertrue
    longitude经度numbertrue
    iconPath显示的图标stringfalse
    callout自定义标记点上方的气泡框Objectfalse
    label为标记点傍边增加标签Objectfalse

    查看更多请查看:

    https://uniapp.dcloud.io/component/map.html

    了解过这些我们就可以使用markers属性创建标记点了, markers属性是数组类型的,所以应该这样创建标记点

        this.covers = [ 
            {
                id: 1,
                latitude: 34.7486,
                longitude: 113.6709,
                iconPath: '../../static/shop.png',
                title: "目的地"
            }
        ];

    如果想添加更多的标记点就可以继续在数组中添加object

    每个object都代表了一个标记点

    挂载

        <map :markers="covers"></map>

    坐标连线

    想让我们的坐标连线就需要使用到 polyline 属性。

    我们先来看一下polyline的常用属性

    名称说明类型必填
    points经纬度数组Arraytrue
    color线的颜色stringfalse
    width线宽Numberfalse
    iconPath显示的图标stringfalse
    arrowLine带箭头的线Booleanfalse
    colorList彩虹显Arrayfalse

    平台差异请查看

    https://uniapp.dcloud.io/component/map.html#app平台地图服务商差异

    这里我们要注意 两个坑,作者亲踩

    所以 polyline 的正确写法应该是这样的

        // 连线
        this.polyline = [
            // 第一条线
            {
                // 每个点的经纬度
                points: [{34.7486, 113.6709}, {28.7486, 113.6709}],
                // 颜色
                color: "#000",
                // 宽度
                width: 10
            }
        ]

    如果想添加第二条线仅仅只需要在 polyline 中在添加一个 Object挂载

        <map :polyline="polyline"></map>

    放大缩小

    map 的放大缩依赖于 scale 属性 所以只需要动态改变 scale 属性的值就可以了。 但这里要注意 scale 的取值范围为 3~20,数字类型

    这就是放大缩小功能的依赖

    4.png

    回到指定位置

    想要地图回到指定的位置也非常简单,只需要使用 uni.createMapContext() 方法创建一个 mapContent 对象 在使用 附带的 moveToLocatio 方法便可让地图回到指定的位置。

    // 回到定位点
    goBackToLocation() {
       uni.createMapContext("map").moveToLocation({34.7486, 113.6709});
    },

    5.png

    导航弹框

    图二中的地图应用选择弹框则是使用了 h5Plus

    nativeUI.actionSheet 方法 创建了弹框

    runtime.openURL 方法 打开了 导航软件 或 h5 页面导航

    nativeUI情请查看

    https://www.html5plus.org/doc/zh_cn/nativeui.html

    runtime情请查看

    https://www.html5plus.org/doc/zh_cn/runtime.html

        // 导航 会打开导航菜单供用户选择
        openNavigation(longitude, latitude, name) {
            let url = ""; // app url
            let webUrl = ""; // web url 用来为用户未安装导航软件时打开浏览器所使用url
            plus.nativeUI.actionSheet({ //选择菜单
                title: "选择地图应用",
                cancel: "取消",
                buttons: [{title: "高德地图"}] // 可选的地图类型
            }, (e)=> {
                    // 判断用户选择的地图
                switch (e.index) {
                    //下面是拼接url,不同系统以及不同地图都有不同的拼接字段
                    case 1:
                        // 安卓
                        if(plus.os.name == "Android") {
                            url = `androidamap://viewMap?sourceApplication=appname&poiname=${name}&lat=${latitude}&lon=${longitude}&dev=0`;
                        }else {
                            url = `iosamap://viewMap?sourceApplication=applicationName&poiname=${name}&lat=${latitude}&lon=${longitude}&dev=0`;
                        }
                        webUrl = `https://uri.amap.com/marker?position=${longitude},${latitude}&name=${name}&src=mypage&coordinate=gaode`
                        break;
                }
                    // 如果选中
                if (url != "") {
                    url = encodeURI(url);
                    // 打开 app 导航 
                    plus.runtime.openURL(url, (err)=>{ // 失败回到
                        // 如果失败则说明未安装 直接 打开网页版进行导航
                        // 毕竟用户可能没有安装app但一定安装的有浏览器
                        plus.runtime.openURL(webUrl);
                    });
                }
        })
    }

    这就是我导航弹窗实现的逻辑了, 这里我仅仅只是用了高德地图的选项,大家可以根据需要增加相应地图app,其他常见的我放在下方了。

    腾讯

    app url

    let appUrl = `qqmap://map/geocoder?coord=${latitude},${longitude}&referer=${腾讯地图key}`

    web url

    let webUrl = `https://apis.map.qq.com/uri/v1/marker?marker=coord:经度,纬度;title:名称;addr:地址&referer=myapp`

    百度

    app url

    let appUrl = `baidumap://map/marker?location=${latitude},${longitude}&title=${name}&coord_type=gcj02&src=andr.baidu.openAPIdemo`

    web url

    let webUrl = `http://api.map.baidu.com/marker?location=${latitude},${longitude}&title=${name}&content=${content}&output=html&src=webapp.baidu.openAPIdemo`

    推荐:《uniapp教程

    以上就是利用uniapp开发一个简单的地图导航的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:掘金社区,如有侵犯,请联系admin@php.cn删除
    专题推荐:uni-app
    上一篇:聊聊如何利用uniapp开发一个贪吃蛇小游戏! 下一篇:uni-app入门:项目创建及原生tabbar配置
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 看看使用uni-app如何编写一个五子棋小游戏(附游戏代码)• 如何快速搭建uni-app项目?两种搭建方法分享• 聊聊怎么将小程序项目转为uni-app项目• 总结分享uni-app的简单介绍• uni-app跨平台应用开发之实现资源在线升级
    1/1

    PHP中文网