AssociativeLine 插件
v0.4.5+
调整关联线控制点的功能从v0.4.6+开始支持
关联性支持文本编辑从v0.5.11+开始支持
该插件用于支持添加关联线。
配置请参考实例化选项。
注册
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
当前所有连接线数据,数组类型,数组的每一项也是一个数组:
[
path, // 连接线节点
clickPath, // 不可见的点击线节点
text, // 文本对象
node, // 起始节点
toNode // 目标节点
]
mindMap.associativeLine.activeLine
当前激活的连接线,数组类型,结构如下:
[
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)
直接添加一条关联线。
调用该方法,会直接创建一条从fromNode
到toNode
节点的关联线。
removeLine()
删除当前激活的关联线。点击某条关联线则视为激活。
clearActiveLine()
清除当前激活的关联线的激活状态。
front()
v0.8.0+
关联线顶层显示。
back()
v0.8.0+
关联线回到原有层级。