logo

X6

  • 文档
  • API
  • 图表示例
  • 常见问题
  • 更新日志
  • XFlow
  • 所有产品antv logo arrow
  • 2.x
  • 简介
  • 快速上手
  • 基础
    • 画布
    • 节点
    • 边
    • 连接桩
    • 交互
    • 事件
    • 数据
  • 进阶
    • 连接点
    • 工具
    • 群组
    • React 节点
    • Vue 节点
    • Angular 节点
    • HTML 节点
  • 插件
    • 图形变换
    • 对齐线
    • 复制粘贴
    • 快捷键
    • 撤销重做
    • 框选
    • 滚动画布
    • 小地图
    • Dnd
    • Stencil
    • 导出
  • 升级到 2.x 版本
  • 开发者工具

对齐线

上一篇
图形变换
下一篇
复制粘贴

Resources

Ant Design
Galacea Effects
Umi-React 应用开发框架
Dumi-组件/文档研发工具
ahooks-React Hooks 库

社区

体验科技专栏
seeconfSEE Conf-蚂蚁体验科技大会

帮助

GitHub
StackOverflow

more products更多产品

Ant DesignAnt Design-企业级 UI 设计语言
yuque语雀-知识创作与分享工具
EggEgg-企业级 Node 开发框架
kitchenKitchen-Sketch 工具集
GalaceanGalacean-互动图形解决方案
xtech蚂蚁体验科技
© Copyright 2025 Ant Group Co., Ltd..备案号:京ICP备15032932号-38

Loading...

在本章节中主要介绍对齐线插件相关的知识,通过阅读你可以了解到

  • 如何在画布中使用对齐线

使用

对齐线是移动节点排版的辅助工具,我们提供了一个独立的插件包 @antv/x6-plugin-snapline 来使用这个功能。

# npm
$ npm install @antv/x6-plugin-snapline --save
# yarn
$ yarn add @antv/x6-plugin-snapline

然后我们在代码中这样使用:

import { Snapline } from '@antv/x6-plugin-snapline'
const graph = new Graph({
background: {
color: '#F2F7FA',
},
})
graph.use(
new Snapline({
enabled: true,
}),
)

演示

Snapline Settings
Tolerance
10

配置

属性名类型默认值必选描述
classNamestring-附加样式名,用于定制对齐线样式
tolerancenumber10对齐精度,即移动节点时与目标位置的距离小于 tolerance 时触发显示对齐线
sharpbooleanfalse是否显示截断的对齐线
resizingbooleanfalse改变节点大小时是否触发对齐线
cleanbooleantrue如果为 true,则在 3s 后清除对齐线,为 false,不会清除,如果为数字(ms),则在指定时间后清除对齐线
filterFilter-节点过滤器

上面的 Filter 类型比较复杂,支持以下三种类型:

  • string[]: 节点 shape 数组,指定的节点 shape 才会参与对齐计算
  • ({ id: string })[]: 节点 ID 数组,指定的节点才会参与对齐计算
  • (this: Graph, node: Node) => boolean: 返回 true 的节点才参与对齐计算

API

graph.isSnaplineEnabled()

isSnaplineEnabled(): boolean

返回是否启用对齐线。

graph.enableSnapline()

enableSnapline(): this

启用对齐线。

graph.disableSnapline()

disableSnapline(): this

禁用对齐线。

graph.toggleSnapline(...)

toggleSnapline(enabled?: boolean): this

切换对齐线的启用状态。参数如下:

名称类型必选默认值描述
enabledboolean-是否启用对齐线,缺省时切换对齐线的启用状态。

graph.hideSnapline()

hideSnapline(): this

隐藏对齐线。

graph.isSnaplineOnResizingEnabled()

isSnaplineOnResizingEnabled(): boolean

调整节点大小时,是否触发对齐线。

graph.enableSnaplineOnResizing()

enableSnaplineOnResizing(): this

启用调整节点大小过程中触发对齐线。

graph.disableSnaplineOnResizing()

disableSnaplineOnResizing(): this

禁用调整节点大小过程中触发对齐线。

graph.toggleSnaplineOnResizing(...)

toggleSnaplineOnResizing(enabled?: boolean): this

切换调整节点大小过程中是否触发对齐线。参数如下:

名称类型必选默认值描述
enabledboolean-是否启用对齐线,缺省时切换对齐线的启用状态。

graph.isSharpSnapline()

isSharpSnapline(): boolean

是否使用短款对齐线。

graph.enableSharpSnapline()

enableSharpSnapline(): this

启用短款对齐线,启用后对齐线只显示到相关节点位置处,否则显示贯穿画布的对齐线。

graph.disableSharpSnapline()

disableSharpSnapline(): this

禁用短款对齐线,对齐线将贯穿整个画布。

graph.toggleSharpSnapline()

toggleSharpSnapline(enabled?: boolean): this

切换短款对齐线的启用状态。参数如下:

名称类型必选默认值描述
enabledboolean-是否启用短款对齐线,缺省时切换短款对齐线的启用状态。

graph.getSnaplineTolerance()

getSnaplineTolerance(): number

获取对齐线精度。

graph.setSnaplineTolerance(...)

setSnaplineTolerance(tolerance: number): this

设置对齐线精度。

graph.setSnaplineFilter(...)

setSnaplineFilter(
filter?:
| null
| (string | { id: string })[]
| ((this: Graph, node: Node) => boolean)
): this

设置过滤条件,满足过滤条件的节点才会参与对齐线计算。