线路图层(PathLayer)
示例
公交线路可视化Demo Baidu数据,有偏
示例源码
vue
<template>
<div style="height: 400px">
<mb-map :zoom="8" :pitch="40">
<mb-path-layer
:data="__RESOURCE_URL__ + 'json/beijing-bus-lines.json'"
:get-path="getPath"
:get-width="100"
/>
</mb-map>
</div>
</template>
<script setup lang="ts">
const getPath = (data) => {
let prevPt
const points: number[][] = []
for (let i = 0; i < data.length; i += 2) {
let pt = [data[i], data[i + 1]]
if (i > 0) {
pt = [prevPt[0] + pt[0], prevPt[1] + pt[1]]
}
prevPt = pt
points.push([pt[0] / 1e4, pt[1] / 1e4])
}
return points
}
</script>API
PROPS
| 名称 | 描述 | 类型 | 默认值 |
|---|---|---|---|
| id | 图层Id | string | - |
| auto-highlight | 本属性为true且pickable为true时,则会将鼠标悬浮选中的对象设为高亮 | boolean | false |
| data | 图层源数据 | string / IndexAny / AnyArr / Promise<any> | '' |
| get-color | 颜色信息 | string / AnyFunc / number[] | black |
| get-path | 路径信息 | AnyFunc | object => object.path |
| get-width | 宽度信息 | number / AnyNumberFunc | 100 |
| highlight-color | 要与高亮对象原始颜色进行混合(blend)的颜色值 | string / number[] | [255, 255, 128, 1] |
| highlighted-object-index | 高亮元素序号 | number | -1 |
| miter-limit | rounded为false时生效 | number | 4 |
| cap-rounded | - | boolean | false |
| joint-rounded | - | boolean | false |
| opacity | 透明度 | number | 1 |
| pickable | 图层是否会响应鼠标事件,若为false,则组件不会emit鼠标相关事件 | boolean | false |
| show | 是否显示 | boolean | true |
| width-max-pixels | - | number | Number.MAX_SAFE_INTEGER |
| width-min-pixels | - | number | 0 |
| width-scale | - | number | 1 |
| width-units | - | string(pixels / meters) | meters |
EVENTS
| 名称 | 描述 | 参数 |
|---|---|---|
| created | 初始化完成事件 | - |
| mousemove | - | { object: any; coordinates: mapboxgl.LngLat; pixel: [number, number] } |
| mouseleave | - | - |
| click | - | { object: any; coordinates: mapboxgl.LngLat; pixel: [number, number] } |
SLOTS
| 名称 | 描述 |
|---|
METHODS
| 名称 | 描述 | 定义 |
|---|
