Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
9a1374e8
unidocs-zh
项目概览
DCloud
/
unidocs-zh
通知
3216
Star
106
Fork
815
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
94
列表
看板
标记
里程碑
合并请求
70
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
94
Issue
94
列表
看板
标记
里程碑
合并请求
70
合并请求
70
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
9a1374e8
编写于
8月 01, 2023
作者:
VK1688
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add unicloud-map
上级
8a5ab717
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
557 addition
and
2 deletion
+557
-2
docs/uniCloud/_sidebar.md
docs/uniCloud/_sidebar.md
+6
-2
docs/uniCloud/unicloud-city-select.md
docs/uniCloud/unicloud-city-select.md
+16
-0
docs/uniCloud/unicloud-map.md
docs/uniCloud/unicloud-map.md
+535
-0
未找到文件。
docs/uniCloud/_sidebar.md
浏览文件 @
9a1374e8
...
...
@@ -99,6 +99,10 @@
*
[
uni-open-bridge 微信支付宝等三方凭据管理
](
uni-open-bridge.md
)
*
[
uni-cloud-s2s 传统服务器与uniCloud安全通信
](
uni-cloud-s2s.md
)
*
[
uni-subscribemsg 订阅消息发送
](
uni-subscribemsg.md
)
*
uni-map 地图
```{"collapsable": true}```
*
*
[
uni-map-common 公共模块
](
uni-map-common.md
)
*
*
[
unicloud-map 云端一体组件
](
unicloud-map.md
)
<!-- * * [unicloud-city-select 城市选择组件](unicloud-city-select.md) -->
*
[
案例
](
resource.md
)
*
[
开发者使用反馈
](
feedback.md
)
*
[
DCloud行业认证服务商
](
https://ask.dcloud.net.cn/article/39388
)
...
...
docs/uniCloud/unicloud-city-select.md
0 → 100644
浏览文件 @
9a1374e8
## unicloud-city-select 城市选择组件
::: warning 注意
该组件依赖
[
uni-map-common 公共模块
](
uni-map-common.md
)
:::
### 介绍@introduce
待补充
> 插件市场地址:[https://ext.dcloud.net.cn/plugin?name=unicloud-city-select](https://ext.dcloud.net.cn/plugin?name=unicloud-city-select)
**运行效果图**
![](
https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/3707/410.png
)
docs/uniCloud/unicloud-map.md
0 → 100644
浏览文件 @
9a1374e8
## unicloud-map 云端一体组件
::: warning 注意
该组件依赖
[
uni-map-common 公共模块
](
uni-map-common.md
)
:::
### 介绍@introduce
unicloud-map是云端一体组件,主要用于显示数据库里的自定义POI,渲染在地图上。具体可以实现如下功能:
1.
显示门店位置、景点位置、个人位置、车辆位置、活动举办地点等各种静态POI
2.
外卖软件显示外卖员实时配送路线
3.
打车软件显示司机到乘客上车点的实时路线
4.
更多基于自定义POI实现的功能
> 插件市场地址:[https://ext.dcloud.net.cn/plugin?name=unicloud-map](https://ext.dcloud.net.cn/plugin?name=unicloud-map)
### 用法示例@example
#### 渲染静态POI@staticpoi
通过从数据库获取POI数据,渲染到地图上
**运行效果图**
![](
https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/3707/409.png
)
**示例代码**
注意:此代码如果运行在APP中,需要使用nvue模式
```
vue
<
template
>
<view
class=
"page"
>
<unicloud-map
ref=
"map"
:debug=
"false"
loadtime=
"auto"
collection=
"opendb-poi"
:where=
"where"
:width=
"750"
:height=
"heightCom"
:latitude=
"latitude"
:longitude=
"longitude"
:scale=
"13"
:poi-maximum=
"100"
:default-icon=
"defaultIcon"
:custom-icons=
"customIcons"
:enable-scroll=
"true"
:enable-zoom=
"true"
:show-compass=
"true"
@
poitap=
"poitap"
></unicloud-map>
<view
class=
"btn-box first"
>
<button
@
click=
"initData"
size=
"mini"
class=
"btn"
>
初始化数据
</button>
<button
@
click=
"show1"
size=
"mini"
class=
"btn"
>
只显示门店
</button>
</view>
<view
class=
"btn-box"
>
<button
@
click=
"show2"
size=
"mini"
class=
"btn"
>
只显示总部
</button>
<button
@
click=
"show3"
size=
"mini"
class=
"btn"
>
显示总部+门店
</button>
</view>
</view>
</
template
>
<
script
>
var
timer
;
const
uniMapCo
=
uniCloud
.
importObject
(
'
uni-map-co
'
,
{
customUI
:
true
});
const
db
=
uniCloud
.
database
();
const
_
=
db
.
command
;
const
category
=
"
static-001
"
;
export
default
{
data
()
{
return
{
latitude
:
39.908823
,
longitude
:
116.39747
,
where
:
{
category
:
category
},
// 查询条件,不支持字符串JQL形式,必须是对象形式
defaultIcon
:
"
/static/icon/default.png
"
,
// 默认图标
// 自定义图标
customIcons
:
[
{
type
:
"
门店
"
,
icon
:
"
/static/icon/shop.png
"
},
{
type
:
"
总部
"
,
icon
:
"
/static/icon/headquarters.png
"
}
]
}
},
onLoad
()
{
},
methods
:
{
// 初始化测试数据
async
initData
()
{
uni
.
showLoading
({
title
:
"
生成中...
"
,
mask
:
true
});
try
{
await
uniMapCo
.
initStatic001
();
await
this
.
refresh
();
}
catch
(
err
)
{}
uni
.
hideLoading
();
},
// 只显示门店
show1
()
{
this
.
where
=
{
category
:
category
,
type
:
"
门店
"
};
},
// 只显示总部
show2
()
{
this
.
where
=
{
category
:
category
,
type
:
"
总部
"
};
},
// 显示门店+总部
show3
()
{
this
.
where
=
{
category
:
category
,
type
:
_
.
in
([
"
门店
"
,
"
总部
"
])
};
},
// 刷新地图
async
refresh
()
{
await
this
.
$refs
.
map
.
refresh
({
needIncludePoints
:
true
});
},
// 监听 - 点击POI事件
poitap
(
e
)
{
let
{
poi
}
=
e
;
this
.
showActionSheet
(
poi
);
},
// 导航弹窗
showActionSheet
(
poi
)
{
let
itemList
=
[
"
导航到这里
"
];
uni
.
showActionSheet
({
title
:
poi
.
title
,
itemList
:
itemList
,
success
:
(
res
)
=>
{
let
item
=
itemList
[
res
.
tapIndex
];
if
(
item
===
"
导航到这里
"
)
{
uni
.
openLocation
({
type
:
'
gcj02
'
,
latitude
:
poi
.
location
.
coordinates
[
1
],
longitude
:
poi
.
location
.
coordinates
[
0
],
name
:
poi
.
title
,
address
:
poi
.
address
});
}
}
});
}
},
computed
:
{
heightCom
()
{
let
systemInfo
=
uni
.
getSystemInfoSync
();
return
`
${
systemInfo
.
windowHeight
-
100
}
px`
;
}
}
}
</
script
>
<
style
lang=
"scss"
scoped
>
.page
{
.btn-box
{
margin
:
10px
;
/* #ifndef APP-NVUE */
display
:
flex
;
/* #endif */
flex-direction
:
row
;
.btn
{
flex
:
1
;
margin
:
0
5px
;
}
&
.first
{
margin
:
10px
10px
0
10px
;
}
}
}
</
style
>
```
#### 渲染动态POII@dynamicspoi
通过从数据库获取POI数据,并通过 uni-id-common 内的路线规划API,计算路线、距离、时间
**运行效果图**
![](
https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/3707/408.png
)
**示例代码**
注意:此代码如果运行在APP中,需要使用nvue模式
```
vue
<
template
>
<view
class=
"page"
>
<unicloud-map
ref=
"map"
:debug=
"false"
loadtime=
"auto"
collection=
"opendb-poi"
:where=
"where"
:width=
"750"
:height=
"heightCom"
:latitude=
"latitude"
:longitude=
"longitude"
:scale=
"13"
:poi-maximum=
"100"
:default-icon=
"defaultIcon"
:custom-icons=
"customIcons"
:enable-scroll=
"true"
:enable-zoom=
"true"
:show-compass=
"true"
:show-location=
"true"
></unicloud-map>
<view
class=
"btn-box first"
>
<button
@
click=
"initData"
size=
"mini"
class=
"btn"
>
初始化配送点
</button>
<button
@
click=
"virtuallyTest"
size=
"mini"
class=
"btn"
>
模拟配送(上报位置)
</button>
</view>
<view
class=
"btn-box"
>
<button
@
click=
"start"
size=
"mini"
class=
"btn"
v-if=
"!isStart"
>
开启监听
</button>
<button
@
click=
"stop"
size=
"mini"
class=
"btn"
v-else
>
暂停监听
</button>
</view>
</view>
</
template
>
<
script
>
var
timer
;
const
uniMapCo
=
uniCloud
.
importObject
(
'
uni-map-co
'
,
{
customUI
:
true
});
const
db
=
uniCloud
.
database
();
const
_
=
db
.
command
;
const
category
=
"
dynamics-001
"
;
export
default
{
data
()
{
return
{
longitude
:
116.39747
,
latitude
:
39.908823
,
where
:
{
category
:
category
},
defaultIcon
:
"
/static/icon/default.png
"
,
// 默认图标
// 自定义图标
customIcons
:[
{
type
:
"
配送员
"
,
icon
:
"
/static/icon/delivery.png
"
},
{
type
:
"
目的地
"
,
icon
:
"
/static/icon/to.png
"
}
],
isStart
:
false
,
polyline
:[],
isReady
:
false
}
},
onLoad
()
{
},
onUnload
()
{
this
.
stop
();
},
methods
:
{
async
initData
(){
let
res
=
await
uniMapCo
.
initDynamics001
();
await
this
.
refresh
();
this
.
setPolyline
(
res
.
polyline
);
},
// 虚拟配送测试
async
virtuallyTest
()
{
// 启动监听
this
.
start
();
// 先执行一次刷新,获得配送路线
await
this
.
refresh
();
const
sleep
=
ms
=>
new
Promise
(
resolve
=>
setTimeout
(
resolve
,
ms
));
let
polyline
=
JSON
.
parse
(
JSON
.
stringify
(
this
.
polyline
))
if
(
polyline
&&
polyline
.
length
>
0
)
{
for
(
let
i
=
0
;
i
<
polyline
[
0
].
points
.
length
;
i
++
)
{
if
(
!
this
.
isStart
)
{
break
;
}
let
item
=
polyline
[
0
].
points
[
i
];
await
sleep
(
500
);
// 模拟停顿
// 模拟上报当前的坐标
await
uniMapCo
.
updateMyLocation
({
longitude
:
item
.
longitude
,
latitude
:
item
.
latitude
,
});
}
}
},
// 刷新地图
async
refresh
()
{
await
this
.
$refs
.
map
.
refresh
({
needIncludePoints
:
true
});
let
res
=
await
uniMapCo
.
getPolyline
();
if
(
res
.
end
)
{
await
this
.
$refs
.
map
.
refresh
({
needIncludePoints
:
true
});
this
.
stop
();
this
.
setPolyline
([]);
}
else
{
this
.
setPolyline
(
res
.
polyline
);
}
},
// 开启监听
start
()
{
this
.
isStart
=
true
;
if
(
timer
)
clearInterval
(
timer
);
timer
=
setInterval
(()
=>
{
this
.
refresh
();
},
1000
);
},
// 停止监听
stop
()
{
this
.
isStart
=
false
;
if
(
timer
)
clearInterval
(
timer
);
},
// 设置路线
setPolyline
(
polyline
){
this
.
polyline
=
polyline
;
this
.
$refs
.
map
.
setPolyline
(
polyline
);
}
},
computed
:
{
heightCom
()
{
let
systemInfo
=
uni
.
getSystemInfoSync
();
return
`
${
systemInfo
.
windowHeight
-
100
}
px`
;
}
}
}
</
script
>
<
style
lang=
"scss"
scoped
>
.page
{
.btn-box
{
margin
:
10px
;
/* #ifndef APP-NVUE */
display
:
flex
;
/* #endif */
flex-direction
:
row
;
.btn
{
flex
:
1
;
margin
:
0
5px
;
}
&
.first
{
margin
:
10px
10px
0
10px
;
}
}
}
</
style
>
```
### 组件属性@props
| 属性名 | 说明 | 类型 | 默认值 | 可选值 |平台差异说明 |
|----------------- |------------------------------- |--------- |-------- |------- |------- |
| collection | 表名 | string | opendb-poi | - |- |
| loadtime | 数据加载时机 | string | auto | 见下 |- |
| where | 查询条件,注意,只支持对象写法,不支持JQL的字符串语法 | object | - | - |- |
| poi-maximum | 最大poi显示数量 | number | 100 | - |- |
| poi-max-distance |查询的最大距离 | number | - | - |- |
| poi-min-distance |查询的最小距离 | number | - | - |- |
| width |地图的宽度(不要设置百分比,必须直接写量,比如750rpx) | number、string| - | - |- |
| height |地图的高度(不要设置百分比,必须直接写量,比如750rpx) | number、string| - | - |- |
| default-icon |默认的POI图标 | string | /static/location.png| - |- |
| custom-icons |自定义图标,根据POI的type来区分 | Array | - | - |- |
| poi-title-format |自定义poi标题的格式化函数 | function | - | - |- |
| latitude |中心纬度 | number、string| - | - |- |
| longitude |中心经度 | number、string| - | - |- |
| scale |地图缩放等级,部分情况下会自动设置,此参数会失效 | number | 16 | - |高德地图缩放比例与微信小程序不同 |
| min-scale |最小缩放等级 | number | 3 | - |App-nvue 3.1.0+、微信小程序2.13+ |
| max-scale |最大缩放等级 | number | 20 | - |App-nvue 3.1.0+、微信小程序2.13+ |
| layer-style |个性化地图 | number、string| 1 | - |App-nvue 3.1.0+、微信小程序2.13+ |
| show-compass |是否显示指南针 | boolean | true | true、false |App-nvue 2.1.5+、微信小程序2.3.0 |
| enable-zoom |是否支持缩放 | boolean | true | true、false |App-nvue 2.1.5+、微信小程序2.3.0 |
| enable-scroll |是否支持拖动 | boolean | true | true、false |App-nvue 2.1.5+、微信小程序2.3.0 |
| enable-rotate |是否支持旋转 | boolean | false | true、false |App-nvue 2.1.5+、微信小程序2.3.0 |
| enable-overlooking|是否开启俯视 | boolean | false | true、false |App-nvue 2.1.5+、微信小程序2.3.0 |
| enable-satellite |是否开启卫星图 | boolean | false | true、false |App-nvue 2.1.5+、微信小程序2.7.0 |
| enable-traffic |是否开启实时路况 | boolean | false | true、false |App-nvue 2.1.5+、微信小程序2.7.0 |
| enable-poi |是否展示地图的原生 POI 点(非数据库内的POI点) | boolean | true | true、false |App-nvue 3.1.0+ |
| enable-building |是否展示建筑物 | boolean | true | true、false |App-nvue 3.1.0+ 支持 (
**废除原enable-3D属性 高德地图默认开启建筑物就是3D无法设置**
) |
| show-location |显示带有方向的当前定位点 | boolean | true | true、false |微信小程序、H5、百度小程序、支付宝小程序、京东小程序 |
| polygons |多边形 | boolean | false | true、false |App-nvue 2.1.5+、App-vue 3.4.3+、H5 3.4.3+、微信小程序、百度小程序 |
| enable-indoor-map |是否展示室内地图 | boolean | false | true、false |App-nvue 3.1.0+ |
| @mounted |组件挂载完毕触发 | EventHandle | - |- |- |
| @poitap |点击自定义POI点时触发 | EventHandle | - |- |- |
| @markertap |点击标记点时触发 | EventHandle | - |- |App-nvue 2.3.3+、H5、微信小程序、支付宝小程序 (App和H5平台需要指定 marker 对象属性 id) |
| @labeltap |点击标记点时触发 | EventHandle | - |- |微信小程序2.9.0 |
| @callouttap |点击标记点对应的气泡时触发 | EventHandle | - |- |- |
| @controltap |点击控件时触发 | EventHandle | - |- |- |
| @regionchange |视野发生变化时触发 | EventHandle | - |- |视野发生变化时触发|微信小程序、H5、百度小程序、支付宝小程序、京东小程序 |
| @tap |点击地图时触发; App-nvue、微信小程序2.9支持返回经纬度 | EventHandle | - |- |点击地图时触发; App-nvue、微信小程序2.9支持返回经纬度 |
| @updated |在地图渲染更新完成时触发| EventHandle | - |- |在地图渲染更新完成时触发|微信小程序、H5、百度小程序 |
| @anchorpointtap |点击定位标时触发 | EventHandle | - |- |App-nvue 3.1.0+、微信小程序2.13+ |
| @native-poitap |点击地图原生POI点时触发 | EventHandle | - |- |微信小程序2.3.0+ |
**注意**
-
只支持腾讯地图或高德地图,且需使用
`gcj02`
坐标,用错坐标类型会显示偏移。
### 组件方法@function
| 方法名 | 说明 |
|-----------------|-------------------------------|
| refresh | 主动刷新POI数据 |
| getMarkers | 获取组件内的markers |
| setMarkers | 设置组件内的markers |
| getPolyline | 获取组件内的polyline |
| setPolyline | 设置组件内的polyline |
| getCircles | 获取组件内的circles |
| setCircles | 设置组件内的circles |
| getControls | 获取组件内的controls |
| setControls | 设置组件内的controls |
**refresh**
主动刷新POI数据
示例
```
js
await
this
.
$refs
.
map
.
refresh
();
```
**getMarkers**
获取组件内的markers
示例
```
js
let
markers
=
this
.
$refs
.
map
.
getMarkers
();
console
.
log
(
'
markers:
'
,
markers
);
```
**setMarkers**
设置组件内的markers,用法与内置组件的map一致,
[
点击查看详情
](
https://uniapp.dcloud.net.cn/component/map.html#%E8%BF%91%E6%9C%9F%E6%96%B0%E5%A2%9E%E5%8A%9F%E8%83%BD
)
示例
```
js
this
.
$refs
.
map
.
setMarkers
(
markers
);
```
**getPolyline**
获取组件内的polyline
示例
```
js
let
polyline
=
this
.
$refs
.
map
.
getPolyline
();
console
.
log
(
'
polyline:
'
,
polyline
);
```
**setPolyline**
设置组件内的polyline,用法与内置组件的map一致,
[
点击查看详情
](
https://uniapp.dcloud.net.cn/component/map.html#%E7%82%B9%E8%81%9A%E5%90%88
)
示例
```
js
this
.
$refs
.
map
.
setPolyline
(
polyline
);
```
**getCircles**
获取组件内的circles
示例
```
js
let
circles
=
this
.
$refs
.
map
.
getCircles
();
console
.
log
(
'
circles:
'
,
circles
);
```
**setCircles**
设置组件内的circles ,用法与内置组件的map一致,
[
点击查看详情
](
https://uniapp.dcloud.net.cn/component/map.html#%E7%82%B9%E8%81%9A%E5%90%88
)
示例
```
js
this
.
$refs
.
map
.
setCircles
(
circles
);
```
**getControls**
获取组件内的controls
示例
```
js
let
controls
=
this
.
$refs
.
map
.
getControls
();
console
.
log
(
'
controls:
'
,
controls
);
```
**setControls**
设置组件内的controls,用法与内置组件的map一致,
[
点击查看详情
](
https://uniapp.dcloud.net.cn/component/map.html#%E7%82%B9%E8%81%9A%E5%90%88
)
示例
```
js
this
.
$refs
.
map
.
setControls
(
controls
);
```
### unicloud-map的opendb数据表@database
unicloud-map需要创建以下表后才能正常运行,可以右键插件database目录下的opendb-poi.schema.json上传Schema
![](
http://dcloud-chjh-web.oss-cn-hangzhou.aliyuncs.com/unidoc/zh/3707/411.png
)
-
地图POI表
[
opendb-poi
](
https://gitee.com/dcloud/opendb/blob/master/collection/opendb-poi/collection.json
)
### 三方定位和地图服务收费说明@fee
[
点击查看
](
https://uniapp.dcloud.net.cn/component/map.html#%E4%B8%89%E6%96%B9%E5%AE%9A%E4%BD%8D%E5%92%8C%E5%9C%B0%E5%9B%BE%E6%9C%8D%E5%8A%A1%E6%94%B6%E8%B4%B9%E8%AF%B4%E6%98%8E
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录