mirror of
https://gitee.com/antv/g6.git
synced 2024-12-15 18:11:08 +08:00
119 lines
2.9 KiB
JavaScript
119 lines
2.9 KiB
JavaScript
import G6 from '@antv/g6';
|
|
|
|
const data = {
|
|
nodes: [
|
|
{
|
|
id: 'donut',
|
|
label: 'Donut',
|
|
x: 250,
|
|
y: 150,
|
|
// the attributes for drawing donut
|
|
donutAttrs: {
|
|
prop1: 10,
|
|
prop2: 20,
|
|
prop3: 25
|
|
},
|
|
// the color map for drawing donut
|
|
donutColorMap: {
|
|
prop1: '#8eaade',
|
|
prop2: '#5c7cb8',
|
|
prop3: '#1e3f7d'
|
|
},
|
|
},
|
|
],
|
|
};
|
|
|
|
const width = document.getElementById('container').scrollWidth;
|
|
const height = document.getElementById('container').scrollHeight || 500;
|
|
const graph = new G6.Graph({
|
|
container: 'container',
|
|
width,
|
|
height,
|
|
// translate the graph to align the canvas's center, support by v3.5.1
|
|
fitCenter: true,
|
|
modes: {
|
|
default: ['drag-canvas', 'drag-node'],
|
|
},
|
|
defaultNode: {
|
|
/* node type, the priority is lower than the type in the node data */
|
|
type: 'donut',
|
|
/* node size */
|
|
size: 60,
|
|
/* style for the keyShape */
|
|
// style: {
|
|
// fill: '#9EC9FF',
|
|
// stroke: '#5B8FF9',
|
|
// lineWidth: 3,
|
|
// },
|
|
labelCfg: {
|
|
/* label's position, options: center, top, bottom, left, right */
|
|
position: 'bottom',
|
|
/* label's offset to the keyShape, 4 by default */
|
|
// offset: 12,
|
|
/* label's style */
|
|
// style: {
|
|
// fontSize: 20,
|
|
// fill: '#ccc',
|
|
// fontWeight: 500
|
|
// }
|
|
},
|
|
/* configurations for four linkpoints */
|
|
// linkPoints: {
|
|
// top: true,
|
|
// right: true,
|
|
// bottom: true,
|
|
// left: true,
|
|
// /* linkPoints' size, 8 by default */
|
|
// // size: 5,
|
|
// /* linkPoints' style */
|
|
// // fill: '#ccc',
|
|
// // stroke: '#333',
|
|
// // lineWidth: 2,
|
|
// },
|
|
/* icon configuration */
|
|
icon: {
|
|
/* whether show the icon, false by default */
|
|
show: true,
|
|
/* icon's img address, string type */
|
|
// img: 'https://gw.alipayobjects.com/zos/basement_prod/012bcf4f-423b-4922-8c24-32a89f8c41ce.svg',
|
|
/* icon's size, 20 * 20 by default: */
|
|
// width: 40,
|
|
// height: 40
|
|
},
|
|
},
|
|
/* styles for different states, there are built-in styles for states: active, inactive, selected, highlight, disable */
|
|
// nodeStateStyles: {
|
|
// // node style of active state
|
|
// active: {
|
|
// fillOpacity: 0.8,
|
|
// },
|
|
// // node style of selected state
|
|
// selected: {
|
|
// lineWidth: 5,
|
|
// },
|
|
// },
|
|
});
|
|
|
|
graph.data(data);
|
|
graph.render();
|
|
|
|
graph.on('node:mouseenter', (evt) => {
|
|
const { item } = evt;
|
|
graph.setItemState(item, 'active', true);
|
|
});
|
|
|
|
graph.on('node:mouseleave', (evt) => {
|
|
const { item } = evt;
|
|
graph.setItemState(item, 'active', false);
|
|
});
|
|
|
|
graph.on('node:click', (evt) => {
|
|
const { item } = evt;
|
|
graph.setItemState(item, 'selected', true);
|
|
});
|
|
graph.on('canvas:click', (evt) => {
|
|
graph.getNodes().forEach((node) => {
|
|
graph.clearItemStates(node);
|
|
});
|
|
});
|