docs: add fisheye demo

This commit is contained in:
yvonneyx 2024-08-23 15:36:45 +08:00
parent d674d09468
commit 065696c7b8
5 changed files with 181 additions and 0 deletions

View File

@ -0,0 +1,39 @@
import { Graph, iconfont } from '@antv/g6';
const style = document.createElement('style');
style.innerHTML = `@import url('${iconfont.css}');`;
document.head.appendChild(style);
fetch('https://assets.antv.antgroup.com/g6/relations.json')
.then((res) => res.json())
.then((data) => {
const graph = new Graph({
container: 'container',
autoFit: 'view',
data,
node: {
style: {
size: (datum) => datum.id.length * 2 + 10,
label: false,
labelText: (datum) => datum.id,
labelBackground: true,
icon: false,
iconFontFamily: 'iconfont',
iconText: '\ue6f6',
iconFill: '#fff',
},
palette: {
type: 'group',
field: (datum) => datum.id,
color: ['#1783FF', '#00C9C9', '#F08F56', '#D580FF'],
},
},
edge: {
style: {
stroke: '#e2e2e2',
},
},
plugins: [{ key: 'fisheye', type: 'fisheye', nodeStyle: { label: true, icon: true } }],
});
graph.render();
});

View File

@ -0,0 +1,108 @@
import { Graph, iconfont } from '@antv/g6';
const style = document.createElement('style');
style.innerHTML = `@import url('${iconfont.css}');`;
document.head.appendChild(style);
fetch('https://assets.antv.antgroup.com/g6/relations.json')
.then((res) => res.json())
.then((data) => {
const graph = new Graph({
container: 'container',
autoFit: 'view',
data,
node: {
style: {
size: (datum) => datum.id.length * 2 + 10,
label: false,
labelText: (datum) => datum.id,
labelBackground: true,
icon: false,
iconFontFamily: 'iconfont',
iconText: '\ue6f6',
iconFill: '#fff',
},
palette: {
type: 'group',
field: (datum) => datum.id,
color: ['#1783FF', '#00C9C9', '#F08F56', '#D580FF'],
},
},
edge: {
style: {
stroke: '#e2e2e2',
},
},
plugins: [
{
key: 'fisheye',
type: 'fisheye',
trigger: 'click',
scaleRBy: 'wheel',
scaleDBy: 'drag',
style: { fill: 'transparent', stroke: 'transparent' },
nodeStyle: { label: true, icon: true },
},
],
});
graph.render();
const config = {
trigger: 'click',
scaleRBy: 'wheel',
scaleDBy: 'drag',
showDPercent: true,
borderless: true,
};
window.addPanel((gui) => {
gui
.add(config, 'trigger', ['pointermove', 'click', 'drag'])
.name('Trigger')
.onChange((value) => {
graph.updatePlugin({
key: 'fisheye',
trigger: value,
});
});
gui
.add(config, 'scaleRBy', ['wheel', 'drag', 'unset'])
.name('Scale R by')
.onChange((value) => {
graph.updatePlugin({
key: 'fisheye',
scaleRBy: value,
});
});
gui
.add(config, 'scaleDBy', ['wheel', 'drag', 'unset'])
.name('Scale D by')
.onChange((value) => {
graph.updatePlugin({
key: 'fisheye',
scaleDBy: value,
});
});
gui
.add(config, 'showDPercent')
.name('Show D Percent')
.onChange((value) => {
graph.updatePlugin({
key: 'fisheye',
showDPercent: value,
});
});
gui
.add(config, 'borderless')
.name('Borderless')
.onChange((value) => {
const style = value
? { fill: 'transparent', lineDash: 0, stroke: 'transparent' }
: { fill: '#F08F56', lineDash: [5, 5], stroke: '#666' };
graph.updatePlugin({
key: 'fisheye',
style,
});
});
});
});

View File

@ -0,0 +1,24 @@
{
"title": {
"zh": "中文分类",
"en": "Category"
},
"demos": [
{
"filename": "basic.js",
"title": {
"zh": "鱼眼放大镜",
"en": "Fisheye"
},
"screenshot": "https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*SPqiTLwdZ9MAAAAAAAAAAAAADmJ7AQ/original"
},
{
"filename": "custom.js",
"title": {
"zh": "自定义鱼眼放大镜",
"en": "Custom Fisheye"
},
"screenshot": "https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*-VyPRY-2dMIAAAAAAAAAAAAADmJ7AQ/original"
}
]
}

View File

@ -0,0 +1,5 @@
---
title: Fisheye
---
Fisheye is designed for focus+context exploration, it keeps the context and the relationships between context and the focus while magnifying the focus area.

View File

@ -0,0 +1,5 @@
---
title: Fisheye 鱼眼放大镜
---
Fisheye 鱼眼放大镜是为 focus+context 的探索场景设计的,它能够保证在放大关注区域的同时,保证上下文以及上下文与关注中心的关系不丢失。