/neo4j-d3-graph

对neo4j导出的数据做d3前端可视化

Primary LanguageHTML

根据Neo4j导出的JSON数据做D3可视化展示

启动服务,再打开 index.html 查看效果

效果图如下及说明:

  • 在搜索、鼠标进入该节点时会展示临近的关系节点
  • 点击节点、文字切换显示
  • 加入了碰撞检测模型,已注释,取消即可与效果图相同

效果图

效果展示: https://coderwanp.github.io/neo4j-d3-graph/

代码使用说明

关于启动服务

由于知识图谱的JSON文件加载是通过AJAX请求过来,所以直接打开html文件会报跨域错误

正确的启动方法是通过IDE软件以项目形式打开文件夹,比如:HBuildX、PyCharm、VSCode、IDEA等,很多启动都自带服务,此时通过 localhost:端口号 访问 index.html 即可查看效果。

JSON格式要求

p 为键值对表示,每个 p 为一个查询关系。

按如下Cypher查询语句导出均可以展示:

MATCH p=(n:节点类型)-[r:关系类型]->() RETURN p limit 20

如何配置为自己的数据

<script> 标签中定位,修改如下几行代码即可,不需要在到处去找位置了

// 自定义图标及颜色(数组保证一一对应)
// names		图例名称变量制作图标
// labels		节点的标签名称(与records.json中保证相同)
// colors		图例颜色
// url 			json文件的路径
var names = ['企业', '贸易类型', '地区', '国家']
var labels = ['Enterprise', 'Type', 'Region', 'Country']
var colors = ['#55ffff', '#aaaaff', '#4e88af', '#ca635f']
var url = 'data/records.json'

修改说明

2021.04.01

之前的代码只支持 距离为1 的关系路径导入。

如果你从Neo4j导出的 records.json 中关系路径长度大于1,如下图这种情况会导致节点全部移至左上角。现在已经修改完毕,支持长距离路径的图,只要满足JSON格式要求,即可进行可视化展示。

image-20210401170404874

2021.04.05

修复图例颜色问题,之前图例超过4个就无法填充颜色了,现在已更改

多图例情况:(热心网友提供的数据,所以打个码)

多图例情况

2021.06.30

关于力导向拖拽的代码,确实文档没有说明清楚,在 vue-d3-graph 的项目是拖拽后固定不动,这个项目现改为拖拽后回弹,如果想要固定的效果注释 dragended 的代码即可。

// 拖动函数代码
var dragging = false;
// 开始拖动并更新相应的点
function dragstarted(d) {
    if (!d3.event.active) simulation.alphaTarget(0.3).restart();
    d.fx = d.x;
    d.fy = d.y;
    dragging = true;
}
// 拖动进行中
function dragged(d) {
    d.fx = d3.event.x;
    d.fy = d3.event.y;
}
// 拖动结束
function dragended(d) {
    if (!d3.event.active) simulation.alphaTarget(0);
    // 注释以下两行,拖拽后节点固定不动
    // d.fx = null;
    // d.fy = null;
    dragging = false;
}