2018-06-05 23:58:10 +08:00
|
|
|
/**
|
|
|
|
* @fileOverview 图分析模版
|
|
|
|
* @author huangtonger@aliyun.com
|
2018-07-23 11:39:20 +08:00
|
|
|
* read only:
|
|
|
|
* edge.isTreeEdge
|
|
|
|
* read && write:
|
|
|
|
* node.rank - node rank the max rank would be the root node
|
|
|
|
* edge.weight - edge weight
|
2018-06-05 23:58:10 +08:00
|
|
|
*/
|
2018-06-14 11:50:35 +08:00
|
|
|
const G6 = require('@antv/g6');
|
2018-06-05 23:58:10 +08:00
|
|
|
const maxSpanningForest = require('./maxSpanningForest');
|
2018-07-10 15:16:54 +08:00
|
|
|
const Layout = require('../layout.forceAtlas2/layout');
|
2018-06-05 23:58:10 +08:00
|
|
|
const Util = G6.Util;
|
|
|
|
|
|
|
|
class Plugin {
|
|
|
|
constructor(options) {
|
|
|
|
Util.mix(this, {
|
2018-07-19 14:45:41 +08:00
|
|
|
layout: {
|
|
|
|
auto: 'once', // true false once
|
|
|
|
processer: new Layout({
|
2018-07-23 11:39:20 +08:00
|
|
|
kr: 120,
|
2018-07-19 14:45:41 +08:00
|
|
|
kg: 8.0,
|
|
|
|
mode: 'common',
|
|
|
|
prev_overlapping: true,
|
|
|
|
dissuade_hubs: false,
|
|
|
|
max_iteration: 1000,
|
|
|
|
barnes_hut: true,
|
|
|
|
ks: 0.1,
|
|
|
|
ksmax: 10,
|
|
|
|
tao: 0.1,
|
|
|
|
...options
|
|
|
|
})
|
|
|
|
},
|
2018-06-05 23:58:10 +08:00
|
|
|
...options
|
|
|
|
});
|
|
|
|
}
|
|
|
|
init() {
|
|
|
|
const graph = this.graph;
|
|
|
|
graph.on('beforeinit', () => {
|
|
|
|
const layout = graph.get('layout');
|
|
|
|
if (!layout) {
|
|
|
|
graph.set('layout', this.layout);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
graph.on('beforerender', () => {
|
|
|
|
const data = graph.getSource();
|
2018-07-23 11:39:20 +08:00
|
|
|
let {
|
2018-07-10 11:08:57 +08:00
|
|
|
nodes,
|
|
|
|
edges
|
|
|
|
} = data;
|
2018-07-23 11:39:20 +08:00
|
|
|
nodes = nodes.map((node, index) => {
|
|
|
|
return {
|
|
|
|
...node,
|
|
|
|
index
|
|
|
|
};
|
|
|
|
});
|
|
|
|
edges = edges.map((edge, index) => {
|
|
|
|
return {
|
|
|
|
...edge,
|
|
|
|
index
|
|
|
|
};
|
|
|
|
});
|
2018-06-05 23:58:10 +08:00
|
|
|
const forest = maxSpanningForest(nodes, edges);
|
|
|
|
forest.edges.forEach(edge => {
|
2018-07-23 11:39:20 +08:00
|
|
|
const { index } = edge;
|
|
|
|
data.edges[index].isTreeEdge = true;
|
2018-06-05 23:58:10 +08:00
|
|
|
});
|
|
|
|
graph.addFilter(item => {
|
|
|
|
return !item.isEdge || item.getModel().isTreeEdge;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
G6.Plugins['template.maxSpanningForest'] = Plugin;
|
|
|
|
|
|
|
|
module.exports = Plugin;
|