【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

相关文章

动手开发基于Springboot的基础开发框架-01

本系列专题虽然是按教学的深度来定稿的,但在项目结构和代码组织方面是按生产系统的要求来书定的。在本章中主要介绍下基础开发框架的内容。后续所有章节的项目全是在本基础框架的基础上演进的。 工程结构介绍 SpringbootSeries:父工程,定义一个通用Maven pom,主要用于版本管理;Framework:子工程组,包含两个Modules,主要是一些框架底层开发jar包;Spring

从项目开始学习Vue——02(若依框架)

往期: 从项目开始学习Vue——01 目录标题 一、基础插件(一)路由Vue Router(二)导航守卫(路由拦截器)二、Vuex(一)什么是VuexVuex的部分介绍内容: (二)何时使用Vuex(三)具体使用StategettermutationActionModule 三、element-ui四、布局插件五、js-cookie的使用方法六、Axios七、加密jsencrypt八、加

Vue线上环境禁止打印console.log

当我们在开发项目时,我们会使用大量的console.log,这样方便我们去调试,但是当正常上线后,在生产环境,我们是不喜欢打印的信息暴露在浏览器控制台的。 这时候我们可以通过一行代码解决: 在main.js文件中添加以下代码:console.log = () => {} 其中process.env.NODE.ENV 取得变量具体看我们生产该变量赋了啥值,这里我生产环境该变量赋值devchai

JS操作记录

var v1 =$('#tota').val(); //获取的id = v1的为字符串 var v = parseInt(v1);//parseInt转类型页面刷新window.location.reload();请求window.open('url');localaction='url';open操作<input name="cat_name" type="text" id="cat_na

解决velocity与jquery的冲突

1、使用jQuery代替$. 如:jQuery.ajax(); 缺点:不适合扩展,一旦替换成第三方库时,那就麻烦大发 2、使用jQuery.noConflict。 如:var j = jQuery.noConflict(); j.ajax(); 缺点:当使用jQuery的相关插件时,会使得插件失效哦! 3、wrap jQuery中的冲突方法。 如$.ajax()在Veloci

在 Vue3 中使用 styled-components

前言 随着组件化时代的兴起,前端应用开始采用组件级别的 CSS 封装:通过 JavaScript 声明和抽象样式,以提高组件的可维护性。在组件加载时动态加载样式,并动态生成类名,从而避免全局污染。 styled-components 是其中的杰出代表。 正如其名称所示,styled-components 以组件的形式声明样式,将样式与组件分离,实现逻辑组件与展示组件的分离。 styled-co

vue2结合element-ui实现TreeSelect 树选择功能

需求背景 在日常开发中,我们会遇见很多不同的业务需求。如果让你用element-ui实现一个 tree-select 组件,你会怎么做? 这个组件在 element-plus 中是有这个组件存在的,但是在 element-ui 中是没有的。 可能你会直接使用 element-plus 组件库,或者其他组件库。但是若你的项目目前的基于vue3和element-ui进行开发的呢? 最终效果

react-select组件使用

1. 在react-select下拉框中鼠标移入时显示标签的title // 在react-select下拉框中鼠标移入时显示标签的title<Selectoptions={options}getOptionLabel={(option) => (<div title={option.label}>{option.label}</div>)}/> 2. 增加下拉框层级数值 // 增加下拉

多个开源的js补环境框架测试

原文链接:https://mp.weixin.qq.com/s/uEMFGpE5bqmTvzSgX2twvA 前言 在做js逆向时肯定会遇到补环境的情况,看到github开源了好几个补环境用的框架,这篇文章做个测试,看看哪个比较好用。 https://github.com/pysunday/sdenvhttps://github.com/bnmgh1/node-sandboxhttps://

vue-cli2,vue-cli3,vite 生产环境去掉console.log

console.log一般都是在开发环境下使用的,在生产环境下需要去除 ,如果手动删除未免也太累了,我们可以用插件对于具体环境全局处理。  vue-cli2 项目build 下面webpack.prod.config.js 文件中: plugins: [new webpack.DefinePlugin({'process.env': env}),new UglifyJsPlugin(