2023-12-04 21:24:44 +08:00
|
|
|
import { Graph, Extensions, extend } from '@antv/g6';
|
2023-12-04 15:19:49 +08:00
|
|
|
|
|
|
|
const ExtGraph = extend(Graph, {
|
2023-12-04 21:24:44 +08:00
|
|
|
nodes: {
|
|
|
|
'sphere-node': Extensions.SphereNode,
|
|
|
|
'plane-node': Extensions.PlaneNode,
|
|
|
|
},
|
|
|
|
behaviors: {
|
|
|
|
'orbit-canvas-3d': Extensions.OrbitCanvas3D,
|
|
|
|
'zoom-canvas-3d': Extensions.ZoomCanvas3D,
|
|
|
|
},
|
2023-12-04 15:19:49 +08:00
|
|
|
});
|
|
|
|
|
2023-12-04 21:24:44 +08:00
|
|
|
const colors = ['rgb(240, 134, 82)', 'rgb(30, 160, 230)', 'rgb(122, 225, 116)'];
|
|
|
|
const sphereR = 15;
|
2023-12-04 15:19:49 +08:00
|
|
|
|
2023-12-04 21:24:44 +08:00
|
|
|
const planeGroup = Array.from({ length: 3 }).map((_, i) => ({
|
|
|
|
id: `plane-${i}`,
|
|
|
|
data: {
|
|
|
|
type: 'plane-node',
|
|
|
|
x: 0,
|
|
|
|
y: -300 + 300 * i + sphereR,
|
|
|
|
z: 0,
|
|
|
|
layer: i + 1,
|
|
|
|
},
|
|
|
|
}));
|
2023-12-04 15:19:49 +08:00
|
|
|
|
|
|
|
const container = document.getElementById('container');
|
|
|
|
const width = container.scrollWidth;
|
|
|
|
const height = container.scrollHeight || 500;
|
|
|
|
|
2023-12-04 21:24:44 +08:00
|
|
|
fetch('https://assets.antv.antgroup.com/g6/3-layer-top.json')
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then((result) => {
|
|
|
|
const nodes = result.nodes
|
|
|
|
.map(({ name, pos, layer }) => ({
|
|
|
|
id: name,
|
|
|
|
data: {
|
|
|
|
type: 'sphere-node',
|
|
|
|
...pos,
|
|
|
|
layer,
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
.concat(planeGroup);
|
|
|
|
|
|
|
|
const edges = result.edges.map((edge, index) => ({ id: `edge-${index}`, ...edge }));
|
2023-12-04 15:19:49 +08:00
|
|
|
|
2023-12-04 21:24:44 +08:00
|
|
|
const graph = new ExtGraph({
|
|
|
|
container,
|
|
|
|
width,
|
|
|
|
height,
|
|
|
|
renderer: 'webgl-3d',
|
|
|
|
modes: {
|
2023-12-04 15:19:49 +08:00
|
|
|
default: [
|
2023-12-04 21:24:44 +08:00
|
|
|
{
|
|
|
|
type: 'orbit-canvas-3d',
|
|
|
|
trigger: 'drag',
|
|
|
|
},
|
|
|
|
'zoom-canvas-3d',
|
2023-12-04 15:19:49 +08:00
|
|
|
],
|
2023-12-04 21:24:44 +08:00
|
|
|
},
|
|
|
|
theme: {
|
2023-12-04 15:19:49 +08:00
|
|
|
type: 'spec',
|
|
|
|
base: 'dark',
|
2023-12-04 21:24:44 +08:00
|
|
|
},
|
|
|
|
data: { nodes, edges },
|
|
|
|
node: {
|
2023-12-04 15:19:49 +08:00
|
|
|
keyShape: {
|
2023-12-04 21:24:44 +08:00
|
|
|
fill: { fields: ['layer'], formatter: (model) => colors[model.data.layer - 1] },
|
|
|
|
r: sphereR,
|
|
|
|
width: {
|
|
|
|
fields: ['type'],
|
|
|
|
formatter: (model) => (model.data.type === 'plane-node' ? 10000 : 0),
|
|
|
|
},
|
|
|
|
depth: {
|
|
|
|
fields: ['type'],
|
|
|
|
formatter: (model) => (model.data.type === 'plane-node' ? 10000 : 0),
|
|
|
|
},
|
|
|
|
materialProps: {
|
|
|
|
fields: ['type'],
|
|
|
|
formatter: (model) =>
|
|
|
|
model.data.type === 'plane-node'
|
|
|
|
? {
|
|
|
|
wireframe: true,
|
|
|
|
cullMode: 0,
|
|
|
|
wireframeColor: '#797979',
|
|
|
|
}
|
|
|
|
: undefined,
|
|
|
|
},
|
2023-12-04 15:19:49 +08:00
|
|
|
},
|
2023-12-04 21:24:44 +08:00
|
|
|
},
|
|
|
|
edge: {
|
|
|
|
keyShape: {
|
|
|
|
lineWidth: 2,
|
|
|
|
stroke: '#f6e432', // 边主图形描边颜色
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
2023-12-04 15:19:49 +08:00
|
|
|
|
2023-12-08 20:27:30 +08:00
|
|
|
graph.on('afterrender', () => {
|
2023-12-04 21:24:44 +08:00
|
|
|
const canvas = graph.canvas;
|
|
|
|
const camera = canvas.getCamera();
|
|
|
|
camera.createLandmark('reset', {
|
2023-12-04 15:19:49 +08:00
|
|
|
position: [0, -400, 2000],
|
|
|
|
focalPoint: [0, 0, 0],
|
|
|
|
zoom: 1,
|
2023-12-04 21:24:44 +08:00
|
|
|
});
|
|
|
|
camera.gotoLandmark('reset', {
|
2023-12-04 15:19:49 +08:00
|
|
|
duration: 1000,
|
|
|
|
easing: 'ease-in',
|
|
|
|
onfinish: () => {
|
2023-12-04 21:24:44 +08:00
|
|
|
canvas.addEventListener('afterrender', () => {
|
|
|
|
graph.canvas.getRoot().rotate(0, 0.3, 0);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
2023-12-04 15:19:49 +08:00
|
|
|
});
|
2023-12-04 21:24:44 +08:00
|
|
|
|
|
|
|
window.graph = graph;
|
|
|
|
});
|