antv-G6在vue2中使用---自定义卡片和收缩节点并添加动画和自定义弹窗样式

本文主要是介绍antv-G6在vue2中使用---自定义卡片和收缩节点并添加动画和自定义弹窗样式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这系列文章主要是完成一个图谱的自定义修改(最近太忙了长篇分段更新自己使用流程)
1. 连接线修改成动态,并添加跟随线移动的光圈上一篇地址➡️点击这里
2. 自定义卡片样式和文字内容
3. 自定义伸缩节点的样式,并添加动画样式
3. 由左右结构换成上下结构的图谱
4. 修改弹窗默认样式

antv-G6知识图谱使用(实例)

  • 前言
  • 想要达到的样式(视频)
  • 1. 添加卡片背景图片
      • 1. 先添加背景图片
      • 2. 之后调整下矩形卡片大小和百分比条位置
      • 3. 运行后效果
  • 2. 收缩节点样式更改成图片样式并添加动画
      • 1. 先将收缩节点更换成图片形式并添加动画
      • 2. 调整加减号位置
      • 3. 运行后样式
  • 3. 由左右结构换成上下结构的图谱
        • 1. 修改基本配置
        • 2. 修改线初始位置点
        • 3. 之后需要调整下收缩节点位置
  • 4. 修改弹窗默认样式
      • 1. 安装`npm install insert-css`
      • 2. 引入使用
      • 3. 运行效果


前言

提示:antv-G6初次使用(实例+分析注释)项目需要时间紧,直接网上找的加上官网信息,主要内容都有注释


想要达到的样式(视频)

1. 添加卡片背景图片

1. 先添加背景图片

  // 背景图片const shape = group.addShape('image', {attrs: {width:rectConfig.width+25,//图片宽度height: rectConfig.height,//图片高度x: nodeOrigin.x-10,//图片相对定位x轴y: nodeOrigin.y,//图片相对定位y轴img:require('../../assets/img/try_play.png'),},// 在 G6 3.3 及之后的版本中,必须指定 name,可以是任意字符串,但需要在同一个自定义元素类型中保持唯一性name: 'image-shape',});
// 禁止点击shape.set('capture', false);

2. 之后调整下矩形卡片大小和百分比条位置

 //元素盒子const rect = group.addShape('rect', {attrs: {x: nodeOrigin.x,y: nodeOrigin.y,width:rectConfig.width,height: rectConfig.height,},});
// bottom line backgroundconst bottomBackRect = group.addShape('rect', {attrs: {x: nodeOrigin.x+5, //这里添加了5y: rectBBox.maxY - 4,//这里减去了4width: rectConfig.width,height: 4,radius: [0, 0, rectConfig.radius, rectConfig.radius],fill: '#E0DFE3',},});bottomBackRect.set('capture', false);// bottom percentconst bottomRect = group.addShape('rect', {attrs: {x: nodeOrigin.x+5,//这里添加了5y: rectBBox.maxY - 4,//这里减去了4width: rate * rectBBox.width,height: 4,radius: [0, 0, 0, rectConfig.radius],fill: colors[status],},});
bottomRect.set('capture', false);

3. 运行后效果

在这里插入图片描述

2. 收缩节点样式更改成图片样式并添加动画

1. 先将收缩节点更换成图片形式并添加动画

有用到Util 需要引入样式const { Util } = G6;
在这里插入图片描述

2. 调整加减号位置

        group.addShape('text', {attrs: {x: rectConfig.width / 2 + 10,//调整这里y: -1,//调整这里textAlign: 'center',textBaseline: 'middle',text: collapsed ? '+' : '-',fontSize: 16,cursor: 'pointer',fill: 'rgba(0, 0, 0,)',},// must be assigned in G6 3.3 and later versions. it can be any string you want, but should be unique in a custom item typename: 'collapse-text',modelId: cfg.id,});

3. 运行后样式

3. 由左右结构换成上下结构的图谱

1. 修改基本配置

在这里插入图片描述

2. 修改线初始位置点

在自定义节点样式 'flow-rect’中改
在这里插入图片描述
在这里插入图片描述

3. 之后需要调整下收缩节点位置

在这里插入图片描述
在这里插入图片描述
之后更改下卡片高度
在这里插入图片描述
在这里插入图片描述

4. 修改弹窗默认样式

1. 安装npm install insert-css

insert-css是一个JavaScript库,用于动态向网页中插入CSS样式。

2. 引入使用

import insertCss from 'insert-css';// 我们用 insert-css 演示引入自定义样式
// 推荐将样式添加到自己的样式文件中
// 若拷贝官方代码,别忘了 npm install insert-css
insertCss(`.g6-component-tooltip {background-color: rgba(0,0,0, 0.65);padding: 10px;box-shadow: rgb(174, 174, 174) 0px 0px 10px;width: fit-content;color: #fff;border-radius = 4px;}
`);

3. 运行效果

在这里插入图片描述

这篇关于antv-G6在vue2中使用---自定义卡片和收缩节点并添加动画和自定义弹窗样式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

Python中__init__方法使用的深度解析

《Python中__init__方法使用的深度解析》在Python的面向对象编程(OOP)体系中,__init__方法如同建造房屋时的奠基仪式——它定义了对象诞生时的初始状态,下面我们就来深入了解下_... 目录一、__init__的基因图谱二、初始化过程的魔法时刻继承链中的初始化顺序self参数的奥秘默认

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab