g6/packages/site/examples/feature/features/demo/itemAnimates.js
Yuxin 98a213ab70
perf: simplify plugin registration; add comments and unit tests (#5352)
* perf: refactor register;add comments and unit tests

* fix: ci

---------

Co-authored-by: yvonneyx <banxuan.zyx@antgroup.com>
2024-01-17 18:59:21 +08:00

303 lines
6.4 KiB
JavaScript

import { Graph } from '@antv/g6';
const data = {
nodes: [
{
id: 'a',
data: {
x: 200,
y: 100,
cluster: '1',
},
},
{
id: 'b',
data: {
x: 100,
y: 200,
cluster: '2',
},
},
{
id: 'c',
data: {
x: 300,
y: 200,
cluster: '3',
},
},
],
edges: [
{
id: 'a2b',
source: 'a',
target: 'b',
},
{
id: 'a2c',
source: 'a',
target: 'c',
},
],
};
const container = document.getElementById('container');
const width = container.scrollWidth;
const height = container.scrollHeight || 500;
const graph = new Graph({
container: 'container',
width,
height,
modes: { default: ['click-select'] },
layout: {
type: 'grid',
},
theme: {
type: 'spec',
specification: {
node: {
dataTypeField: 'cluster',
},
},
},
node: {
labelShape: {
text: {
fields: ['id'],
formatter: (model) => model.id,
},
},
labelBackgroundShape: {},
animates: {
buildIn: [
{
fields: ['size', 'opacity'],
shapeId: 'group',
duration: 500,
},
],
buildOut: [
{
fields: ['opacity'],
duration: 200,
},
],
update: [
{
fields: ['x', 'y'],
},
{
fields: ['opacity'],
shapeId: 'haloShape',
states: ['selected'],
},
{
fields: ['lineWidth', 'fill'],
shapeId: 'keyShape',
states: ['selected'],
},
],
show: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 300,
},
],
hide: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 300,
},
{
fields: ['opacity'],
shapeId: 'labelShape',
duration: 300,
},
],
},
},
edge: {
animates: {
buildIn: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 500,
},
],
buildOut: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 200,
},
],
update: [
{
fields: ['opacity'],
shapeId: 'haloShape',
states: ['selected'],
},
{
fields: ['lineWidth'],
shapeId: 'keyShape',
states: ['selected'],
},
],
show: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 300,
},
],
hide: [
{
fields: ['opacity'],
shapeId: 'keyShape',
duration: 300,
},
],
},
},
data,
});
const newNodes = [];
const buildInOutActions = {
'Add Node(buildin)': () => {
const node = graph.addData('node', {
id: `node-${Math.random()}`,
data: {
cluster: Math.random(),
},
});
graph.updateNodePosition([
{
id: node.id,
data: {
x: Math.random() * 500,
y: Math.random() * 500,
},
},
]);
newNodes.push(node);
},
'Remove Node(buildout)': () => {
if (!newNodes.length) return;
graph.removeData('node', newNodes[0].id);
newNodes.shift();
},
};
const updateActions = {
'Update Position(update)': () => {
const positions = [];
data.nodes.forEach((node) => {
const { x, y } = node.data;
positions.push({
id: node.id,
data: {
x: x + Math.random() * 50 - 25,
y: y + Math.random() * 50 - 25,
},
});
node.x += Math.random() * 50 - 25;
node.y += Math.random() * 50 - 25;
});
graph.updateNodePosition(positions);
},
'Update Node Color(update)': () => {
graph.updateData(
'node',
graph.getAllNodesData().map((node) => ({
id: node.id,
data: {
cluster: Math.random(),
},
})),
);
},
'Select/Deselect Node(update)': () => {
if (graph.getItemState('a', 'selected')) {
graph.setItemState('a', 'selected', false);
} else {
graph.setItemState('a', 'selected', true);
}
},
'Select/Deselect Edge(update)': () => {
if (graph.getItemState('a2b', 'selected')) {
graph.setItemState('a2b', 'selected', false);
} else {
graph.setItemState('a2b', 'selected', true);
}
},
};
const showHideActions = {
'Hide/Show Node(show/hide)': () => {
if (graph.getItemVisible('a')) {
graph.hideItem('a');
} else {
graph.showItem('a');
graph.showItem('a2b');
graph.showItem('a2c');
}
},
};
const viewPortActions = {
'Fit View': () => {
graph.fitView({}, { duration: 500 });
},
'Fit Center': () => {
graph.fitCenter('render', { duration: 500 });
},
'Zoom In': () => {
const currentZoom = graph.getZoom();
graph.zoomTo(currentZoom * 1.1, undefined, { duration: 500 });
},
'Zoom Out': () => {
const currentZoom = graph.getZoom();
graph.zoomTo((currentZoom * 1) / 1.1, undefined, { duration: 500 });
},
Translate: () => {
graph.translate({ dx: Math.random() * 200 - 100, dy: Math.random() * 200 - 100 }, { duration: 500 });
},
'1:1': () => {
graph.zoomTo(1, undefined, { duration: 500 });
},
};
const actions = {
'animate.buildIn & animate.buildOut': buildInOutActions,
'animate.show & animate.hide': showHideActions,
'animate.update': updateActions,
'view port': viewPortActions,
};
const controllerContainer = document.createElement('div');
controllerContainer.style.position = 'absolute';
container.appendChild(controllerContainer);
Object.keys(actions).forEach((groupName, i) => {
const btnContainer = document.createElement('div');
controllerContainer.appendChild(btnContainer);
const tip = document.createElement('span');
tip.innerHTML = `👉 ${groupName}: `;
btnContainer.appendChild(tip);
Object.keys(actions[groupName]).forEach((name, i) => {
const btn = document.createElement('a');
btn.innerHTML = name;
btn.style.backgroundColor = 'rgba(255, 255, 255, 0.8)';
btn.style.padding = '4px';
btn.style.marginLeft = i > 0 ? '24px' : '8px';
btnContainer.appendChild(btn);
btn.addEventListener('click', () => {
actions[groupName][name]();
});
});
});
window.graph = graph;