echart关系图(graph)添加波点涟漪效果

这个是直接用echarts 的官网的实例改的,可以直接放到上面去看效果。

涟漪效果需要指定坐标系。(cartesian2d ---》二维直角坐标系、polar ---》极坐标系、geo---》地理坐标系)

而在关系图中,关系图的默认应该是直角坐标系(但是在官方实例中一般不会给出来)。布局是null。所以要涟漪效果出现。就必须给定一个坐标系才行。 其他的在api中都可以找到,我用的版本是4

option = {
     xAxis : [{
           type : 'value',
           splitLine: {
             show: false
           },
           axisTick: {
             show: false
           },
           axisLabel: {
             show: false,
             interval: 0,
             textStyle: {
               color: 'white',
               fontSize: 14,
             },
             rotate: 45
           },
           axisLine: {
             show: false  // 显示与关闭坐标轴
           }
         }, ],
         yAxis : [{
           type : 'value',
           splitLine: {
             show: false
           },
           axisTick: {
             show: false
           },
           axisLabel: {
             show: false,
             textStyle: {
               color: 'white',
               fontSize: 14
             }
           },
           axisLine: {
             show: false // 显示与关闭坐标轴
           },
         }],
    
    animationDurationUpdate: 1500,
    animationEasingUpdate: 'quinticInOut',
    series : [
        {
            type: 'graph',
            layout: 'none',
            symbolSize: 50,
            roam: true,
            label: {
                normal: {
                    show: true
                }
            },
            edgeSymbol: ['circle', 'arrow'],
            edgeSymbolSize: [4, 10],
            edgeLabel: {
                normal: {
                    textStyle: {
                        fontSize: 20
                    }
                }
            },
            data: [{
                name: '节点1',
                x: 300,
                y: 300
            }, {
                name: '节点2',
                x: 800,
                y: 300
            }, {
                name: '节点3',
                x: 550,
                y: 100
            }, {
                name: '节点4',
                x: 550,
                y: 500
            }],
            // links: [],
            links: [{
                source: 0,
                target: 1,
                symbolSize: [5, 20],
                label: {
                    normal: {
                        show: true
                    }
                },
                lineStyle: {
                    normal: {
                        width: 5,
                        curveness: 0.2
                    }
                }
            }, {
                source: '节点2',
                target: '节点1',
                label: {
                    normal: {
                        show: true
                    }
                },
                lineStyle: {
                    normal: { curveness: 0.2 }
                }
            }, {
                source: '节点1',
                target: '节点3'
            }, {
                source: '节点2',
                target: '节点3'
            }, {
                source: '节点2',
                target: '节点4'
            }, {
                source: '节点1',
                target: '节点4'
            }],
            lineStyle: {
                normal: {
                    opacity: 0.9,
                    width: 2,
                    curveness: 0
                }
            }
        },
          {
          
            type: 'effectScatter',
            data: [
                { value:[48 , 150],  //  这个value对应的是这个涟漪对应的位置[x,y]
                label: { formatter: function(p){ return '节点1'; } }, symbolSize: 50  }, 
                { value:[752 , 150 , '111'],  //  【x,y,  值数据】
                label: { formatter: function(p){ return '节点2'; } }, symbolSize: 50  },
                { value:[400 , 298], 
                label: { formatter: function(p){ return '节点3'; } }, symbolSize: 50  },
                { value:[400 , 2], 
                label: { formatter: function(p){ return '节点4'; } }, symbolSize: 50  },
                ],
            symbolSize: 50,
            showEffectOn: 'render',
            rippleEffect: {
                brushType: 'stroke'
            },
            hoverAnimation: true,
            label: {
                normal: {
                    show: true
                }
            },
            itemStyle: {
                normal: {
                    color: 'purple',
                    shadowBlur: 10,
                    shadowColor: '#333'
                }
            },
            zlevel: 4 , // 关系图的zlevel最小是3,所以要大于3
        }
    ]
};

效果图展示:

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
ECharts是百度开源的一个基于JavaScript的可视化表库,可以用于数据可视化。其中ECharts中的graph组件是用于展示关系型数据的表组件,可以绘制节点和节点之间的关系,支持多种布局算法,可以进行交互操作等。 使用EChartsgraph组件可以轻松地绘制各种类型的关系,比如社交网络、组织结构、流程、知识谱等。在使用graph组件时,需要提供节点和边的数据,并可以通过配置项来设置节点和边的样式、布局方式、交互方式等。 以下是一个简单的ECharts graph组件的示例代码: ```javascript // 初始化一个ECharts实例 var myChart = echarts.init(document.getElementById('main')); // 定义节点和边的数据 var nodes = [ { name: '节点1', x: 100, y: 100 }, { name: '节点2', x: 200, y: 200 } ]; var edges = [ { source: 0, target: 1 } ]; // 定义ECharts的配置项 var option = { series: [{ type: 'graph', layout: 'force', data: nodes, links: edges }] }; // 使用ECharts的setOption方法将配置项应用到表中 myChart.setOption(option); ``` 上述代码中,我们定义了两个节点和一条边的数据,并使用EChartsgraph组件来绘制这些节点和边。其中,节点的数据包括节点的名称和坐标,边的数据包括起始节点和目标节点的索引。在ECharts的配置项中,我们指定了表的类型为graph,并使用了force布局算法来进行节点的排列。最后,使用setOption方法将配置项应用到表中。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值