Echarts力导向图graph 关系图绘制Demo

【前言】

近期因业务需求,给我司产品做了一个Echarts----力导向图&关系图 demo

其中分为两种关系图:

01.不同等级节点样式不同

02.不同公司的颜色样式不同

【效果图】
效果图如下:
Echarts 关系图snap

【CODE】
code如下:

 var dom = document.getElementById("container");
        var myChart = echarts.init(dom);
        var app = {};
        option = null;
        myChart.showLoading();
        var webkitDep = {
            "type": "force",
            "categories": [ //关系网类别,可以写多组  
                {
                    "name": "甲公司", //关系网名称  
                    "keyword": {},
                    "base": "网格关系"
                },
                {
                    "name": "乙公司", //关系网名称  
                    "keyword": {},
                    "base": "网格关系"
                },
            ],
            "nodes": [ //展示的节点  
                {
                    "name": "甲公司", //节点名称  
                    "value": 10,
                    "symbolSize": 40,
                    "category": 0 //与关系网类别索引对应,此处只有一个关系网所以这里写0 

                },
                {
                    "name": "甲公司A股东",
                    "value": 8,
                    "symbolSize": 25,
                    "category": 0,
                    itemStyle: {
                        color: '#3398db'
                    }
                },
                {
                    "name": "甲公司B股东",
                    "value": 10,
                    "symbolSize": 25,
                    "category": 0,
                    itemStyle: {
                        color: '#3398db'
                    }
                },
                {
                    "name": "子公司1",
                    "value": 10,
                    "symbolSize": 15,
                    "category": 0,
                    itemStyle: {
                        color: 'green'
                    }
                },
                {
                    "name": "子公司2",
                    "value": 110,
                    "symbolSize": 15,
                    "category": 0,
                    itemStyle: {
                        color: 'green'
                    }
                },
                {
                    "name": "子公司3",
                    "value": 100,
                    "symbolSize": 15,
                    "category": 0,
                    itemStyle: {
                        color: 'green'
                    }
                },
                {
                    "name": "子公司4",
                    "value": 1000,
                    "symbolSize": 15,
                    "category": 0,
                    itemStyle: {
                        color: 'green'
                    }
                },
                {
                    "name": "乙公司", //节点名称  
                    "value": 10,
                    "symbolSize": 40,
                    "color": "#fff",
                    "category": 1 //与关系网类别索引对应,此处只有一个关系网所以这里写0  
                },
                {
                    "name": "乙公司A股东",
                    "value": 8,
                    "symbolSize": 25,
                    "category": 1
                },
                {
                    "name": "乙公司B股东",
                    "value": 10,
                    "symbolSize": 25,
                    "category": 1
                },
                {
                    "name": "乙公司C股东",
                    "value": 8,
                    "symbolSize": 25,
                    "category": 1
                },
                {
                    "name": "子公司1",
                    "value": 10,
                    "symbolSize": 15,
                    "category": 1
                },
                {
                    "name": "子公司2",
                    "value": 110,
                    "symbolSize": 15,
                    "category": 1
                },
                {
                    "name": "子公司3",
                    "value": 100,
                    "symbolSize": 15,
                    "category": 1
                }
            ],
            "links": [ //节点之间连接  
                {
                    "source": 0, //起始节点,0表示第一个节点  
                    "target": 1 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 0,
                    "target": 2
                },
                {
                    "source": 1,
                    "target": 3
                },
                {
                    "source": 1,
                    "target": 4
                },
                {
                    "source": 2,
                    "target": 5
                },
                {
                    "source": 2,
                    "target": 6
                },
                {
                    "source": 7, //起始节点,0表示第一个节点  
                    "target": 8 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 7, //起始节点,0表示第一个节点  
                    "target": 9 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 7, //起始节点,0表示第一个节点  
                    "target": 10 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 8, //起始节点,0表示第一个节点  
                    "target": 11 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 9, //起始节点,0表示第一个节点  
                    "target": 12 //目标节点,1表示与索引为1的节点进行连接  
                },
                {
                    "source": 10, //起始节点,0表示第一个节点  
                    "target": 13 //目标节点,1表示与索引为1的节点进行连接  
                }
            ]
        };
        myChart.hideLoading();

        option = {
            legend: {
                data: ['甲公司', '乙公司'] //此处的数据必须和关系网类别中name相对应  
            },
            series: [{
                type: 'graph',
                layout: 'force',
                animation: false,
                label: {
                    normal: {
                        show: true,
                        position: 'right'
                    }
                },
                draggable: true,
                data: webkitDep.nodes.map(function (node, idx) {
                    node.id = idx;
                    return node;
                }),
                categories: webkitDep.categories,
                force: {
                    edgeLength: 80, //连线的长度  
                    repulsion: 100 //子节点之间的间距  
                },
                edges: webkitDep.links
            }]
        };
        myChart.setOption(option);;
        if (option && typeof option === "object") {
            myChart.setOption(option, true);
        }

完结撒花

感谢Thanks♪(・ω・)ノ 周末愉快!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Calmness_7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值