ECharts 实现人民的名义关系图谱 代码开源

本文介绍了如何使用ECharts创建关系图谱,包括设置series的type为graph,选择force布局,配置tooltip和data,以及定义关系。提供完整代码示例,并分享了Github仓库和在线演示链接,适合需要在web上展示关系图的开发者参考。
摘要由CSDN通过智能技术生成
1、什么是ECharts

ECharts是百度开源的纯 Javascript 图表库,目前开源可以与highcharts相匹敌的一个图表库,相信有很多国内用户使用。

官网 http://echarts.baidu.com/

 

2、开始简单配置关系图

1、首先配置series的type为graph。

2、layout为force,layout可以选择none、circular和force

  'none' 不采用任何布局,使用节点中提供的 x, y 作为节点的位置。

  'circular' 采用环形布局。

  'force' 采用力引导布局。

  来自官方文档

2、设置鼠标移动到人物处显示人物简介tooltip

tooltip: {
    formatter: function (x) {
        return x.data.des;
    }
}

 

3、设置data 

{
    name: '侯亮平',
    des: '最高检反贪局侦查处处长,汉东省人民检察院副检察长兼反贪局局长。<br/>经过与腐败违法分子的斗争,最终将一批腐败分子送上了审判台,<br/>正义战胜邪恶,自己也迎来了成长。',
    symbolSize: 100,
    itemStyle: {
        normal: {
            color: 'red'
        }
    }
}

 

4、设置关系

{
    source: '高育良',
    target: '侯亮平',
    name: '师生',
    des: '侯亮平是高育良的得意门生'
}

 

3、完整代码

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>ECharts 实现人民的名义关系图谱</title>
    <script src="jquery-1.10.2.min.js"></script>
    <script src="echarts.min.js"></script>
    <style type="text/css">
        html, body, #main { height: 100%; width: 100%; margin: 0; padding: 0 }
    </style>
</head>
<body>
    <div id="main" style=""></div>
    <script type="text/javascript">
        var myChart = echarts.init(document.getElementById('main'));
        option = {
            title: { text: '人民的名义关系图谱' },
            tooltip: {
                formatter: function (x) {
                    return x.data.des;
                }
            },
            series: [
                {
                    type: 'graph',
                    layout: 'force',
                    symbolSize: 80,
                    roam: true,
                    edgeSymbol: ['circle', 'arrow'],
                    edgeSymbolSize: [4, 10],
                    edgeLabel: {
                        normal: {
                            textStyle: {
                                fontSize: 20
                            }
                        }
                    },
                    force: {
                        repulsion: 2500,
                        edgeLength: [10, 50]
                    },
                    draggable: true,
                    itemStyle: {
                        normal: {
                            color: '#4b565b'
                        }
                    },
                    lineStyle: {
                        normal: {
                            width: 2,
                            color: '#4b565b'

                        }
                    },
                    edgeLabel: {
                        normal: {
                            show: true,
                            formatter: function (x) {
                                return x.data.name;
                            }
                        }
                    },
                    label: {
                        normal: {
                            show: true,
                            textStyle: {
                            }
                        }
                    },
                    data: [
                        {
                            name: '侯亮平',
                            des: '最高检反贪局侦查处处长,汉东省人民检察院副检察长兼反贪局局长。<br/>经过与腐败违法分子的斗争,最终将一批腐败分子送上了审判台,<br/>正义战胜邪恶,自己也迎来了成长。',
                            symbolSize: 100,
                            itemStyle: {
                                normal: {
                                    color: 'red
组织结构图 .dvItem { position:absolute; width:24px; border:1px solid #999999; font-size:12px; padding:5px; height:80px; z-index:9; background-color:#FFFFFF; line-height:16px; } a { text-decoration:none; color:#333333; } .dvhline { position:absolute; z-index:17; padding:0px; margin:0px; border-top:1px solid #999999; } .dvvline { color:blue; position:absolute; background-color:#999999; width:1px; z-index:17; } var dItem = new Array(); var w = 600; var h = 40; var iw = 60; var ih = 80; var boxh = 80; var startleft = 400; var starttop = 40; var hr = "" var labledv = "<div class=\"dvItem\" style=\"" var hdv = "<div class=\"dvhline\" style=\"width:"; var vdv = ""; var enddv = ""; var htm = ""; var len; var maxn=0;//深度 function Load_Data() { dItem[0] = "1|总经理|0|"; dItem[1] = "2|营运主管|1|"; dItem[2] = "3|技术主管|1|"; dItem[3] = "4|客服主管|2|"; dItem[4] = "5|商务主管|2|"; dItem[5] = "6|商务代表|5|"; dItem[6] = "7|营运策划|2|"; dItem[7] = "8|程序员|3|"; dItem[8] = "9|美工|3|"; len = dItem.length; Set_Item(0,0); Set_Max(); Write_Item(0,0,0,1); var htm1 = ""; for(var i=0;i<len;i++) { htm1 = htm1 +dItem[i]+""; } //document.getElementById("Load_DV").innerHTML = htm1 ; document.getElementById("List_DV").innerHTML = htm; } //设置层次 function Set_Item(pid,ni) { var n = ni + 1; var iAry = new Array(); for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[2] == pid) { dItem[i] = dItem[i] + ni; if(maxn < ni) { maxn = ni; } Set_Item(iAry[0],n); } } } //设置节点子节点中最大数 function Set_Max() { var iAry = new Array(); var childnum; for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); childnum = Get_Child_Num(iAry[0]); if(childnum <= 1) { dItem[i] = dItem[i] + "|0"; } else { dItem[i] = dItem[i] + "|" + Get_Max(iAry[0],iAry[3]); } } } function Get_Max(pid,start) { var iAry = new Array(); var m = 0; var n = 0; for(var j=start;j<=maxn;j++) { for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[3] == j) { if(Get_RootID(pid,iAry[0])) { m = m + 1; } } if(n < m) { n = m; } } m = 0; } return n; } function Get_RootID(pid,id) { var iAry = new Array(); for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[0] == id) { if(iAry[2] == pid) { return true; break; } else { return Get_RootID(pid,iAry[2]); } } } return false; }
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值