d3.js: Relation Graph

d3.js  Tags · d3/d3 · GitHub

D3 by Observable | The JavaScript library for bespoke data visualization

下载或

<!-- 引入 D3.js 库 -->
    <script src="https://d3js.org/d3.v7.min.js"></script>

<!-- 引入 D3.js 库 -->
    <script src="https://d3js.org/d3.v7.js"></script>

geovinu.json:

{"nodes": [{"id": 0,"name": "贾宝玉","image": "1.jpg","group": 1,"description": "贾国府衔玉而生的公子。"},{"id": 1,"name": "林黛玉","image": "lin.jpg","group": 1,"description": "贾亲密女友。"},{"id": 3,"name": "薛宝钗","image": "bao.jpg","group": 1,           "description": "贾府中意女子。"},{"id": 4,"name": "王熙凤","image": "wan.jpg","group": 2,"description": "贾琏的妻子"}],"links": [{ "source": 0, "target": 1, "value": 8, "relation": "女友" },{ "source": 0, "target": 3, "value": 7, "relation": "女友" },{ "source": 1, "target": 3, "value": 7, "relation": "情敌" },{ "source": 4, "target": 3, "value": 5, "relation": "婶侄" },{ "source": 4, "target": 1, "value": 5, "relation": "婶妹" },{ "source": 4, "target": 0, "value": 5, "relation": "婶侄" }]
}

geovindu.js

