【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

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路