PHP前端开发

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

百变鹏仔 2个月前 (11-20) #uniapp
文章标签 简单

怎么利用uniapp开发一个简单的地图导航?本篇文章就来为大家提供一个制作简单地图的思路,希望对大家有所帮助!

先来看一眼效果图

简易map

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

所需配置

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

配置好这一部分就可以开始使用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></map>

坐标连线

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

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

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

平台差异请查看

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

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

  • polyline 属性是一个数组

    polyline 之所以是一个数组是因为他可以同时创建多条线并且连线,每条线还可以有着不同的颜色、箭头、图标等。

  • points 也是一个数组

    points之所以是一个数组是因为他要确定某一条线上的每一个点,且每个点都应该由经纬度构成

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

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

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

    <map></map>

放大缩小

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

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

回到指定位置

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

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

导航弹框

图二中的地图应用选择弹框则是使用了 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)=&gt; {                // 判断用户选择的地图            switch (e.index) {                //下面是拼接url,不同系统以及不同地图都有不同的拼接字段                case 1:                    // 安卓                    if(plus.os.name == "Android") {                        url = `androidamap://viewMap?sourceApplication=appname&amp;poiname=${name}&amp;lat=${latitude}&amp;lon=${longitude}&amp;dev=0`;                    }else {                        url = `iosamap://viewMap?sourceApplication=applicationName&amp;poiname=${name}&amp;lat=${latitude}&amp;lon=${longitude}&amp;dev=0`;                    }                    webUrl = `https://uri.amap.com/marker?position=${longitude},${latitude}&amp;name=${name}&amp;src=mypage&amp;coordinate=gaode`                    break;            }                // 如果选中            if (url != "") {                url = encodeURI(url);                // 打开 app 导航                 plus.runtime.openURL(url, (err)=&gt;{ // 失败回到                    // 如果失败则说明未安装 直接 打开网页版进行导航                    // 毕竟用户可能没有安装app但一定安装的有浏览器                    plus.runtime.openURL(webUrl);                });            }    })}

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

腾讯

app url

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

web url

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

百度

app url

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

web url

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

推荐:《uniapp教程》