// JavaScript Document geovindu.js
const svg = d3.select("#chart").attr("width", 800).attr("height", 500);const width = +svg.attr("width");const height = +svg.attr("height");const descriptionDiv = d3.select("#description");d3.json("geovindu.json").then(data => {console.log("Loaded data:", data);console.log("Links:", data.links);// 创建连接线const link = svg.append("g").attr("class", "links").selectAll("line").data(data.links).enter().append("line").attr("stroke-width", d => Math.sqrt(d.value));//先隐藏link.style("opacity", 0);// 创建关系标签文字const linkLabels = svg.append("g").attr("class", "link-labels").selectAll("text").data(data.links).enter().append("text").text(d => d.relation).attr("font-size", "10px").attr("fill", "#333999");// 创建节点const node = svg.append("g").attr("class", "nodes").selectAll("g").data(data.nodes).enter().append("g");const simulation = d3.forceSimulation().force("link", d3.forceLink().id(d => d.id).distance(150)) // 调整链接距离.force("charge", d3.forceManyBody().strength(-300)) // 调整电荷力强度.force("center", d3.forceCenter(width / 2, height / 2));const circles = node.append("circle").attr("r", 5).attr("fill", d => {if (d.group === 1) return "red";else return "blue";});const images = node.append("image").attr("href", d => d.image).attr("x", -5).attr("y", -5).attr("width", 50).attr("height", 50).on("mouseover", (event, d) => {// 显示描述信息descriptionDiv.style("display", "block").style("left", (event.pageX + 10) + "px").style("top", (event.pageY + 10) + "px").html(d.description);// 显示与该节点相关的线条和关系名称标签link.style("opacity", l => l.source === d || l.target === d ? 1 : 0);linkLabels.style("opacity", l => l.source === d || l.target === d ? 1 : 0);}).on("mouseout", () => {// 隐藏描述信息descriptionDiv.style("display", "none");// 隐藏所有线条和关系名称标签link.style("opacity", 0);linkLabels.style("opacity", 0);})	.on("error", (error, d) => {console.error(`Error loading image for ${d.name}:`, error);});const labels = node.append("text").text(d => d.name).attr('x', 6).attr('y', 3).on("mouseover", (event, d) => {// 显示描述信息descriptionDiv.style("display", "block").style("left", (event.pageX + 10) + "px").style("top", (event.pageY + 10) + "px").html(d.description);// 显示与该节点相关的线条和关系名称标签link.style("opacity", l => l.source === d || l.target === d ? 1 : 0);linkLabels.style("opacity", l => l.source === d || l.target === d ? 1 : 0);}).on("mouseout", () => {// 隐藏描述信息descriptionDiv.style("display", "none");// 隐藏所有线条和关系名称标签link.style("opacity", 0);linkLabels.style("opacity", 0);});const drag = d3.drag().on("start", dragstarted).on("drag", dragged).on("end", dragended);node.call(drag);simulation.nodes(data.nodes).on("tick", ticked);simulation.force("link").links(data.links);function ticked() {link.attr("x1", d => d.source.x).attr("y1", d => d.source.y).attr("x2", d => d.target.x).attr("y2", d => d.target.y);// 更新关系标签文字的位置linkLabels.attr("x", d => (d.source.x + d.target.x) / 2).attr("y", d => (d.source.y + d.target.y) / 2);node.attr("transform", d => `translate(${d.x},${d.y})`);}function dragstarted(event, d) {if (!event.active) simulation.alphaTarget(0.3).restart();d.fx = d.x;d.fy = d.y;}function dragged(event, d) {d.fx = event.x;d.fy = event.y;}function dragended(event, d) {if (!event.active) simulation.alphaTarget(0);d.fx = null;d.fy = null;}}).catch(error => {console.error("Error loading data:", error);});

geovindu.css

@charset "utf-8";
/* CSS Document geovindu.css geovindu,Geovin Du */.node circle {fill: #cccccc;stroke: steelblue;stroke-width: 3px;}.node text {font: 12px sans-serif;cursor: pointer;}.links {fill: none;stroke: #999fff;stroke-width: 2px;opacity: 1; /* 初始时连接线隐藏 */transition: opacity 0.3s;}.link-labels text {font-size: 10px;fill: #333999;opacity: 0; /* 初始时关系名称标签隐藏 */transition: opacity 0.3s;}#description {position: absolute;background-color: white;border: 1px solid black;padding: 10px;display: none;}

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0">  <title>简单人物关系图谱 Relation Graph </title><link rel="shortcut icon" href="/favicon.ico">
<meta content="Relation Graph  涂聚文,Geovin Du,塗聚文,geovindu,捷为工作室" name="keywords">
<meta content="Relation Graph 涂聚文,Geovin Du,塗聚文,geovindu,捷为工作室" name="description"><script src="./d3/7.9.0/d3.js"></script><link rel="stylesheet" type="text/css" href="./geovindu.css" />
</head><body><svg id="chart" width="800" height="600"></svg><div id="description"></div><script type="text/javascript" src="geovindu.js">    </script>
</body></html>

输出:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/10538.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Oracle Primavera P6自动进行进度计算

前言 在P6 Professional 有一个自动计划计算的选项&#xff0c;很多人不了解该设置如何使用&#xff0c;以及什么时候该启动这项配置。 详情 P6 Professional 默认为非自动进度计算。启用自动选项后&#xff0c;可以快速查看调度更改的效果。 ​ ​ 如图所示&#xff0c;当你…

反射、枚举以及lambda表达式

一.反射 1.概念&#xff1a;Java的反射&#xff08;reflection&#xff09;机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c;都能够调用它的任意方法和属性&#xff0c;既然能拿到那么&am…

【Proteus仿真】【51单片机】简易计算器系统设计

目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 联系作者 一、主要功能 1、LCD1602液晶显示 2、矩阵按键​ 3、可以进行简单的加减乘除运算 4、最大 9999*9999 二、使用步骤 系统运行后&#xff0c;LCD1602显示数据&#xff0c;通过矩阵按键…

HarmonyOS简介:HarmonyOS核心技术理念

核心理念 一次开发、多端部署可分可合、自由流转统一生态、原生智能 一次开发、多端部署 可分可合 自由流转 自由流转可分为跨端迁移和多端协同两种情况 统一生态 支持业界主流跨平台开发框架&#xff0c;通过多层次的开放能力提供统一接入标准&#xff0c;实现三方框架快速…

(即插即用模块-特征处理部分) 十九、(NeurIPS 2023) Prompt Block 提示生成 / 交互模块

文章目录 1、Prompt Block2、代码实现 paper&#xff1a;PromptIR: Prompting for All-in-One Blind Image Restoration Code&#xff1a;https://github.com/va1shn9v/PromptIR 1、Prompt Block 在解决现有图像恢复模型时&#xff0c;现有研究存在一些局限性&#xff1a; 现有…

Day24-【13003】短文,数据结构与算法开篇,什么是数据元素?数据结构有哪些类型?什么是抽象类型?

文章目录 13003数据结构与算法全书框架考试题型的分值分布如何&#xff1f; 本次内容概述绪论第一节概览什么是数据、数据元素&#xff0c;数据项&#xff0c;数据项的值&#xff1f;什么是数据结构&#xff1f;分哪两种集合形式&#xff08;逻辑和存储&#xff09;&#xff1f…

使用 MSYS2 qemu 尝鲜Arm64架构国产Linux系统

近期&#xff0c;我的师弟咨询我关于Arm64架构的国产CPU国产OS开发工具链问题。他们公司因为接手了一个国企的单子&#xff0c;需要在这类环境下开发程序。说实在的我也没有用过这个平台&#xff0c;但是基于常识&#xff0c;推测只要基于C和Qt&#xff0c;应该问题不大。 1. …

unity学习21:Application类与文件存储的位置

目录 1 unity是一个跨平台的引擎 1.1 使用 Application类&#xff0c;去读写文件 1.2 路径特点 1.2.1 相对位置/相对路径&#xff1a; 1.2.2 固定位置/绝对路径&#xff1a; 1.3 测试方法&#xff0c;仍然挂一个C#脚本在gb上 2 游戏数据文件夹路径&#xff08;只读&…

【Redis】hash 类型的介绍和常用命令

1. 介绍 Redis 中存储的 key-value 本身就是哈希表的结构&#xff0c;存储的 value 也可以是一个哈希表的结构 这里每一个 key 对应的一个 哈希类型用 field-value 来表示 2. 常用命令 命令 介绍 时间复杂度 hset key field value 用于设置哈希表 key 中字段 field 的值为…

基于51单片机和WS2812B彩色灯带的流水灯

目录 系列文章目录前言一、效果展示二、原理分析三、各模块代码四、主函数总结 系列文章目录 前言 用彩色灯带按自己想法DIY一条流水灯&#xff0c;谁不喜欢呢&#xff1f; 所用单片机&#xff1a;STC15W204S &#xff08;也可以用其他1T单片机&#xff0c;例如&#xff0c;S…

力扣017_最小覆盖字串题解----C++

题目描述 我们可以用滑动窗口的思想解决这个问题。在滑动窗口类型的问题中都会有两个指针&#xff0c;一个用于「延伸」现有窗口的 r 指针&#xff0c;和一个用于「收缩」窗口的 l 指针。在任意时刻&#xff0c;只有一个指针运动&#xff0c;而另一个保持静止。我们在 s 上滑动…

如何从客观角度批判性阅读分析博客

此文仅以个人博客为例&#xff0c;大量阅读朋友反馈给我的交流让我得知他们所理解我的博客所表达的意思并非我所想表达的&#xff0c;差异或大或小&#xff0c;因人而异。 观点与事实 只有从客观角度反复批判性阅读和分析&#xff0c;才能逐渐清晰观点和事实。 观点不等于事实…

深入理解MySQL 的 索引

索引是一种用来快速检索数据的一种结构, 索引使用的好不好关系到对应的数据库性能方面, 这篇文章我们就来详细的介绍一下数据库的索引。 1. 页面的大小: B 树索引是一种 Key-Value 结构&#xff0c;通过 Key 可以快速查找到对应的 Value。B 树索引由根页面&#xff08;Root&am…

Spring Boot项目如何使用MyBatis实现分页查询及其相关原理

写在前面&#xff1a;大家好&#xff01;我是晴空๓。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正&#xff0c;感谢大家的不吝赐教。我的唯一博客更新地址是&#xff1a;https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油&#xff0c;冲鸭&#x…

LabVIEW温度修正部件测试系统

LabVIEW温度修正部件测试系统 这个基于LabVIEW的温度修正部件测试系统旨在解决飞行器温度测量及修正电路的测试需求。该系统的意义在于提供一个可靠的测试平台&#xff0c;用于评估温度修正部件在实际飞行器环境中的性能表现&#xff0c;从而确保飞行器的安全性和可靠性。 系统…

动态规划每日一练(四)

一、day1——最长数对链 题目链接&#xff1a; 646. 最长数对链 - 力扣&#xff08;LeetCode&#xff09;646. 最长数对链 - 给你一个由 n 个数对组成的数对数组 pairs &#xff0c;其中 pairs[i] [lefti, righti] 且 lefti < righti 。现在&#xff0c;我们定义一种 跟随…

对比category_encoders库和sklearn库中的OrdinalEncoder

OrdinalEncoder 是用来对数据中的分类特征进行编码、转换为整数标签的函数。 category_encoders库 from category_encoders import OrdinalEncoder 安装&#xff1a;pip install category_encoders --trusted-host pypi.tuna.tsinghua.edu.cn&#xff08;记得关闭代理&#x…

【PLL】杂散生成和调制

时钟生成 --》 数字系统 --》峰值抖动频率生成 --》无线系统 --》 频谱纯度、 周期信号的相位不确定性 随机抖动&#xff08;random jitter, RJ&#xff09;确定性抖动&#xff08;deterministic jitter,DJ&#xff09; 时域频域随机抖动积分相位噪声确定性抖动边带 杂散生成和…

理解神经网络:Brain.js 背后的核心思想

温馨提示 这篇文章篇幅较长,主要是为后续内容做铺垫和说明。如果你觉得文字太多,可以: 先收藏,等后面文章遇到不懂的地方再回来查阅。直接跳读,重点关注加粗或高亮的部分。放心,这种“文字轰炸”不会常有的,哈哈~ 感谢你的耐心阅读!😊 欢迎来到 brain.js 的学习之旅!…

Ubuntu下的Doxygen+VScode实现C/C++接口文档自动生成

Ubuntu下的DoxygenVScode实现C/C接口文档自动生成 Chapter1 Ubuntu下的DoxygenVScode实现C/C接口文档自动生成1、 Doxygen简介1. 安装Doxygen1&#xff09;方法一&#xff1a;2&#xff09;方法二&#xff1a;2. doxygen注释自动生成插件3. doxygen注释基本语法4. doxygen的生成…