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

怎么利用uniapp开发一个简单的地图导航?本篇文章就来为大家提供一个制作简单地图的思路,希望对大家有所帮助! 先来看一眼效果图 简易map 在图一的地图中可以看到 a点 连接 到...

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

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

先来看一眼效果图

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

简易map

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

所需配置

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

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

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

地图标记点

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

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

名称说明类型必填id标记点idnumbertruelatitude纬度numbertruelongitude经度numbertrueiconPath显示的图标stringfalsecallout自定义标记点上方的气泡框Objectfalselabel为标记点傍边增加标签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经纬度数组Arraytruecolor线的颜色stringfalsewidth线宽NumberfalseiconPath显示的图标stringfalsearrowLine带箭头的线BooleanfalsecolorList彩虹显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:polyline="polyline"></map>

放大缩小

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

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

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

回到指定位置

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

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

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

导航弹框

图二中的地图应用选择弹框则是使用了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){leturl="";//appurlletwebUrl="";//weburl用来为用户未安装导航软件时打开浏览器所使用urlplus.nativeUI.actionSheet({//选择菜单title:"选择地图应用",cancel:"取消",buttons:[{title:"高德地图"}]//可选的地图类型},(e)=>{//判断用户选择的地图switch(e.index){//下面是拼接url,不同系统以及不同地图都有不同的拼接字段case1://安卓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

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

web url

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

百度

app url

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

web url

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

产品猿社区致力收录更多优质的商业产品,给服务商以及软件采购客户提供更多优质的软件产品,帮助开发者变现来实现多方共赢;

日常运营的过程中我们难免会遇到各种版权纠纷等问题,如果您在社区内发现有您的产品未经您授权而被用户提供下载或使用,您可按照我们投诉流程处理,点我投诉

本文来自用户发布投稿,不代表产品猿立场 ;若对此文有疑问或内容有严重错误,可联系平台客服反馈;

部分产品是用户投稿,可能本文没有提供官方下下载地址或教程,若您看到的内容没有下载入口,您可以在我们产品园商城搜索看开发者是否有发布商品;若您是开发者,也诚邀您入驻商城平台发布的产品,地址:点我进入

如若转载,请注明出处:https://www.chanpinyuan.cn/27350.html;
(0)
上一篇 2022年11月23日 下午4:17
下一篇 2022年11月23日 下午4:17

相关推荐

发表回复

登录后才能评论
分享本页
返回顶部