## uni-map-common 公共模块
聚合多家地图供应商的云能力的公共模块。
不管高德还是腾讯地图,都有众多服务端API,比如逆地址解析。uni-map-common对这些API进行了统一封装,抹平了差异。
开发者只需使用uni-map-common,就可以更简单的使用地图的云接口。并且方便在不同地图厂商之间切换。
同时本公共模块也是 [uniCloud-map 云端一体地图](unicloud-map.md) 的基础支撑模块。
::: warning 注意
uni-map-common公共模块仅能在云函数/云对象内使用。如果您不了解公共模块,请[参阅](cf-common.md)
:::
> 插件市场地址:[https://ext.dcloud.net.cn/plugin?name=uni-map-common](https://ext.dcloud.net.cn/plugin?name=uni-map-common)
> 交流群:[uni-map交流群](https://im.dcloud.net.cn/#/?joinGroup=64d62b106823de10406ad72f)
## 公共返回参数@publicresult
以下所有API均会返回的参数
|参数 |说明 |
|--- |--- |
|errCode |为0代表成功,其他均为失败 |
|errMsg |失败后的提示 |
|provider | 当前数据是哪家地图供应商返回的 |
|result | 插件返回结果(抹平各平台差异后的返回结果) |
|originalResult | 原始返回结果(供应商接口原始返回结果,需new UniMap时,设置needOriginalResult: true) |
## 地图key@key
调用地图API需要先在对应的地图开放平台申请key
### 申请腾讯地图key@qqmapkey
[申请地址](https://lbs.qq.com/dev/console/application/mine)
**服务端key**
key的配置文件:`/uni_modules/uni-config-center/uniCloud/cloudfunctions/common/uni-config-center/uni-map/config.js`
申请步骤:点击我的应用,创建新应用,添加key,key的类型选WebServiceAPI,白名单留空
![](https://web-ext-storage.dcloud.net.cn/unicloud/uni-map/035ee67b-b270-4fb0-a845-efd7064bb756.png)
**客户端key**
key的配置文件:`manifest.json`
根据不同的客户端类型勾选不同的key类型
|客户端类型|申请对应key类型 |
|--- |--- |
|Web |WebServiceAPI |
|App |SDK |
|微信小程序| 微信小程序 |
### 申请高德地图key@amapkey
[申请地址](https://console.amap.com/dev/key/app)
**服务端key**
key的配置文件:`/uni_modules/uni-config-center/uniCloud/cloudfunctions/common/uni-config-center/uni-map/config.js`
申请步骤:点击我的应用,创建新应用,添加key,key的类型选Web服务,白名单留空
![](https://web-ext-storage.dcloud.net.cn/unicloud/uni-map/a04364bc-1a8c-4561-8f53-1ea387db69dc.png)
**客户端key**
key的配置文件:`manifest.json`
根据不同的客户端类型勾选不同的key类型
|客户端类型 |申请对应key类型(服务平台) |
|--- |--- |
|Web |Web端(JS API) |
|App-iOS |iOS |
|App-Android| Android平台 |
|微信小程序 | 微信小程序 |
### 客户端
## 初始化实例
在调用API前,需要先初始化实例
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx",
needOriginalResult: false, // 是否需要返回原始信息
});
```
**参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|provider |String |是 |指定使用哪家地图供应商 |all |
|key |String |是 |地图供应商对应的key |all |
|needOriginalResult |Boolean|否 |是否需要返回原始信息,默认false|all |
**provider可选项**
- qqmap 腾讯地图
- amap 高德地图
## API@api
### 逆地址解析(坐标转地址)@location2address
**功能介绍**
主要用于将经纬度坐标识别为详细地址,如:39.908815,116.397507 识别为 北京市东城区西长安街1号
同时还能获取到经纬度所在省、市、区、乡镇、门牌号、行政区划代码,及周边参考位置信息,如道路及交叉口、河流、湖泊、桥等
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.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 |Object |否 |周边POI(AOI)列表控制参数,仅当get\_poi=1时生效 |all |
| |-- radius |Number |否 |搜索半径,单位:米
radius取值范围
腾讯地图 1-5000(米)
高德地图 0~3000(米),默认是1000(米) |all |
| |-- policy |Number |否 |控制返回场景
1[默认] 以地标+主要的路+近距离POI为主,着力描述当前位置;
2 到家场景:筛选合适收货的POI,并会细化收货地址,精确到楼栋;
3 出行场景:过滤掉车辆不易到达的POI(如一些景区内POI),
增加道路出入口、交叉口、大区域出入口类POI,排序会根据真实API大用户的用户点击自动优化。
4 社交签到场景,针对用户签到的热门 地点进行优先排序。
5 位置共享场景,用户经常用于发送位置、位置分享等场景的热门地点优先排序
4 注:policy=1/2/3最多返回10条周边POI,policy=4/5最多返回20条, |all |
| |-- address_format |String |否 |地址格式
long 长地址(默认)
short 短地址 |腾讯地图 |
| |-- poitype |String |否 |返回附近POI类型
参数仅支持传入POI TYPECODE,可以传入多个POI TYPECODE,相互之间用“|”分隔。
获取 POI TYPECODE 可以参考 [高德地图-POI分类码表](https://a.amap.com/lbs/static/amap_3dmap_lite/amap_poicode.zip) | 高德地图 |
| |-- roadlevel |Number |否 |道路等级
0:显示所有道路
1:过滤非主干道路,仅输出主干道路数据 |高德地图 |
| |-- homeorcorp |Number |否 |是否优化POI返回顺序homeorcorp 参数的设置可以影响召回 POI 内容的排序策略,
目前提供三个可选参数:
0:不对召回的排序策略进行干扰。
1:综合大数据分析将居家相关的 POI 内容优先返回,即优化返回结果中 pois 字段的poi顺序。
2:综合大数据分析将公司相关的 POI 内容优先返回,即优化返回结果中 pois 字段的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 |
|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 |
|roads | Array |道路信息列表 |高德地图 |
| |-- id | String|道路id |高德地图 |
| |-- title | String|道路名称 |高德地图 |
| |-- distance | String|道路到请求坐标的距离(米) |高德地图 |
| |-- direction | Object|方位 |高德地图 |
| |-- location | Object|坐标点 |高德地图 |
| |-- lat | Number|纬度 |高德地图 |
| |-- lng | Number|经度 |高德地图 |
|roadinters | Array |道路交叉口列表 |高德地图 |
| |-- distance | String|交叉路口到请求坐标的距离(米) |高德地图 |
| |-- direction | String|方位(输入点相对路口的方位) |高德地图 |
| |-- first_id | String|第一条道路id |高德地图 |
| |-- first_name | String|第一条道路名称 |高德地图 |
| |-- second_id | String|第二条道路id |高德地图 |
| |-- second_name| String|第二条道路名称 |高德地图 |
| |-- location | Object|路口经纬度 |高德地图 |
| |-- lat | Number|纬度 |高德地图 |
| |-- lng | Number|经度 |高德地图 |
### 地址解析(地址转坐标)@address2location
**功能介绍**
用于将文字地址转换成对应的经纬度坐标,同时识别文字地址中的行政区域
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.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
**功能介绍**
实现从其它地图供应商坐标系或标准GPS坐标系,批量转换到指定地图供应商的坐标系。
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.translate({
locations: [
{ lat: 39.908815, lng: 116.397507 },
{ lat: 39.908815, lng: 116.397107 }
],
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
**功能介绍**
通过终端设备IP地址获取其当前所在地理位置,常用于显示当前所在城市。
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.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
**功能介绍**
用于获取输入关键字的补完与提示,帮助用户快速输入。需配合前端程序实现Autocomplete(自动完成)的效果。
![](https://qiniu-web-assets.dcloud.net.cn/unidoc/zh/uni-admin/%E8%85%BE%E8%AE%AF%E5%9C%B0%E5%9B%BE/1.jpg)
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.inputtips({
keyword: "人民医院",
city: "北京市"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|keyword |String |是 | 用户输入的关键词(希望获取后续提示的关键词) |all |
|city |String |是 | 限制城市范围 |all |
|citylimit |Boolean|否 | false:当前城市无结果时,自动扩大范围到全国匹配(默认)
true:固定在当前城市 | all |
|location |Object |否 | 定位坐标,传入后,若用户搜索关键词为类别词(如酒店、餐馆时),
与此坐标距离近的地点将靠前显示|all
| |-- lat|Number|纬度 |all |
| |-- lng|Number |经度 |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补全
高德地图为:省+市+区(直辖市为“市+区”) |all |
| |-- children |Array |子地点,当get_subpois=1时返回 |腾讯地图 |
| |-- parent_id|String |主地点ID,对应data中的地点ID |腾讯地图 |
| |-- id |String |地点唯一标识 |腾讯地图 |
| |-- title |String |地点名称 |腾讯地图 |
| |-- address |String |地址 |腾讯地图 |
| |-- category |String |POI(地点)分类 |腾讯地图 |
| |-- location |String |地址 |腾讯地图 |
| |-- lat|Number |纬度 |腾讯地图 |
| |-- lng|Number |经度 |腾讯地图 |
| |-- adcode |String |行政区划代码 |腾讯地图 |
| |-- city |String |地址 |腾讯地图 |
| |-- address |String |地点所在城市名称 |腾讯地图 |
### 地点搜索@search
**功能介绍**
用于搜索周边地点,如,搜索颐和园附近半径500米内的酒店(一个圆形范围)
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.search({
keyword: "酒店",
location: {
lat: 39.908815,
lng: 116.397507
},
radius: 1000,
auto_extend: 1,
get_subpois: 0,
orderby: "weight",
page_index: 1,
page_size: 20,
city: "北京市",
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|keyword |String |是 | 搜索关键字,长度最大80个字节 |all |
|location |Object |是 | 搜索中心点的经纬度 |all |
| |-- lat|Number |是 |纬度 |all |
| |-- lng|Number |是 |经度 |all |
|radius |Number |否 | 搜索半径,单位:米,取值范围:
腾讯地图:10到1000
高德地图:取值范围:0-50000 |all |
|auto_extend |Number |否 | 当前范围无结果时,是否自动扩大范围
0:不扩大
1:自动扩大范围(默认) |all |
|get_subpois |Number |否 | 是否返回子地点,如大厦停车场、出入口等取值
0:不返回(默认)
1:返回 |all |
|orderby |String |否 |排序,支持按距离由近到远排序,取值:
distance:按距离排序
weight:综合排序
说明:
1. 周边搜索默认排序会综合考虑距离、权重等多方面因素
2. 设置按距离排序后则仅考虑距离远近,一些低权重的地点可能因距离近排在前面,导致体验下降|all |
|page\_index |Number |否 | 页码,从1开始,最大页码需通过count进行计算,必须与page_size同时使用 |all |
|page\_size |Number |否 | 每页条数,取值范围1-20,必须与page_index 同时使用 |all |
|filter |String |否 | 筛选条件 |腾讯地图 |
|types |String |否 | 指定地点类型 |高德地图 |
|city |String |否 | 搜索的城市 |高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|data |Array | 搜索结果POI(地点)数组,每项为一个POI(地点)对象 |all |
| |-- id |String |POI(地点)唯一标识 |all |
| |-- title |String |地点名称 |all |
| |-- tel |String |电话 |all |
| |-- address |String |地址 |all |
| |-- category |String |分类 |all |
| |-- type |String |POI类型,值说明:0:普通POI / 1:公交车站 / 2:地铁站 / 3:公交线路 / 4:行政区划 |腾讯地图 |
| |-- location |String |经纬度 |all |
| |-- lat |Number |纬度 |all |
| |-- lng |Number |经度 |all |
| |-- distance |Number |距离,单位: 米,根据传入的定位点计算返回 |all |
| |-- adcode |Number |行政区划代码 |all |
| |-- province |String |省 |腾讯地图 |
| |-- city |String |市 |腾讯地图 |
| |-- district |String |区/县 |腾讯地图 |
| |-- children |Array |子地点,当get_subpois=1时返回 |all |
| |-- parent_id|String |主地点ID,对应data中的地点ID |all |
| |-- id |String |地点唯一标识 |all |
| |-- title |String |地点名称 |all |
| |-- tel |String |电话 |all |
| |-- category |String |POI(地点)分类 |all |
| |-- address |String |地址 |all |
| |-- location |Object |经纬度 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- type |String |POI类型,值说明:0:普通POI / 1:公交车站 / 2:地铁站 / 3:公交线路 / 4:行政区划 |腾讯地图 |
| |-- adcode |String |行政区划代码 |腾讯地图 |
| |-- province |String |省 |腾讯地图 |
| |-- city |String |市 |腾讯地图 |
| |-- district |String |区/县 |腾讯地图 |
### 行政区域查询@districtSearch
**功能介绍**
用于查询四级行政区划列表:省、市、区、街道
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.districtSearch({
adcode: "110101"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|adcode |String |否 | 父级行政区划adcode |all |
|get\_polygon |Number |否 | 返回行政区划轮廓点串(经纬度点串),取值:
0 默认,不返回轮廓
1 包含海域,3公里抽稀粒度
2 纯陆地行政区划,可通过max_offset设置返回轮廓的抽稀级别
注:乡镇/街道(四级)不支持返回轮廓|腾讯地图:0、1、2 高德地图:0、2 |
|max\_offset |Number |否 | 轮廓点串的抽稀精度(仅对get_polygon=2时支持),
单位米,可选值:
100 :100米(当缺省id返回省级区划时,将按500米返回,其它级别正常生效)
500 :500米
1000:1000米
3000:3000米 |腾讯地图 |
|page\_index |Number |否 | 页码,从1开始,最大页码需通过count进行计算,必须与page_size同时使用 |高德地图 |
|page\_size |Number |否 | 每页条数,取值范围1-20,必须与page_index 同时使用 |高德地图 |
|filter |String |否 |按照指定行政区划进行过滤,填入后则只返回该省/直辖市信息
需填入adcode,为了保证数据的正确,强烈建议填入此参数 |高德地图 |
|subdistrict |Number |否 |可选值:
1:返回下一级行政区;
2:返回下两级行政区;
3:返回下三级行政区; |高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|data |Array | 结果数组 |all |
| |-- adcode |String | 行政区划唯一标识 |all |
| |-- name |String |简称,如“内蒙古” 注意:高德地图name = fullname |all |
| |-- fullname |String |全称,如“内蒙古自治区” |all |
| |-- location |String |经纬度 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- pinyin |Array |行政区划拼音,每一下标为一个字的全拼,如:[“nei”,“meng”,“gu”] |腾讯地图 |
| |-- cidx |Array |子级行政区划在下级数组中的下标位置 |腾讯地图 |
| |-- polygon |Array |该行政区划的轮廓经纬度点串(当使用get_polygon=1或2时返回),数组每一项为一个多边形,一个行政区划可以由多块多边形组成
注意:部分城市存在飞地,当两个polygon重叠时,重叠区域隶属其他城市,不重叠时代表此城市的飞地 |腾讯地图 |
| |-- level |Array |行政区划级别 |高德地图 |
| |-- children |Array |下级行政区列表,需传subdistrict参数才会有此值 |高德地图 |
### 路线规划@route
#### 驾车(driving)@drivingroute
**功能介绍**
用于计算从起点到终点驾车的路线以及结合实时路况、少收费、不走高速等多种偏好,精准预估到达时间。
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.route({
mode: "driving",
from: "40.034852,116.319820",
to: "39.771075,116.351395"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|mode |String |是 | 交通方式 固定为:driving |all |
|from |String |是 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 终点位置坐标,格式:lat,lng |all |
|from_poi |String |否 | 起点POI ID,传入后,优先级高于from(坐标) |all |
|to_poi |String |否 | 终点POI ID,传入后,优先级高于to(坐标) |all |
|policy |String |否 | 算路策略 [详情](#drivingroutepolicy) |all |
|waypoints |String |否 | 格式:lat1,lng1;lat2,lng2; |all |
|avoid_polygons |String |否 | 避让区域 |all |
|road_type |Number |否 | [from辅助参数] 起点道路类型[详情](#routeroadtype) |all |
|plate_number |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:返回多方案(最多可返回三条方案供用户备选) |腾讯地图 |
|no_step |Number |否 | 不返回路线引导信息,可使回包数据量更小,
取值:
0:[默认]返回路线引导信息
1:不返回 |腾讯地图 |
|avoidroad |String |否 | 避让道路名,只支持一条避让道路 |高德地图 |
|ferry |Number |否 | 是否使用轮渡
0:使用渡轮
1:不使用渡轮 |高德地图 |
##### 【驾车】方式policy值范围@drivingroutepolicy
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
##### 【驾车】road_type值范围@routeroadtype
0:[默认]不考虑起点道路类型
1:在桥上
2:在桥下
3:在主路
4:在辅路
5:腾讯地图:在对面 高德地图:隧道
6:桥下主路
7:腾讯地图:桥下辅路 高德地图:环岛
9:腾讯地图:不支持 高德地图:停车场内部
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
**驾车(driving)返回参数**
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|routes |Array | 路线方案 |all |
| |-- mode |String |方案交通方式 |all |
| |-- tags |Array |方案标签 |腾讯地图 |
| |-- distance |Number |方案总距离,单位:米 |all |
| |-- traffic\_light\_count |Number |方案途经红绿灯个数 |腾讯地图 |
| |-- restriction_status |Object |限行状态码:
0 途经没有限行城市,或路线方案未涉及限行区域
1 途经包含有限行的城市
3 [设置车牌] 已避让限行
4 [设置车牌] 无法避开限行区域(本方案包含限行路段) |腾讯地图:0、1、3、4 高德地图:0、1|
| |-- polyline |Array |方案路线坐标点串 |腾讯地图 |
| |-- taxi_cost |Number |预估打车费用,单位:元 |all |
| |-- steps |Array |路线步骤 |all |
| |-- instruction |String |阶段路线描述 |all |
| |-- road_name |String |阶段路线路名 |all |
| |-- dir_desc |String |阶段路线方向 |all |
| |-- distance |Number |阶段路线距离,单位:米 |all |
| |-- act_desc |String |阶段路线末尾动作:如:左转调头 |all |
| |-- accessorial_desc |String |末尾辅助动作:如:到达终点 |all |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |all |
| |-- polyline_idx |Array |阶段路线坐标点串在方案路线坐标点串的位置 |腾讯地图 |
| |-- cost |Object |设置后可返回方案所需时间及费用成本 |高德地图 |
| |-- duration |String |线路耗时,分段step中的耗时 |高德地图 |
| |-- tolls |String |此路线道路收费,单位:元,包括分段信息 |高德地图 |
| |-- toll_distance |String |收费路段里程,单位:米,包括分段信息 |高德地图 |
| |-- toll_road |String |主要收费道路 |高德地图 |
| |-- traffic_lights |String |方案中红绿灯个数,单位:个 |高德地图 |
| |-- speed |Array |路况信息,只有设置get_speed=1才会返回 |高德地图 |
| |-- distance |String |距离,单位:米 |高德地图 |
| |-- level |String |路况类型:0:畅通 1:缓行 2:拥堵 3:无路况 4:严重拥堵 |高德地图 |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |高德地图 |
| |-- speed |Array |路况信息,只有设置get_speed=1才会返回 |腾讯地图 |
| |-- distance |String |距离,单位:米 |腾讯地图 |
| |-- level |String |路况类型:0:畅通 1:缓行 2:拥堵 3:无路况 4:严重拥堵 |腾讯地图 |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |腾讯地图 |
| |-- polyline_idx |String |阶段路线坐标点串,在路线坐标点串的位置 |腾讯地图 |
| |-- waypoints |Array |途经点,顺序与输入waypoints一致 (输入waypoints时才会有此结点返回) |腾讯地图 |
| |-- title |String |途经点路名 |腾讯地图 |
| |-- location |Object |途经点坐标: |腾讯地图 |
| |-- lat |Number |纬度 |腾讯地图 |
| |-- lng |Number |经度 |腾讯地图 |
| |-- duration |Number |预估到达耗时,单位:分钟 |腾讯地图 |
| |-- distance |Number |起点到该途经点的距离,单位:米 |腾讯地图 |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |腾讯地图 |
| |-- polyline_idx |Number |该途经点在polyline中的索引位置(数组下标位置) |腾讯地图 |
| |-- cities |Object |途径城市信息 |all |
| |-- adcode |String |途径区域编码 |all |
| |-- citycode |String |途径城市编码 |高德地图 |
| |-- city |String |途径城市名称 |高德地图 |
| |-- district |String |途径区县信息 |高德地图 |
| |-- name |String |途径区县名称 |高德地图 |
| |-- adcode |String |途径区县adcode |高德地图 |
#### 步行(walking)@walkingroute
**功能介绍**
用于计算从起点到终点基于步行路线规划。
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.route({
mode: "walking",
from: "40.034852,116.319820",
to: "39.771075,116.351395"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|mode |String |是 | 交通方式 固定为:walking |all |
|from |String |是 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 终点位置坐标,格式:lat,lng |all |
|to_poi |String |否 | 终点POI ID,传入后,优先级高于to(坐标) |腾讯地图 |
|alternative_route|Number |否 | 1:多备选路线中第一条路线
2:多备选路线中前两条路线
3:多备选路线中三条路线
不传则默认返回一条路线方案|高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
**步行(walking)返回参数**
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|routes |Array | 路线方案 |all |
| |-- mode |String |方案交通方式 |all |
| |-- distance |Number |方案总距离,单位:米 |all |
| |-- duration |Number |方案估算时间,单位:分钟 |all |
| |-- direction |String |方案整体方向 |腾讯地图 |
| |-- polyline |Array |方案路线坐标点串 |腾讯地图 |
| |-- steps |Array |路线步骤 |all |
| |-- instruction |String |阶段路线描述 |all |
| |-- road_name |String |阶段路线路名 |all |
| |-- dir_desc |String |阶段路线方向 |all |
| |-- distance |Number |阶段路线距离,单位:米 |all |
| |-- act_desc |String |阶段路线末尾动作:如:左转调头 |all |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |all |
| |-- type |Number |阶段路线的步行设施类型(type),包含:
0普通道路,1过街天桥,2地下通道,3人行横道|腾讯地图 |
| |-- polyline_idx |Array |阶段路线坐标点串在方案路线坐标点串的位置 |腾讯地图 |
| |-- taxi_cost |Number |预估打车费用,单位:元(此字段不一定会返回) |高德地图 |
| |-- duration |Number |线路耗时,分段step中的耗时,单位:分钟 |高德地图 |
#### 骑行(bicycling)@bicyclingroute
**功能介绍**
用于计算从起点到终点基于自行车的骑行路线规划
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.route({
mode: "bicycling",
from: "40.034852,116.319820",
to: "39.771075,116.351395"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|mode |String |是 | 交通方式 固定为:walking |all |
|from |String |是 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 终点位置坐标,格式:lat,lng |all |
|to_poi |String |否 | 终点POI ID,传入后,优先级高于to(坐标) |腾讯地图 |
|alternative_route|Number |否 | 1:多备选路线中第一条路线
2:多备选路线中前两条路线
3:多备选路线中三条路线
不传则默认返回一条路线方案|高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
**骑行(bicycling)返回参数**
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|routes |Array | 路线方案 |all |
| |-- mode |String |方案交通方式 |all |
| |-- distance |Number |方案总距离,单位:米 |all |
| |-- duration |Number |方案估算时间,单位:分钟 |all |
| |-- direction |String |方案整体方向 |腾讯地图 |
| |-- polyline |Array |方案路线坐标点串 |腾讯地图 |
| |-- steps |Array |路线步骤 |all |
| |-- instruction |String |阶段路线描述 |all |
| |-- road_name |String |阶段路线路名 |all |
| |-- dir_desc |String |阶段路线方向 |all |
| |-- distance |Number |阶段路线距离,单位:米 |all |
| |-- act_desc |String |阶段路线末尾动作:如:左转调头 |all |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |all |
| |-- polyline_idx |Array |阶段路线坐标点串在方案路线坐标点串的位置 |腾讯地图 |
| |-- duration |String |线路耗时,分段step中的耗时 |高德地图 |
#### 电动车(ebicycling)@ebicyclingroute
**功能介绍**
用于计算从起点到终点基于电动自行车的骑行路线规划
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.route({
mode: "ebicycling",
from: "40.034852,116.319820",
to: "39.771075,116.351395"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|mode |String |是 | 交通方式 固定为:ebicycling |all |
|from |String |是 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 终点位置坐标,格式:lat,lng |all |
|to_poi |String |否 | 终点POI ID,传入后,优先级高于to(坐标) |腾讯地图 |
|alternative_route|Number |否 | 1:多备选路线中第一条路线
2:多备选路线中前两条路线
3:多备选路线中三条路线
不传则默认返回一条路线方案|高德地图 |
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
**电动车(ebicycling)返回参数**
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|routes |Array | 路线方案 |all |
| |-- mode |String |方案交通方式 |all |
| |-- distance |Number |方案总距离,单位:米 |all |
| |-- duration |Number |方案估算时间,单位:分钟 |all |
| |-- direction |String |方案整体方向 |腾讯地图 |
| |-- polyline |Array |方案路线坐标点串 |腾讯地图 |
| |-- steps |Array |路线步骤 |all |
| |-- instruction |String |阶段路线描述 |all |
| |-- road_name |String |阶段路线路名 |all |
| |-- dir_desc |String |阶段路线方向 |all |
| |-- distance |Number |阶段路线距离,单位:米 |all |
| |-- act_desc |String |阶段路线末尾动作:如:左转调头 |all |
| |-- polyline |String |分路段坐标点串,格式:lat1,lng1;lat2,lng2 |all |
| |-- polyline_idx |Array |阶段路线坐标点串在方案路线坐标点串的位置 |腾讯地图 |
| |-- duration |Number |线路耗时,分段step中的耗时 |高德地图 |
#### 公交(transit)@transitroute
**功能介绍**
基于公共汽车、地铁、火车等公共交通工具,计算起到终点的路线换乘方案,同时提供少换乘、少步行等偏好设置,支持一次返回多条方案以供用户选择。
**示例**
```js
// 引入uni-map-common公共模块
const UniMap = require('uni-map-common');
// 初始化实例
let uniMap = new UniMap({
provider: "qqmap", // 指定使用哪家地图供应商
key: "xxxxxx"
});
// 调用API
let result = await uniMap.route({
mode: "transit",
from: "40.034852,116.319820",
to: "29.771075,116.351395",
city1: "010",
city2: "0792"
});
console.log("result", result);
```
**请求参数**
|参数 |类型 |必填 |说明 |兼容性 |
|:-- |:-: |:-: |:-- |:-: |
|mode |String |是 | 交通方式 固定为:transit |all |
|from |String |是 | 起点位置坐标,格式:lat,lng |all |
|to |String |是 | 终点位置坐标,格式:lat,lng |all |
|from_poi |String |否 | 起点POI ID,传入后,优先级高于from(坐标) |all |
|to_poi |String |否 | 终点POI ID,传入后,优先级高于to(坐标) |all |
|policy |String |否 | 算路策略 [详情](#transitroutepolicy) |all |
|departure_time |Number |否 | 出发时间,用于过滤掉非运营时段的线路,格式为Unix时间戳,默认使用当前时间 |腾讯地图 |
|ad1 |String |是 | 仅支持adcode |高德地图 |
|ad2 |String |是 | 仅支持adcode |高德地图 |
|city1 |String |是 | 起点所在城市(仅支持citycode,相同时代表同城,不同时代表跨城) |高德地图 |
|city2 |String |是 | 目的地所在城市(仅支持citycode,相同时代表同城,不同时代表跨城) |高德地图 |
|alternative_route|Number |否 | 返回方案条数 最大3条,mode为公交时,最大10条 |高德地图 |
|multiexport |Number |否 | 地铁出入口数量
0:只返回一个地铁出入口
1:返回全部地铁出入口 |高德地图 |
|max_trans |Number |否 | 最大换乘次数 |高德地图 |
|nightflag |Number |否 | 考虑夜班车
0:不考虑夜班车
1:考虑夜班车 |高德地图 |
|date |String |否 | 请求日期 例如:2013-10-28 |高德地图 |
|time |String |否 | 请求时间 例如:9-54 |高德地图 |
##### 【公交】方式policy值范围@transitroutepolicy
0:默认模式
1:最经济模式,票价最低
2:最少换乘模式,换乘次数少
3:最少步行模式,尽可能减少步行距离
4:最舒适模式,尽可能乘坐空调车
5:不乘地铁模式,不乘坐地铁路线
6:地铁图模式,起终点都是地铁站(地铁图模式下originpoi及destinationpoi为必填项)
7:地铁优先模式,步行距离不超过4KM
8:时间短模式,方案花费总时间最少
注意:高德地图支持所有策略,腾讯地图只支持 0、2、3、5、6、7
**返回参数**
仅列出result内的参数,其他参数见 [公共返回参数](#publicresult)
**公交(transit)返回参数**
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|routes |Array | 路线方案 |all |
| |-- mode |String |方案交通方式 |all |
| |-- distance |Number |方案总距离,单位:米 |all |
| |-- duration |Number |方案估算时间,单位:分钟 |all |
| |-- bounds |Number |整体路线的外接矩形范围,可在地图显示时使用
通过矩形西南+东北两个端点坐标定义而面
示例:“39.901405,116.334023,39.940289,116.451720” |腾讯地图 |
| |-- transit_fee |Number |各换乘方案总花费,单位:元 |高德地图 |
| |-- steps |Array |一条完整公交路线可能会包含多种公共交通工具,
各交通工具的换乘由步行路线串联起来,
形成这样的结构(即 steps数组的结构):
[步行 , 公交 , 步行 , 公交 , 步行(到终点)]|all |
| |-- mode |String |本段交通方式,取值:
walking:步行
transit:公共交通工具
不同的方式,返回不同的数据结构,须根据该参数值来判断以哪种结构进行解析,各类具体定义见下文 |all |
| |-- 其它字段 |-- |随mode不同有不同字段返回,见下文 |all |
公交方式包含步行+公共交通混合
以下是交通方式 - 步行 - 响应结果
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
| mode |String | 交通方式,固定值:walking |all |
| distance |Number |本段step距离,单位:米 |all |
| duration |Number |估算时间,单位:分钟 |all |
| direction |String |方案整体方向描述,如:“南” |腾讯地图 |
| polyline |Array |路线坐标点串,可用于在地图中绘制路线 |腾讯地图 |
|steps |Array |分路段导航信息 |all |
| |-- instruction |String |阶段路线描述 |all |
| |-- road_name |String |阶段路线路名 |all |
| |-- dir_desc |String |阶段路线方向 |all |
| |-- distance |Number |阶段路线距离,单位:米 |all |
| |-- act_desc |String |阶段路线末尾动作:如:左转调头 |all |
| |-- polyline_idx |Array |阶段路线坐标点串在方案路线坐标点串的位置 |腾讯地图 |
响应结果 - 交通方式 - 公共交通(transit)
本段为公共交通方式的对象结构,对应steps[]数组下的子对象(“mode”:“transit”)
1. 交通工具 - 公共汽车(“vehicle”:“BUS”):
本段为公共交通的子对象,vehicle属性值为"BUS"
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|mode |String | 交通方式,固定值:transit |all |
|lines |Array | lines线路信息|all |
| |-- vehicle |String |交通工具:公交车(BUS) |all |
| |-- id |String |线路唯一标识 |all |
| |-- title |String |线路名称 |all |
| |-- station_count |Number |经停站数 |all |
| |-- distance |Number |路线距离,单位:米 |all |
| |-- duration |Number |路线估算时间,单位:分钟 |all |
| |-- polyline |Array |线路坐标点串,可用于在地图中绘制路线 |all |
| |-- start_time |String |首班车时间 |all |
| |-- end_time |String |末班车时间 |all |
| |-- geton |Object |上车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- getoff |Object |下车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- stations |Array |经停站列表 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- running_status |Number |线路运营状态,取值范围:
300:正常
301:可能错过末班车
302:首班车还未发出
303:停运 |腾讯地图 |
| |-- price |Number |预估费用,单位:分,返回-1时为缺少票价信息 |腾讯地图 |
| |-- destination |Object |公交终点站(用于指示方向) |腾讯地图 |
| |-- id |String |站点唯一标识 |腾讯地图 |
| |-- title |String |终点站名 |腾讯地图 |
| |-- type |String |公交类型 |高德地图 |
2. 交通工具 - 地铁(“vehicle”:“SUBWAY”):
本段为公共交通的子对象,vehicle属性值为"SUBWAY"
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|mode |String | 交通方式,固定值:transit |all |
|lines |Array | lines线路信息 |all |
| |-- vehicle |String |交通工具:地铁(SUBWAY) |all |
| |-- id |String |线路唯一标识 |all |
| |-- title |String |线路名称 |all |
| |-- station_count |Number |经停站数 |all |
| |-- running_status |Number |线路运营状态,取值范围:
300:正常
301:可能错过末班车
302:首班车还未发出
303:停运 |腾讯地图 |
| |-- price |Number |预估费用,单位:分,返回-1时为缺少票价信息 |腾讯地图 |
| |-- distance |Number |路线距离,单位:米 |all |
| |-- duration |Number |路线估算时间,单位:分钟 |all |
| |-- polyline |Array |线路坐标点串,可用于在地图中绘制路线 |all |
| |-- destination |Object |公交终点站(用于指示方向) |腾讯地图 |
| |-- id |String |站点唯一标识 |腾讯地图 |
| |-- title |String |终点站名 |腾讯地图 |
| |-- start_time |String |首班车时间 |腾讯地图 |
| |-- end_time |String |末班车时间 |腾讯地图 |
| |-- geton |Object |上车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat |Number |纬度 |all |
| |-- lng |Number |经度 |all |
| |-- exit |Object |出入口 |腾讯地图 |
| |-- id |String |唯一标识 |腾讯地图 |
| |-- title|String |出入口名称 |腾讯地图 |
| |-- getoff |Object |下车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat |Number |纬度 |all |
| |-- lng |Number |经度 |all |
| |-- exit |Object |站点经纬度坐标 |腾讯地图 |
| |-- id |String |唯一标识 |腾讯地图 |
| |-- title|String |出入口名称 |腾讯地图 |
| |-- stations |Array |经停站列表 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat |Number |纬度 |all |
| |-- lng |Number |经度 |all |
3. 交通工具 - 火车(“vehicle”:“RAIL”):
本段为公共交通的子对象,vehicle属性值为"RAIL"
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|mode |String | 交通方式,固定值:transit |all |
|lines |Array | lines线路信息 |all |
| |-- vehicle |String |交通工具:地铁(RAIL) |all |
| |-- title |String |车次名称 |all |
| |-- station_count |Number |经停站数 |腾讯地图 |
| |-- running_status |Number |线路运营状态,取值范围:
300:正常
301:可能错过末班车
302:首班车还未发出
303:停运 |腾讯地图 |
| |-- price |Number |预估费用,单位:分,返回-1时为缺少票价信息 |腾讯地图 |
| |-- distance |Number |路线距离,单位:米 |all |
| |-- duration |Number |路线估算时间,单位:分钟 |all |
| |-- departure_time |String |发车时间 |腾讯地图 |
| |-- arrival_time |String |到达时间 |腾讯地图 |
| |-- days_count |Number |耗时天数,1为当天到达,2为隔天到达,以此类推 |腾讯地图 |
| |-- polyline |Array |线路坐标点串,可用于在地图中绘制路线 |腾讯地图 |
| |-- destination |Object |公交终点站(用于指示方向) |腾讯地图 |
| |-- id |String |站点唯一标识 |腾讯地图 |
| |-- title |String |终点站名 |腾讯地图 |
| |-- geton |Object |上车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |腾讯地图 |
| |-- adcode |String |上车站点所在城市的adcode |高德地图 |
| |-- time |String |上车点发车时间 |高德地图 |
| |-- start |Number |是否始发站,1表示为始发站,0表示非始发站 |高德地图 |
| |-- getoff |Object |下车站 |all |
| |-- id |String |站点唯一标识 |all |
| |-- title |String |终点站名 |all |
| |-- location |Object |站点经纬度坐标 |all |
| |-- lat|Number |纬度 |all |
| |-- lng|Number |经度 |all |
| |-- adcode |String |上车站点所在城市的adcode |高德地图 |
| |-- time |String |上车点发车时间 |高德地图 |
| |-- end |Number |是否为终点站,1表示为终点站,0表示非终点站 |高德地图 |
| |-- stations |Array |经停站列表 |腾讯地图 |
| |-- id |String |站点唯一标识 |腾讯地图 |
| |-- title |String |终点站名 |腾讯地图 |
| |-- location |Object |站点经纬度坐标 |腾讯地图 |
| |-- lat|Number |纬度 |腾讯地图 |
| |-- lng|Number |经度 |腾讯地图 |
| |-- spaces |Object |仓位及价格信息 |高德地图 |
| |-- code |String |仓位编码 |高德地图 |
| |-- cost |String |仓位费用 |高德地图 |
3. 交通工具 - 出租车(“vehicle”:“TAXI”):
本段为公共交通的子对象,vehicle属性值为"TAXI"(仅高德地图支持"TAXI")
|参数 |类型 |说明 |兼容性 |
|:-- |:-: |:-- |:-: |
|mode |String | 交通方式,固定值:transit |高德地图 |
|lines |Array | lines线路信息 |高德地图 |
| |-- vehicle |String |交通工具:地铁(TAXI) |高德地图 |
| |-- price |String |预估费用,单位:元,返回-1时为缺少票价信息 |高德地图 |
| |-- drivetime |Number |打车预计花费时间,单位:分 |高德地图 |
| |-- distance |Number |打车距离,单位:米 |高德地图 |
| |-- polyline |String |线路点集合 |高德地图 |
| |-- startpoint |String |打车起点经纬度 |高德地图 |
| |-- startname |String |打车起点名称 |高德地图 |
| |-- endpoint |String |打车终点经纬度 |高德地图 |
| |-- endname |String |打车终点名称 |高德地图 |
## 全局错误码@errorcode
| 错误模块 | 错误码 | 说明 |
|:-- |:--: |:-- |
| uni-map-common | 110 | 请求来源未被授权 |
| uni-map-common | 111 | 签名验证失败 |
| uni-map-common | 112 | IP未被授权 |
| uni-map-common | 113 | 此功能未被授权 |
| uni-map-common | 120 | 此key每秒请求量已达到上限 |
| uni-map-common | 121 | 此key每日调用量已达到上限 |
| uni-map-common | 122 | ip访问超限 |
| uni-map-common | 123 | 账号访问限制(如余额不足) |
| uni-map-common | 160 | sig参数不支持此请求类型 |
| uni-map-common | 161 | sig参数不支持和非object的POST JSON一起使用 |
| uni-map-common | 190 | 无效的KEY |
| uni-map-common | 199 | 此key未开启webservice功能 |
| uni-map-common | 301 | 缺少必要字段key |
| uni-map-common | 311 | key格式错误 |
| uni-map-common | 300 | 缺少必要字段 |
| uni-map-common | 306 | 缺少参数 |
| uni-map-common | 311 | 服务不支持https请求 |
| uni-map-common |320 |参数数据类型错误 |
| uni-map-common |330 |参数长度错误 |
| uni-map-common |351 |存在不共存的参数 |
| uni-map-common |324 |get和post中的同一参数值不相同 |
| uni-map-common |326 |起终点距离过近 |
| uni-map-common |327 |附近无公交站 |
| uni-map-common |328 |无可达公交路线 |
| uni-map-common |329 |无可达火车路线 |
| uni-map-common |331 |查询条件过长 |
| uni-map-common |332 |途径点个数超过限制 |
| uni-map-common |333 |存在无法吸附的坐标点 |
| uni-map-common |335 |不支持该城市的公交查询 |
| uni-map-common |341 |缺少keyword(关键词) |
| uni-map-common |344 |附近无火车站(公交) |
| uni-map-common |347 |查询无结果 |
| uni-map-common |348 |参数错误 |
| uni-map-common |364 |是否扩大搜索参数只能为0或1 |
| uni-map-common |365 |纬度不能超过±90 |
| uni-map-common |366 |经度不能超过±180 |
| uni-map-common |373 |起终点距离超长 |
| uni-map-common |374 |起终点坐标错误 |
| uni-map-common |375 |局域网IP无法定位 |
| uni-map-common |377 |提供的起终点无法规划出导航线路 |
| uni-map-common |378 |提供的起终点无法规划出步行线路 |
| uni-map-common |379 |提供的起终点无法规划出公交线路 |
| uni-map-common |380 |坐标类型必须在有坐标的情况下使用 |
| uni-map-common |382 |IP无法定位 |
| uni-map-common |384 |提供的起终点无法规划出骑行线路 |
| uni-map-common |387 |没有对应的POI |
| uni-map-common |393 |没有符合条件的数据 |
| uni-map-common |394 |错误的查询条件 |
| uni-map-common |395 |传入参数不合法 |
| uni-map-common |396 |最多支持200个坐标点,且起终点数目乘积最多为625(距离矩阵) |
| uni-map-common |397 |一对多最多支持200个坐标点,多对多最多支持25个坐标点且起终点数目乘积最多为625(距离矩阵) |
| uni-map-common |500 |服务响应失败 |
## 常见问题
### 使用uni-map-common后,我还需要购买5万元的地图商业授权费用吗?
答:使用地图服务需要商业授权,可联系DCloud申请折扣优惠。详情参考 [商业授权相关说明](https://uniapp.dcloud.net.cn/tutorial/app-geolocation.html#lic)