【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

本文主要是介绍【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【课程链接】

AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili

本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解)

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title>06 深入图形与图形分组、自定义节点、节点动画</title><!-- 引入 G6 --><script src="https://gw.alipayobjects.com/os/lib/antv/g6/4.3.11/dist/g6.min.js"></script><!-- <script src="https://gw.alipayobjects.com/os/lib/antv/g6/3.7.1/dist/g6.min.js"></script> -->
</head><body><div id="container"></div><script>G6.registerNode('lineNode', {// 复写draw方法draw: (cfg, group) => {const keyShape = group.addShape('circle', {attrs: {r: 70,x: 0,y: 0,opacity: 0}});// 画5条虚线做极坐标的对齐线const rGap = 10;let currentR = 30;for (let i = 0; i < 5; i++) {group.addShape('circle', {attrs: {r: currentR,x: 0,y: 0,lineWidth: 1,stroke: '#bae7ff',lineDash: [5, 5]}})currentR += rGap;}// 中心的圆点和文本group.addShape('circle', {attrs: {fill: cfg.centerColor,x: 0,y: 0,r: 20}})group.addShape('text', {attrs: {text: cfg.label,fill: '#111',x: 0,y: 0,textAlign: 'center',textBaseline: 'middle',fontWeight: 500},// 给text一个name,为动画animate检索做准备name: 'line-chart-label'});// 绘制折线和它们的坐标点const alphaGap = Math.PI * 2 / 25;let pointCount = 0;cfg.details.forEach(detail => {const { color, values } = detail;const positions = []values.forEach(value => {const r = value + 20;const alpha = alphaGap * pointCount;pointCount++;const x = r * Math.cos(alpha);const y = r * Math.sin(alpha);const point = group.addShape('circle', {attrs: {fill: color,x,y,r: 2,},// 给圆点起名字name,为圆点添加hover效果做准备name: 'line-chart-point'})positions.push({ x, y });});// 绘制各个detail数据的路径group.addShape('path', {attrs: {path: positions.map((pos, i) => [i === 0 ? 'M' : 'L', pos.x, pos.y]),stroke: color,lineWidth: 1}})})return keyShape;},// 中间文本不断缩放的动画afterDraw: (cfg, group) => {const textShape = group.find(ele => ele.get('name') === 'line-chart-label')const rate = 1.01;// 动画的另一种写法,onFrame,onFrame的参数ratio是一次动画执行的比例textShape.animate(ratio => {const currentFontSize = textShape.attr('fontSize') || 12;const scale = ratio < 0.5 ? rate : (1 / rate);const targetFontSize = currentFontSize * scale;// console.log('ratio', ratio);	0 < ratio < 1	 			// console.log('currentFontSize', currentFontSize);		 			// console.log('scale', scale);		 return { fontSize: targetFontSize }}, {duration: 1000,repeat: true})}}, 'circle');const width = document.getElementById('container').scrollWidthconst height = document.getElementById('container').scrollHeight || 500const graph = new G6.Graph({container: 'container',width,height,fitCenter: true,defaultNode: {type: 'lineNode'}})const data = {nodes: [{id: 'node1',label: 'Node1',x: 150,y: 150,centerColor: "#bae7ff", // 中心圆形的颜色details: [{ cat: 'pv', values: [20, 30, 40, 30, 30], color: '#5B8FF9' },{ cat: 'dal', values: [40, 30, 20, 30, 50], color: '#5AD8A6' },{ cat: 'uv', values: [40, 30, 30, 40, 40], color: '#5D7092' },{ cat: 'sal', values: [20, 30, 50, 20, 20], color: '#F6BD16' },{ cat: 'cal', values: [10, 10, 20, 20, 20], color: '#E8684A' },],},{id: 'node2',label: 'Node2',x: 400,y: 150,centerColor: "#5b8ff9",details: [{ cat: 'pv', values: [10, 10, 50, 20, 10], color: '#5B8FF9' },{ cat: 'dal', values: [20, 30, 10, 50, 40], color: '#5AD8A6' },{ cat: 'uv', values: [10, 50, 30, 20, 30], color: '#5D7092' },{ cat: 'sal', values: [50, 30, 20, 20, 20], color: '#F6BD16' },{ cat: 'cal', values: [50, 10, 20, 50, 30], color: '#E8684A' },],},],edges: [{source: 'node1',target: 'node2',},]}graph.data(data);graph.render();// 为数据的圆点添加hover后变大的动画graph.on('line-chart-point:mouseenter', e => {const { target } = etarget.animate({ r: 5 },{ duration: 100, repeat: false })})graph.on('line-chart-point:mouseleave', e => {const { target } = etarget.animate({ r: 2 },{ duration: 100, repeat: false })})// 为数据的圆点添加hover后变大的动画 ENDif (typeof window !== 'undefined')window.onresize = () => {if (!graph || graph.get('destroyed')) return;if (!container || !container.scrollWidth || !container.scrollHeight)graph.changeSize(container.scrollWidth, container.scrollHeight);}</script>
</body></html>

这篇关于【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151869

相关文章

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容