本篇文章用来为大家提供一个制作简单地图的思路
先来看一眼效果图
简易map
在图一的地图中可以看到 a点 连接 到 b点, 基本信息 以及 基本的控件(放大、缩小、回到某个指定的点),接下来我们分开逐步讲解。
所需配置
需要先在manifest.json 中的 app模块 中配置地图,并添加相关地图的key ,如果没有可在相关开发者平台进行申请
配置好这一部分就可以开始使用map组件了
地图标记点
在uniapp map中想创建标记点就需要使用到一个属性 markers 。
我们先来看一下markers 的常用属性
名称 | 说明 | 类型 | 必填 |
---|
id | 标记点id | number | true | latitude | 纬度 | number | true | longitude | 经度 | number | true | iconPath | 显示的图标 | string | false | callout | 自定义标记点上方的气泡框 | Object | false | label | 为标记点傍边增加标签 | Object | false |
查看更多请点击这里
了解过这些我们就可以使用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 | 经纬度数组 | Array | true | color | 线的颜色 | string | false | width | 线宽 | Number | false | iconPath | 显示的图标 | string | false | arrowLine | 带箭头的线 | Boolean | false | colorList | 彩虹显 | Array | false |
平台差异请点击查看
这里我们要注意 两个坑,作者亲踩
-
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,数字类型
这就是放大缩小功能的依赖
回到指定位置
想要地图回到指定的位置也非常简单,只需要使用 uni.createMapContext() 方法创建一个 mapContent 对象 在使用 附带的 moveToLocatio 方法便可让地图回到指定的位置。
goBackToLocation() {
uni.createMapContext("map").moveToLocation({34.7486, 113.6709});
},
导航弹框
图二中的地图应用选择弹框则是使用了 h5Plus 的
nativeUI.actionSheet 方法 创建了弹框
runtime.openURL 方法 打开了 导航软件 或 h5 页面导航
nativeUI情请点击这里查看
runtime情请点击这里查看
openNavigation(longitude, latitude, name) {
let url = "";
let webUrl = "";
plus.nativeUI.actionSheet({
title: "选择地图应用",
cancel: "取消",
buttons: [{title: "高德地图"}]
}, (e)=> {
switch (e.index) {
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);
plus.runtime.openURL(url, (err)=>{
plus.runtime.openURL(webUrl);
});
}
})
}
这就是我导航弹窗实现的逻辑了, 这里我仅仅只是用了高德地图的选项,大家可以根据需要增加相应地图app,其他常见的我放在下方了。
腾讯
app url
Android app url
let appUrl = `qqmap://map/geocoder?coord=${latitude},${longitude}&referer=${腾讯地图key}`
ios 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
Android app url
let appUrl = `baidumap://map/marker?location=${latitude},${longitude}&title=${name}&coord_type=gcj02&src=andr.baidu.openAPIdemo`
ios app url
let appUrl = `baidumap://map/marker?location=${latitude},${longitude}&title=${name}&content=${name}&src=ios.baidu.openAPIdemo&coord_type=gcj02`
web url
let webUrl = `http://api.map.baidu.com/marker?location=${latitude},${longitude}&title=${name}&content=${content}&output=html&src=webapp.baidu.openAPIdemo`
结语: 天才无非是长久的忍耐,努力吧!
|