## uni-map-service 公共模块
聚合了多家地图供应商的服务端API
::: warning 注意
uni-map-service公共模块仅能在云函数/云对象内使用。如果您不了解公共模块,请[参阅](cf-common.md)
:::
> 插件市场地址:[https://ext.dcloud.net.cn/plugin?name=uni-map-service](https://ext.dcloud.net.cn/plugin?name=uni-map-service)
## 配置@config
待补充
## 公共返回参数@publicresult
以下所有API均会返回的参数
|参数 |说明 |
|--- |--- |
|errCode |为0代表成功,其他均为失败 |
|errMsg |失败后的提示 |
|originalResult | 原始返回结果(供应商接口原始返回结果,需new UniMapService时,设置needOriginalResult: true) |
|result | 插件返回结果(抹平各平台差异后的返回结果) |
## 初始化实例
在调用API前,需要先初始化实例
```js
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
needOriginalResult: false, // 是否需要返回原始信息
});
```
**参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|provider |String |是 |指定使用哪家地图供应商 |all |
|needOriginalResult |Boolean|否 |是否需要返回原始信息,默认false|all |
**provider可选项**
- qqmap 腾讯地图
- amap 高德地图
## API@api
### 逆地址解析(坐标转地址)@location2address
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.location2address({
location: "39.908815,116.397507"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|location |String |是 |经纬度(GCJ02坐标系),格式:location=lat<纬度>,lng<经度> |all |
|get_poi |Number |否 |是否返回周边地点(POI)列表
0:不返回(默认)
1:返回 |all |
|poi_options|String |否 |周边POI(AOI)列表控制参数 |腾讯地图 |
|poitype |String |否 |返回附近POI类型 | 高德地图|
|radius |String |否 |搜索半径(radius取值范围在0~3000,默认是1000。单位:米) | 高德地图|
|roadlevel |Number |否 |道路等级
0:显示所有道路
1:过滤非主干道路,仅输出主干道路数据 |高德地图 |
|homeorcorp |String |否 |是否优化POI返回顺序 | 高德地图|
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|formatted_addresses| String|详细地址 |all |
|country | String|国家 |all |
|province | String|省 |all |
|city | String|市 |all |
|district | String|区 |all |
|street | String|街道/道路,可能为空字串|all |
|street_number | String|门牌,可能为空字串 |all |
|adcode | String|行政区划代码 |all |
|towncode | String|乡镇街道编码 |all |
|pois | Array |周边POI |all |
| |-- id |String |id |all |
| |-- title |String |地点名称 |all |
| |-- address |String |地址 |all |
| |-- location |Object |经纬度 |all |
| |-- distance |Number |距离(米) |all |
| |-- direction|String |方位 |all |
| |-- category |String |类别 |all |
### 地址解析(地址转坐标)@address2location
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.address2location({
address: "北京市海淀区彩和坊路海淀西大街74号"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|address|String |是 |地址(注:地址中请包含城市名称,以及需要对地址进行URL编码,否则会影响解析效果)|all |
|city |String |否 |指定查询的城市(不传则在全国范围内查询) |all |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|location |Object | 经纬度 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
|adcode |String |行政区划代码 |all |
|province | String|省 |all |
|city | String|市 |all |
|district | String|区,可能为空字串 |all |
|street | String|街道/道路,可能为空字串|all |
|street_number| String|门牌,可能为空字串 |all |
### 坐标转换@translate
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.translate({
locations: "39.12,116.83;30.21,115.43",
type: 3
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|locations |Array |是 |预转换的坐标,支持批量转换 |all |
| |-- lat|Number|纬度 |all |
| |-- lng|Number|经度 |all |
|type |Number |否 |输入的locations的坐标类型,
可选值:
1:GPS
2:sogou
3:baidu
4:mapbar
6:sogou |腾讯地图:全部支持; 高德地图:1、3、4|
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|locations |Array | 坐标转换结果,转换后的坐标顺序与输入顺序一致|all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
### IP定位@ip2location
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.ip2location({
ip: "111.206.145.41"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|ip |String |是 | IP地址|all |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|location |Object | 坐标 |腾讯地图 |
| |-- lat|Number |纬度 |腾讯地图 |
| |-- lng|Number |经度 |腾讯地图 |
|nation |String | 国家 |腾讯地图 |
|nation_code |String | 国家代码(ISO3166标准3位数字码)|腾讯地图 |
|adcode |Number | 行政区划代码 |all |
|province |String | 省 |all |
|city |String | 市,可能为空 |all |
|district |String | 区,可能为空 |腾讯地图 |
|rectangle |String | 所在城市矩形区域范围 |高德地图 |
### 关键词输入提示@inputtips
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.inputtips({
keyword: "人民医院",
region: "北京市"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|keyword |String |是 | 用户输入的关键词(希望获取后续提示的关键词) |all |
|city |String |是 | 限制城市范围 |all |
|citylimit |Boolean|否 | false:当前城市无结果时,自动扩大范围到全国匹配(默认)
true:固定在当前城市 | all |
|location |String |否 | 定位坐标,传入后,若用户搜索关键词为类别词(如酒店、餐馆时),
与此坐标距离近的地点将靠前显示
格式:location=lat<纬度>,lng<经度>|all |
|get_subpois |Number |否 | 是否返回子地点,如大厦停车场、出入口等取值
0:不返回(默认)
1:返回) |腾讯地图 |
|policy |Number |否 | 检索策略 |腾讯地图 |
|filter |String |否 | 筛选条件 |腾讯地图 |
|address_format |String |否 |可选值:short 返回“不带行政区划的”短地址 |腾讯地图 |
|page\_index |Number |否 | 页码,从1开始,最大页码需通过count进行计算,必须与page_size同时使用 |腾讯地图 |
|page\_size |Number |否 | 每页条数,取值范围1-20,必须与page_index 同时使用 |腾讯地图 |
|datatype |Number |否 | 返回的数据类型,多种数据类型用“\|”分隔
可选值:
all:返回所有数据类型
poi:返回POI数据类型
bus:返回公交站点数据类型
busline:返回公交线路数据类型|高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|data |Array | 提示词数组,每项为一个POI对象 |all |
| |-- id |String |若数据为POI类型,则返回POI ID;若数据为bus类型,则返回bus id;若数据为busline类型,则返回busline id。|all |
| |-- title |String |地点名称 |all |
| |-- address |String |地址 |all |
| |-- category |String |分类 |腾讯地图 |
| |-- type |String |POI类型,值说明:0:普通POI / 1:公交车站 / 2:地铁站 / 3:公交线路 / 4:行政区划 |腾讯地图 |
| |-- location |String |经纬度 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- adcode |Number |行政区划代码 |all |
| |-- province |String |省 |腾讯地图 |
| |-- city |String |市 |腾讯地图 |
| |-- district |String |区/县,当type(POI类型)为3(公交线路)时,district由city补全 |腾讯地图 |
|sub_pois |String |子地点列表,仅在输入参数get\_subpois=1时返回 |腾讯地图 |
| |-- parent_id|String |主地点ID,对应data中的地点ID |腾讯地图 |
| |-- id |String |地点唯一标识 |腾讯地图 |
| |-- title |String |地点名称 |腾讯地图 |
| |-- address |String |地址 |腾讯地图 |
| |-- category |String |POI(地点)分类 |腾讯地图 |
| |-- location |String |地址 |腾讯地图 |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- adcode |String |行政区划代码 |腾讯地图 |
| |-- city |String |地址 |腾讯地图 |
| |-- address |String |地点所在城市名称 |腾讯地图 |
### 路线规划(驾车/步行/骑行/电动车/公交)@routePlan
**示例**
```js
// 引入uni-map-service公共模块
const UniMapService = require('uni-map-service');
// 初始化实例
let uniMapService = new UniMapService({
provider: "qqmap", // 指定使用哪家地图供应商
});
// 调用API
let result = await uniMapService.routePlan({
mode: "driving",
from: "40.034852,116.319820",
to: "39.771075,116.351395"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |适用mode |说明 |兼容性 |
|:-- |:-: |:-: |:-: |:-- |:-: |
|mode |String |是 | 通用 | 交通方式
driving:驾车
walking:步行
bicycling:骑行
ebicycling:电动车
transit:公交 |all |
|from |String |是 | 通用 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 通用 | 终点位置坐标,格式:lat,lng |all |
|to_poi |String |否 | 通用 | 终点POI ID,传入后,优先级高于from(坐标) |all |
|show_fields |Number |否 | 通用 | 返回结果控制,show\_fields用来筛选response结果中可选字段。
show\_fields的使用需要遵循如下规则:
1、具体可指定返回的字段类请见下方返回结果说明中的“show\_fields”内字段类型
2、多个字段间采用“,”进行分割
3、show\_fields未设置时,只返回基础信息类内字段
|高德地图 |
|from_poi |String |否 | 驾车、公交 | 起点POI ID,传入后,优先级高于from(坐标) |all |
|policy |String |否 | 驾车、公交 |算路策略,详情见下方policy值范围 |all |
|waypoints |String |否 | 驾车 |途经点,格式:lat1,lng1;lat2,lng2;…
腾讯地图最大支持30个
高德地图最大支持16个 |all |
|avoidpolygons |String |否 | 驾车 | 避让区域 |all |
|road_type |Number |否 | 驾车 | [from辅助参数] 起点道路类型 |all |
|plate |String |否 | 驾车 | 车牌号,填入后,路线引擎会根据车牌对限行区域进行避让,不填则不不考虑限行问题 |all |
|cartype |Number |否 | 驾车 | 车辆类型(影响限行规则),
取值:
0:[默认]普通汽车
1:新能源
2:插电式混动汽车 |腾讯地图:0、1; 高德地图:全部支持 |
|heading |Number |否 | 驾车 | [from辅助参数]在起点位置时的车头方向,数值型,取值范围0至360(0度代表正北,顺时针一周360度) |腾讯地图 |
|speed |Number |否 | 驾车 | [from辅助参数]速度,单位:米/秒,默认3。 当速度低于1.39米/秒时,heading将被忽略 |腾讯地图 |
|accuracy |Number |否 | 驾车 | [from辅助参数]定位精度,单位:米,取>0数值,默认5。 当定位精度>30米时heading参数将被忽略 |腾讯地图 |
|from_track |Number |否 | 驾车 | [from辅助参数]起点轨迹 |腾讯地图 |
|get_mp |Number |否 | 驾车 | 是否返回多方案
0:[默认]仅返回一条路线方案
1:返回多方案(最多可返回三条方案供用户备选) |腾讯地图 |
|get_speed |Number |否 | 驾车 | 是否返回路况(道路速度)
0:[默认]不返回路况 1:返回路况 |腾讯地图 |
|added_fields |Number |否 | 驾车 | 返回指定标准附加字段,取值支持 cities 路线途经行政区划信息(按路线A途经顺序排序) |腾讯地图 |
|no_step |Number |否 | 驾车 | 不返回路线引导信息,可使回包数据量更小,
取值:
0:[默认]返回路线引导信息
1:不返回 |腾讯地图 |
|avoidroad |String |否 | 驾车 | 避让道路名,只支持一条避让道路 |高德地图 |
|ferry |Number |否 | 驾车 | 是否使用轮渡
0:使用渡轮
1:不使用渡轮 |高德地图 |
|departure_time |Number |否 | 公交 | 出发时间,用于过滤掉非运营时段的线路,格式为Unix时间戳,默认使用当前时间 |腾讯地图 |
|city1 |String |是 | 公交 | 起点所在城市(仅支持citycode,相同时代表同城,不同时代表跨城) |高德地图 |
|city2 |String |是 | 公交 | 目的地所在城市(仅支持citycode,相同时代表同城,不同时代表跨城) |高德地图 |
|multiexport |Number |否 | 公交 | 地铁出入口数量
0:只返回一个地铁出入口
1:返回全部地铁出入口 |高德地图 |
|max_trans |Number |否 | 公交 | 最大换乘次数 |高德地图 |
|nightflag |Number |否 | 公交 | 考虑夜班车
0:不考虑夜班车
1:考虑夜班车 |高德地图 |
|date |String |否 | 公交 | 请求日期 例如:2013-10-28 |高德地图 |
|time |String |否 | 公交 | 请求时间 例如:9-54 |高德地图 |
|alternative_route|Number |否 | 步行、骑行、电动车、公交 | 返回方案条数 最大3条,mode为公交时,最大10条 |高德地图 |
**【驾车】方式policy值范围**
0:速度优先(只返回一条路线),此路线不一定距离最短
1:费用优先(只返回一条路线),不走收费路段,且耗时最少的路线
2:距离优先(只返回一条路线),仅走距离最短的路线,但是可能存在穿越小路/小区的情况
3:速度优先(只返回一条路线),不走快速路,例如京通快速路
32:高德地图APP默认策略
33:躲避拥堵
34:高速优先
35:不走高速
36:少收费
37:大路优先
38:速度最快
39:躲避拥堵+高速优先
40:躲避拥堵+不走高速
41:躲避拥堵+少收费
42:少收费+不走高速
43:躲避拥堵+少收费+不走高速
44:躲避拥堵+大路优先
45:躲避拥堵+速度最快
101:该策略会通过终点坐标查找所在地点(如小区/大厦等),并使用地点出入口做为目的地,使路径更为合理
注意:高德地图支持除101外的所有策略,腾讯地图只支持 0、34、35、36、37、101
**【公交】方式policy值范围**
0:默认模式
1:最经济模式,票价最低
2:最少换乘模式,换乘次数少
3:最少步行模式,尽可能减少步行距离
4:最舒适模式,尽可能乘坐空调车
5:不乘地铁模式,不乘坐地铁路线
6:地铁图模式,起终点都是地铁站(地铁图模式下originpoi及destinationpoi为必填项)
7:地铁优先模式,步行距离不超过4KM
8:时间短模式,方案花费总时间最少
注意:高德地图支持所有策略,腾讯地图只支持 0、2、3、5、6、7
**返回参数**
注意:此接口固定返回originalResult参数(透传供应商接口原始返回结果)
腾讯地图:
[返回参数:驾车(driving)](https://lbs.qq.com/service/webService/webServiceGuide/webServiceRoute#2)
[返回参数:步行(walking)](https://lbs.qq.com/service/webService/webServiceGuide/webServiceRoute#3)
[返回参数:骑行(bicycling)](https://lbs.qq.com/service/webService/webServiceGuide/webServiceRoute#4)
[返回参数:电动车(ebicycling)](https://lbs.qq.com/service/webService/webServiceGuide/webServiceRoute#5)
[返回参数:公交(transit)](https://lbs.qq.com/service/webService/webServiceGuide/webServiceRoute#6)
高德地图:
[返回参数:驾车(driving)](https://lbs.amap.com/api/webservice/guide/api/newroute#t5)
[返回参数:步行(walking)](https://lbs.amap.com/api/webservice/guide/api/newroute#t6)
[返回参数:骑行(bicycling)](https://lbs.amap.com/api/webservice/guide/api/newroute#t7)
[返回参数:电动车(ebicycling)](https://lbs.amap.com/api/webservice/guide/api/newroute#t8)
[返回参数:公交(transit)](https://lbs.amap.com/api/webservice/guide/api/newroute#t9)
## 全局错误码@errorcode
| 错误模块 | 错误码 | 说明 |
|:-- |:--: |:-- |
| uni-map-service | 110 | 请求来源未被授权 |
| uni-map-service | 111 | 签名验证失败 |
| uni-map-service | 112 | IP未被授权 |
| uni-map-service | 113 | 此功能未被授权 |
| uni-map-service | 120 | 此key每秒请求量已达到上限 |
| uni-map-service | 121 | 此key每日调用量已达到上限 |
| uni-map-service | 160 | sig参数不支持此请求类型 |
| uni-map-service | 161 | sig参数不支持和非object的POST JSON一起使用 |
| uni-map-service | 190 | 无效的KEY |
| uni-map-service | 199 | 此key未开启webservice功能 |
| uni-map-service | 301 | 缺少必要字段key |
| uni-map-service | 311 | key格式错误 |
| uni-map-service | 300 | 缺少必要字段 |
| uni-map-service | 306 | 缺少参数 |
| uni-map-service | 310 | 参数格式错误 |
| uni-map-service |320 |参数数据类型错误 |
| uni-map-service |330 |参数长度错误 |
| uni-map-service |351 |存在不共存的参数 |
| uni-map-service |324 |get和post中的同一参数值不相同 |
| uni-map-service |326 |起终点距离过近 |
| uni-map-service |327 |附近无公交站 |
| uni-map-service |328 |无可达公交路线 |
| uni-map-service |329 |无可达火车路线 |
| uni-map-service |331 |查询条件过长 |
| uni-map-service |332 |途径点个数超过限制 |
| uni-map-service |333 |存在无法吸附的坐标点 |
| uni-map-service |335 |不支持该城市的公交查询 |
| uni-map-service |341 |缺少keyword(关键词) |
| uni-map-service |344 |附近无火车站(公交) |
| uni-map-service |347 |查询无结果 |
| uni-map-service |348 |参数错误 |
| uni-map-service |364 |是否扩大搜索参数只能为0或1 |
| uni-map-service |365 |纬度不能超过±90 |
| uni-map-service |366 |经度不能超过±180 |
| uni-map-service |373 |起终点距离超长 |
| uni-map-service |374 |起终点坐标错误 |
| uni-map-service |375 |局域网IP无法定位 |
| uni-map-service |377 |提供的起终点无法规划出导航线路 |
| uni-map-service |378 |提供的起终点无法规划出步行线路 |
| uni-map-service |379 |提供的起终点无法规划出公交线路 |
| uni-map-service |380 |坐标类型必须在有坐标的情况下使用 |
| uni-map-service |382 |IP无法定位 |
| uni-map-service |384 |提供的起终点无法规划出骑行线路 |
| uni-map-service |387 |没有对应的POI |
| uni-map-service |393 |没有符合条件的数据 |
| uni-map-service |394 |错误的查询条件 |
| uni-map-service |395 |传入参数不合法 |
| uni-map-service |396 |最多支持200个坐标点,且起终点数目乘积最多为625(距离矩阵) |
| uni-map-service |397 |一对多最多支持200个坐标点,多对多最多支持25个坐标点且起终点数目乘积最多为625(距离矩阵) |
| uni-map-service |500 |服务响应失败 |
## 常见问题
### 使用uni-map-service后,我还需要购买5万元的地图商业授权费用吗?
答:待补充