【React】Sigma.js框架网络图-入门篇(2)

2024-04-27 12:36

本文主要是介绍【React】Sigma.js框架网络图-入门篇(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过《【React】Sigma.js框架网络图-入门篇》有了基本认识

由于上一篇直接给出了基本代码示例,可能看着比较复杂也不知道是啥意思;
今天从理论入手重新认识下!

一、基本认识

首先,我们先了解下基础术语:

  • 图(Graph):由节点(Node)和边(Edge)组成的一种数据结构,用于描述事物之间的关系
  • Node:节点,表示事物
    • 例如:python、java、编程语言…
  • Edge:边,表示事物之间的关系
    • 例如:
    • python -> 编程语言
    • java -> 编程语言
    • 编程语言 -> python
    • 编程语言 -> java

通过上诉转化为Graph展示:
在这里插入图片描述

二、Sigma.js 生命周期

2.1 sigma初始化

参数说明
Graphology实例这对于 sigma 的运行至关重要。它提供了 sigma 可视化的图形数据结构。
DOM Element此元素充当图形可视化的容器,并在 sigma 实例的整个生命周期中保持一致。
Settings (Optional)可以在实例化期间提供初始设置以配置 sigma 的行为。
setSettingupdateSetting方法允许在实例化后修改设置。

实例化期间提供的图(Graph)可以稍后使用该setGraph方法进行更新。

2.2 两步渲染机制

sigma渲染涉及两个主要步骤:数据处理、将其可视化。

  1. 数据处理
    在渲染之前,sigma 必须处理数据。这涉及诸如调用nodeReduceredgeReducer设置以及为 WebGL 渲染器索引数据之类的任务。
  2. 渲染
    数据处理后,sigma通过在canvas(画布元素)中生成可视化图形。

2.3 自动渲染触发器

Sigma在特定场景下自动调用处理和渲染方法:

场景说明
Graphology EventsGraphology 实例发出与数据更新相关的事件时,sigma 会负责必要的渲染。 开发人员不需要管理这个。
Settings Updates对设置的任何修改都会触发重新渲染。
User Interactions通过鼠标或触摸设备的交互导致相机更新和后续渲染。

2.4 手动渲染触发器

在某些情况下,可能需要手动启动处理和渲染步骤。

例如:
如果外部因素改变了nodeReduceredgeReducer使用的状态,
则必须执行处理和渲染以实现正确的可视化。

Sigma为此提供了三种方法:

方法说明
refresh该方法处理数据然后呈现。也就是视图重载
scheduleRefresh使用requestAnimationFrame安排下一帧的refresh
如果已安排刷新,则不会安排另一次刷新,从而避免冗余。
此方法对于去抖动很有用,因为refresh有时会占用大量资源。
scheduleRender安排下一帧的渲染,但前提是尚未安排render渲染和refresh刷新。

注意: 渲染方法是私有的。 当需要重新渲染时,开发时应始终使用scheduleRender

三、Sigma.js 数据基本构成

Sigma.js 使用Graphology作为其底层图模型
对数据(NodeEdge等)有个基本数据结构规定(可视为系统关键词,定义扩展字段时不要重叠)

3.1 公共属性

属性名说明
size表示节点的半径。
作用于Node时,越大的值将渲染越大的节点;
作用于Edge时,越大的值将渲染越粗的线;
color以字符串形式表示节点的颜色。CSS named colors
它处理十六进制值(例如:#e22653)和CSS命名的颜色(例如deeppink)。
label节点显示名称
hidden布尔属性。如果设置为true,则不会显示该节点。
forceLabel设置为true时,无论缩放级别或其他条件如何,都将始终显示节点的标签。
zIndex决定节点的显示顺序。 zIndex 值较高的节点将绘制在 zIndex 值较低的节点之上。
注意:只有当sigma设置zIndex为true时,zIndex属性才有效

3.2 Node节点

  • 最小构成字段:
属性名说明
id节点的唯一标识
xy决定节点在画布上的位置。它们通常使用布局算法设置,但也可以手动指定。
(无布局默认情况下需要手动指定)
  • 其他预定属性
属性名说明
type定义了节点的视觉展示形态,如:circle, square

3.3 Edge

  • 最小构成字段:
属性名说明
source基于哪个节点
target到哪个节点

这篇关于【React】Sigma.js框架网络图-入门篇(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript