Skip to content

AssociativeLine 插件

v0.4.5+

调整关联线控制点的功能从v0.4.6+开始支持

关联性支持文本编辑从v0.5.11+开始支持

该插件用于支持添加关联线。

配置请参考实例化选项

注册

js
import MindMap from 'simple-mind-map'
import AssociativeLine from 'simple-mind-map/src/plugins/AssociativeLine.js'
// import AssociativeLine from 'simple-mind-map/src/AssociativeLine.js' v0.6.0以下版本使用该路径

MindMap.usePlugin(AssociativeLine)

注册完且实例化MindMap后可通过mindMap.associativeLine获取到该实例。

配置

支持修改关联线的粗细和颜色,分为默认状态和激活状态。配置如下:

  • associativeLineWidth:关联线默认状态的粗细,默认值为2

  • associativeLineColor:关联线默认状态的颜色,默认值为rgb(51, 51, 51)

  • associativeLineActiveWidth:关联线激活状态的粗细,默认值为8

  • associativeLineActiveColor:关联线激活状态的颜色,默认值为rgba(2, 167, 240, 1)

  • associativeLineDasharray:关联线的线条样式,默认值为[6, 4]

  • associativeLineTextColor:关联线文字颜色,默认值为rgb(51, 51, 51)

  • associativeLineTextFontSize:关联线文字大小,默认值为14

  • associativeLineTextLineHeight:关联线文字行高,默认值为1.2

  • associativeLineTextFontFamily:关联线文字字体,默认值为微软雅黑, Microsoft YaHei

配置以主题的方式提供,以上默认值为默认主题的值,不同的主题可能不一样,所以如果想要修改这四个属性,可以通过mindMap.setThemeConfig(config)方法进行修改。

属性

mindMap.associativeLine.lineList

当前所有连接线数据,数组类型,数组的每一项也是一个数组:

js
[
    path, // 连接线节点
    clickPath, // 不可见的点击线节点
    text, // 文本对象
    node, // 起始节点
    toNode // 目标节点
]

mindMap.associativeLine.activeLine

当前激活的连接线,数组类型,结构如下:

js
[
    path, // 连接线节点
    clickPath, // 不可见的点击线节点
    text, // 文本对象
    node, // 起始节点
    toNode, // 目标节点
    markerPath// v0.12.2+,箭头对象
]

方法

getStyleConfig(node, toNode)

v0.12.2+

  • node:关联线起始节点实例

  • toNode:关联线目标节点实例

返回值:关联线的样式数据对象。

获取某条关联线的样式数据。

优先级:关联线自定义样式、节点自定义样式、主题的节点层级样式、主题的最外层样式。

如果你开发了一个设置某条关联线样式的视图后,一般需要回显某个关联线当前的样式,那么可以通过该方法来获取。官方demo代码实现参考:AssociativeLineStyle.vue

updateActiveLineStyle()

v0.12.2+

更新当前激活连线的样式,一般在自定义了节点关联线的样式后调用。

直接调用node.setStyle方法更新样式也会触发关联线的样式更新,但是关联线的激活状态会丢失。所以如果想保留激活状态的话,可以调用node.setData方法更新数据,然后再调用该方法更新样式,这样关联线激活状态不会丢失。官方demo代码实现参考:AssociativeLineStyle.vue

cancelCreateLine()

v0.10.5+

中途取消创建关联线。

renderAllLines()

重新渲染所有关联线。

removeAllLines()

移除所有关联线。

createLineFromActiveNode()

从当前激活节点开始创建关联线,如果有多个激活节点,默认为第一个节点。

调用该方法后,会从第一个激活节点到当前鼠标实时位置渲染一条关联线,当点击某个目标节点后则代表创建完成,会在第一个激活节点和点击节点之间渲染一条关联线。

createLine(fromNode)

从指定节点开始创建关联线。

调用该方法后,会从指定节点到当前鼠标实时位置渲染一条关联线,当点击某个目标节点后则代表创建完成,会在指定节点和点击节点之间渲染一条关联线。

addLine(fromNode, toNode)

直接添加一条关联线。

调用该方法,会直接创建一条从fromNodetoNode节点的关联线。

removeLine()

删除当前激活的关联线。点击某条关联线则视为激活。

clearActiveLine()

清除当前激活的关联线的激活状态。

front()

v0.8.0+

关联线顶层显示。

back()

v0.8.0+

关联线回到原有层级。

MIT License.