g6/packages/site/examples/item/defaultNodes/demo/donut.js
2023-02-02 10:31:36 +08:00

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);
});
});