X6 默认提供了以下几种路由:
路由名称 | 说明 |
---|---|
normal | 默认路由,原样返回路径点 |
orth | 正交路由,由水平或垂直的正交线段组成 |
oneSide | 受限正交路由,由受限的三段水平或垂直的正交线段组成 |
manhattan | 智能正交路由,由水平或垂直的正交线段组成,并自动避开路径上的其他节点(障碍) |
metro | 智能地铁线路由,由水平或垂直的正交线段和斜角线段组成,类似地铁轨道图,并自动避开路径上的其他节点(障碍) |
er | 实体关系路由,由 Z 字形的斜角线段组成 |
系统的默认路由,该路由原样返回传入的 vertices
路径点。
正交路由,该路由在路径上添加额外的一些点,使边的每一条线段都水平或垂直正交。
支持的参数如下表:
参数名 | 参数类型 | 是否必选 | 默认值 | 参数说明 |
---|---|---|---|---|
padding | SideOptions | 否 | 20 | 设置锚点距离转角的最小距离 |
SideOptions
定义如下:
export type SideOptions =
| number
| {
vertical?: number
horizontal?: number
left?: number
top?: number
right?: number
bottom?: number
}
例如:
graph.addEdge({
source,
target,
vertices: [
{ x: 100, y: 200 },
{ x: 300, y: 120 },
],
router: {
name: 'orth',
args: {
padding: {
left: 50,
},
},
},
})
以下是效果图
oneSide
路由是正交路由 orth
的受限版本,该路生成一个严格的三段路由:从起始节点的 side
侧开始,经过中间段,再从终止节点的 side
侧结束路由。需要特别注意的是,使用该路由时请不要同时指定 vertices
,否则路由效果会非常差
支持的参数如下表:
参数名 | 参数类型 | 是否必选 | 默认值 | 参数说明 |
---|---|---|---|---|
side | 'left' | 'right' | 'top' | 'bottom' |
否 | 'bottom' |
路由的起始/结束方向,默认值为 'bottom' |
padding | SideOptions | 否 | 20 | 设置锚点距离转角的最小距离 |
例如:
graph.addEdge({
source,
target,
router: {
name: 'oneSide',
args: { side: 'right' },
},
})
以下是效果图
manhattan
路由是正交路由 orth
的智能版本,该路由由水平或垂直的正交线段组成,并自动避开路径上的其他节点(障碍)。支持的参数如下表:
参数名 | 参数类型 | 是否必选 | 默认值 | 参数说明 |
---|---|---|---|---|
step | number | 否 | 10 | 路由算法步进步长,其值越小计算量越大,推荐使用画布的网格大小 |
excludeTerminals | (‘source’ | ‘target’)[] | 否 | [] | 忽略起始或终止节点,忽略后不参与障碍物计算 |
excludeShapes | string[] | 否 | [] | 忽略指定形状的节点,忽略后不参与障碍物计算 |
excludeNodes | (Node | string)[] | 否 | [] | 忽略的节点,忽略后不参与障碍物计算忽略的节点,忽略后不参与障碍物计算 |
startDirections | string[] | 否 | [‘top’, ‘right’, ‘bottom’, ‘left’] | 支持从哪些方向开始路由 |
endDirections | string[] | 否 | [‘top’, ‘right’, ‘bottom’, ‘left’] | 支持从哪些方向结束路由 |
padding | SideOptions | 否 | - | 设置锚点距离转角的最小距离 |
例如:
graph.addEdge({
source,
target,
router: {
name: 'manhattan',
args: {
startDirections: ['top'],
endDirections: ['bottom'],
},
},
})
以下是效果图
地铁路由 metro
是曼哈顿路由 manhattan
的一个变种,它由水平或垂直的正交线段和斜角线段组成,类似地铁轨道图,并自动避开路径上的其他节点(障碍)。其选项与 manhattan
一样,但 maxDirectionChange
的默认值为 45,表示路由线段的最大倾斜角度为 45 度。
例如:
graph.addEdge({
source,
target,
router: {
name: 'metro',
args: {
startDirections: ['top'],
endDirections: ['bottom'],
},
},
})
以下是效果图
实体关系路由 er
由 Z 字形的斜角线段组成,常用于表示 ER 图中的实体之间的连线。
支持的参数如下表:
参数名 | 参数类型 | 是否必选 | 默认值 | 参数说明 |
---|---|---|---|---|
offset | number |‘center’ | 否 | 32 | 路由的第一个点和最后一个点与节点之间的距离。当取值为 'center' 时,节点距离的中心作为路由点坐标 |
min | number | 否 | 16 | 路由的第一个点和最后一个点与节点之间的最小距离 |
direction | ‘T’|‘B’|‘L’|‘R’|‘H’|‘V’ | 否 | - | 路由方向,缺省时将自动选择最优方向 |
例如:
graph.addEdge({
source,
target,
router: {
name: 'er',
args: {
offset: 24,
},
},
})
以下是效果图
除了内置路由,还可以按照一定规则来创建自定义路由,例如,实现随机的路由:
// 路由参数
interface RandomRouterArgs {
bounces?: number
}
function randomRouter(
vertices: Point.PointLike[],
args: RandomRouterArgs,
view: EdgeView,
) {
const bounces = args.bounces || 20
const points = vertices.map((p) => Point.create(p))
for (var i = 0; i < bounces; i++) {
const sourceCorner = view.sourceBBox.getCenter()
const targetCorner = view.targetBBox.getCenter()
const randomPoint = Point.random(
sourceCorner.x,
targetCorner.x,
sourceCorner.y,
targetCorner.y,
)
points.push(randomPoint)
}
return points
}
Graph.registerRouter('random', randomRouter)
edge.setRouter('random', { bounces: 3 })
以下是效果图