uniapp을 사용하여 간단한 지도 내비게이션을 개발하는 방법은 무엇입니까? 이 기사는 간단한 지도를 만드는 데 도움이 되기를 바랍니다.
먼저 렌더링을 살펴보겠습니다
그림 1의 지도를 보면 a지점이 b지점과 연결되어 있는 것을 알 수 있으며, 기본정보와 기본정보 컨트롤(확대, 축소, 지정된 지점으로 돌아가기)에 대해서는 단계별로 별도로 설명하겠습니다.
필수 구성
먼저 manifest.json
의 앱 모듈
에서 지도를 구성하고 키를 추가해야 합니다. 관련 맵코드>가 없으면 해당 개발자 플랫폼에서 신청하시면 됩니다<code>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 |
查看更多请查看:
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
지도 마커 포인트 | 유니앱 지도에 마커 포인트를 생성하려면, markers 속성을 사용해야 합니다. | ||
---|---|---|---|
name | description | type | required |
id | marker id | 의 공통 속성을 살펴보겠습니다. | 번호|
string | false | 설명선 | |
Object | false | label | |
Object | false | ||
https://uniapp.dcloud.io/comComponent/map.html | 이 점을 이해한 후 markers 속성을 사용하여 마커 포인트, markers</를 생성할 수 있습니다. code> 속성은 배열 유형이므로 마커 포인트는 다음과 같이 생성되어야 합니다</td><div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;"> // 连线
this.polyline = [
// 第一条线
{
// 每个点的经纬度
points: [{34.7486, 113.6709}, {28.7486, 113.6709}],
// 颜色
color: "#000",
// 宽度
width: 10
}
]</pre><div class="contentsignin">로그인 후 복사</div></div><div class="contentsignin">로그인 후 복사</div></div><td>더 많은 마커 포인트를 추가하려면 계속해서 배열에 <code>객체 를 추가하면 됩니다. | 각 < code>객체는 둘 다 표시된 지점을 나타냅니다 |
폴리라인<을 사용해야 합니다. /코드 > 속성. 🎜🎜먼저 <code>폴리라인
🎜🎜🎜🎜🎜Name🎜🎜Description🎜🎜Type🎜🎜Required🎜🎜🎜🎜🎜🎜points🎜🎜위도와 경도🎜 🎜 배열🎜🎜 true🎜🎜🎜🎜color🎜🎜선 색상🎜🎜string🎜🎜false🎜🎜🎜🎜width🎜🎜line width🎜🎜Number🎜🎜false🎜🎜🎜🎜iconPath 🎜 🎜표시된 아이콘🎜🎜string🎜🎜false🎜 🎜 🎜🎜arrowLine🎜🎜화살표가 있는 선🎜🎜Boolean🎜🎜false🎜🎜🎜🎜colorList🎜🎜Rainbow display🎜🎜Array🎜🎜false🎜🎜🎜🎜平台差异请查看
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,数字类型
这就是放大缩小功能的依赖
回到指定位置
想要地图回到指定的位置也非常简单,只需要使用 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)=> { // 判断用户选择的地图 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,其他常见的我放在下方了。
let appUrl = `qqmap://map/geocoder?coord=${latitude},${longitude}&referer=${腾讯地图key}`
let webUrl = `https://apis.map.qq.com/uri/v1/marker?marker=coord:经度,纬度;title:名称;addr:地址&referer=myapp`
let appUrl = `baidumap://map/marker?location=${latitude},${longitude}&title=${name}&coord_type=gcj02&src=andr.baidu.openAPIdemo`
let webUrl = `http://api.map.baidu.com/marker?location=${latitude},${longitude}&title=${name}&content=${content}&output=html&src=webapp.baidu.openAPIdemo`
推荐:《uniapp教程》
위 내용은 uniapp을 사용하여 간단한 지도 탐색 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!