echart力导向图实现搜索节点高亮效果,以及切换节点图片及圆点效果_lp9r3w枚 .-程序员宅基地

技术标签: 节点替换为图片  echart力导向图  搜索高亮  vue  

drawLine () {
                this.GetRandom(this.list1);
                var myChart = echarts.init(document.getElementById('relate_graph3'));
                var option = {
                    // backgroundColor: new echarts.graphic.RadialGradient(0.3, 0.3, 0.8, [{
                    //     offset: 0,
                    //     color: '#fff'
                    // }, {
                    //     offset: 1,
                    //     color: '#cdd0d5'
                    // }]),
                    animationDurationUpdate: 1500,
                    animationEasingUpdate: 'quinticInOut',
                    series : [{
                        type: 'graph',
                        layout: 'none',
                        legendHoverLink : true, //是否启用图例 hover(悬停) 时的联动高亮。
                        hoverAnimation : true, //是否开启鼠标悬停节点的显示动画
                        data: this.list1.map(function (node) {
                        return {
                            x: node.x,
                            y: node.y,
                            id: node.id,
                            symbolSize: node.psize,
                            symbolSize1: node.csize,
                            name: node.name,
                            itemStyle: {
                                normal: {
                                    label: {
                                        show: true
                                    },
                                    color: node.color,
                                    opacity: 1
                                },
                                emphasis: {
                                    label: {
                                        show: true
                                    },
                                    color: node.color,
                                    opacity: 1
                                }
                            }
                        };
                        }),
                        edges: this.list2.map(function (edge) {
                            return {
                                source: edge.sourceId,
                                target: edge.targetId
                            };
                        }),
                        label : { //=============图形上的文本标签
                            normal : {
                                show : true, //是否显示标签。
                                position : 'outside', //标签的位置。['50%', '50%'] [x,y]
                                textStyle : { //标签的字体样式
                                    fontStyle : 'normal', //文字字体的风格 'normal'标准 'italic'斜体 'oblique' 倾斜
                                    fontWeight : 'bolder', //'normal'标准'bold'粗的'bolder'更粗的'lighter'更细的或100 | 200
                                    fontFamily : 'sans-serif', //文字的字体系列
                                    fontSize : 12 //字体大小
                                }
                            },
                            emphasis : { //高亮状态
                                show : true,
                                textStyle : { //标签的字体样式
                                    fontStyle : 'normal', //文字字体的风格 'normal'标准 'italic'斜体 'oblique' 倾斜
                                    fontWeight : 'bolder', //'normal'标准'bold'粗的'bolder'更粗的'lighter'更细的或100 | 200
                                    fontFamily : 'sans-serif', //文字的字体系列
                                    fontSize : 12 //字体大小
                                }
                            }
                        },
                        edgeSymbol: [ 'arrow', 'none' ],
                        roam: true,
                        focusNodeAdjacency: true, //是否在鼠标移到节点上的时候突出显示节点以及节点的边和邻接节点
                        lineStyle : { //==========关系边的公用线条样式。
                            normal : {
                                color: '#909399',
                                width : '1',
                                type : 'solid', //线的类型 'solid'(实线)'dashed'(虚线)'dotted'(点线)
                                curveness : 0.3, //线条的曲线程度,从0到1
                                opacity : 0.6
                            // 图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。默认0.5
                            },
                            emphasis : { //高亮状态
                                width : '2',
                                color: '#909399',
                                type : 'solid', //线的类型 'solid'(实线)'dashed'(虚线)'dotted'(点线)
                                curveness : 0.3, //线条的曲线程度,从0到1
                                opacity : 1
                            }
                        },
                        edgeLabel : { //==============线条的边缘标签 
                            normal : {
                                show : false,
                                textStyle: {
                                    fontSize: 10
                                }
                            },
                            emphasis : { //高亮状态
                                show : false,
                                textStyle: {
                                    fontSize: 12
                                }
                            }
                        }
                    }],
                    // toolbox: { //==============可以保存为图片
                    //     show: true,
                    //     feature: {
                    //         dataView: {
                    //             show: true,
                    //             readOnly: true
                    //         },
                    //         restore: {
                    //             show: true
                    //         },
                    //         saveAsImage: {
                    //             show: true
                    //         }
                    //     }
                    // },
                    tooltip: { //==============显示鼠标移入的显示
                        triggerOn: 'click', //点击  mousemove
                        enterable: true,
                        hideDelay: 50,
                        padding: 0,
                        confine: true,
                        formatter: function(params, ticket, callback) {
                            if (params.dataType === 'node') {
                                var html = '';
                                html += '<div class="dialogShowR" v-scrollBar>'
                                html += '<div>服务名称:租赁保证金</div>'
                                html += '<div>协议类型:http</div>'
                                html += '<div>监听端口号:8089</div>'
                                html += '<div>服务审批状态:发布-待审核</div>'
                                html += '<div>服务版本号:1.1</div>'
                                html += '<div>服务接口数:43</div>'
                                html += '<div>最后编辑时间:2018-10-11 12:00:00</div>'
                                html += '<div class="desc">简要描述:<p>针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存</p></div>'
                                html += '<div class="desc">服务描述:<p>针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对针对境外的存款人员的业务针对</p></div>'
                                html += '<div>被依赖的服务数量为:' + params.data.symbolSize1 + '</div>'
                                html += '<div>被依赖的服务数量为:' + params.data.symbolSize + '</div>'
                                html += '</div>'
                                return html;
                            } else if (params.dataType === 'edge') {
                                var html1 = '';
                                html1 += '<div class="dialogShow"><h5>服务源代码为:' + params.data.source + '</h5></div>';
                                return html1;
                            }
                        }
                    }
                };
                myChart.setOption(option);
                myChart.on('mouseover', function (params) {
                    if (params.dataType === 'node') {
                        let options = myChart.getOption();
                        let nodesOption = options.series[0].data;
                        let linksOption = options.series[0].edges;
                        for (let m in nodesOption) {
                            let arr = [];
                            for (let i in linksOption) {
                                arr.push(linksOption[i].target);
                            }
                            if (nodesOption[m].name === params.name) {
                                nodesOption[m].itemStyle.opacity = 1;
                                for (let j in linksOption) {
                                    if (linksOption[j].source == params.data.id) {
                                        options.series[0].lineStyle.opacity = 1;
                                    }
                                }
                            } else if (arr.indexOf(nodesOption[m].id)) {
                                nodesOption[m].itemStyle.opacity = 1;
                            } else {
                                nodesOption[m].itemStyle.opacity = 0.1;
                            }
                        }
                        myChart.setOption(options);
                    }
                    myChart.dispatchAction({
                        type: 'focusNodeAdjacency',
                        dataIndex: params.dataIndex
                    })
                });
                myChart.on('mouseout', function (params) {
                    myChart.dispatchAction({
                        type: 'unfocusNodeAdjacency',
                        seriesIndex: 0
                    })
                });
                // this.$refs.myCharts.oncontextmenu = () => false;
                myChart.on('contextmenu', function (param) {
                    document.oncontextmenu = () => false;
                    let menu = document.getElementById("menuuu");
                    let event = param.event;
                    let pageX = event.offsetX;
                    let pageY = event.offsetY;
                    console.log(pageX, 'pageX'); 
                    menu.style.left = (pageX + 40) + 'px';//右键出菜单部分
                    menu.style.top = (pageY + 60) + 'px';//右键出菜单部分
                    menu.style.display = "block";
                });
            },
            GetRandom (list) {
                for (var i = 0; i < this.list1.length; i++) {
                    var x = Math.floor(Math.random() * 100);
                    var y = Math.floor(Math.random() * 100);
                    var colorAll = ['#a75ebc', '#ff7e00', '#f6e0ff', '#ff0000'];
                    var n = Math.floor(Math.random() * 5);
                    var color = colorAll[n];
                    this.list1[i].x = x;
                    this.list1[i].y = y;
                    this.list1[i].color = color;
                }
            },
            handleSearch () {
                var myChart1 = echarts.init(document.getElementById('relate_graph3'));
                let options = myChart1.getOption();
                let nodesOption = options.series[0].data;
                let linksOption = options.series[0].edges;
                for (let m in nodesOption) {
                    nodesOption[m].itemStyle.opacity = 1;
                    if (nodesOption[m].name.indexOf(this.input) > -1) {
                        for (let k in linksOption) {
                            if (linksOption[k].source == nodesOption[m].id) {
                                options.series[0].lineStyle.opacity = 1; //通过修改该节点的透明度来实现高亮的效果
                            }
                        }
                    } else {
                        nodesOption[m].itemStyle.opacity = 0.1;
                    }
                    options.series[0].lineStyle.opacity = 0.1;
                }
                myChart1.setOption(options);
            },
            handleRadio () {
                let myChart1 = echarts.init(document.getElementById('relate_graph3'));
                let options = myChart1.getOption();
                if (this.radio1 === '1') {
                    options.series[0].label.show = true;//控制是否显示label
                } else {
                    options.series[0].label.show = false;//控制是否显示label
                }
                // console.log(options, 'options');
                myChart1.setOption(options);
            },
             handleRadio1 () {
                let myChart1 = echarts.init(document.getElementById('relate_graph3'));
                let options = myChart1.getOption();
                let myIMG = '
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/youlinaixu/article/details/84860745

智能推荐

c# 调用c++ lib静态库_c#调用lib-程序员宅基地

文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib

deepin/ubuntu安装苹方字体-程序员宅基地

文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang

html表单常见操作汇总_html表单的处理程序有那些-程序员宅基地

文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些

PHP设置谷歌验证器(Google Authenticator)实现操作二步验证_php otp 验证器-程序员宅基地

文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器

【Python】matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距-程序员宅基地

文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距

docker — 容器存储_docker 保存容器-程序员宅基地

文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器

随便推点

网络拓扑结构_网络拓扑csdn-程序员宅基地

文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn

JS重写Date函数,兼容IOS系统_date.prototype 将所有 ios-程序员宅基地

文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios

如何将EXCEL表导入plsql数据库中-程序员宅基地

文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql

Git常用命令速查手册-程序员宅基地

文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...

分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120-程序员宅基地

文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120

【C++缺省函数】 空类默认产生的6个类成员函数_空类默认产生哪些类成员函数-程序员宅基地

文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数

推荐文章

热门文章

相关标签