visjs 绘图 图标 动态添加数据

Wesley13
• 阅读 723

近期弄个显示例图,主要表示关系图,就找到了visjs,很好很强大,就是资料较少,只能从网站的例子去找自己想要的东西  http://visjs.org/network\_examples.html,从系统的样例中寻找自己所需要的,下面就显示一些我需要的,

function doEchartsFun(data){
        obj = data;    
        //    vis
        var nodes = null;
        var edges = null;
        var network = null;
    
        var LENGTH_MAIN = 350,
            LENGTH_SERVER = 150,
            LENGTH_SUB = 50,
            WIDTH_SCALE = 2,
            RED = 'red',
            ORANGE = 'orange',
            ERROR='black',
            GRAY = 'yellow';
    
        nodes = [];
        edges = [];
        // console.log(data)
        for(var i = 0;i < data.hostlist.length;i++){
            nodes.push(obj.hostlist[i]);
        }
         for(var i = 0;i < data.line.length;i++){
            edges.push(obj.line[i]);
        }
        // 添加图例
        // var mynetwork = document.getElementById("ec");
        // var x = - mynetwork.clientWidth -200 ;
        // var y = - mynetwork.clientHeight -50 ;
        // var step = 70;
        // nodes.push({id: 1000, x: x, y: y, label: '',group: 'sj', value: 10, fixed: true, physics:false});
        // nodes.push({id: 1001, x: x, y: y + step, label: '', group: 'fk', value: 10, fixed: true,  physics:false});
        // nodes.push({id: 1002, x: x, y: y + 2 * step, label: '', group: 'wj', value: 10, fixed: true,  physics:false});
        // nodes.push({id: 1003, x: x, y: y + 3 * step, label: 'Computer', group: 'desktop', value: 1, fixed: true,  physics:false});
        // nodes.push({id: 1004, x: x, y: y + 4 * step, label: 'Smartphone', group: 'mobile', value: 1, fixed: true,  physics:false});
       removeLoading('test');
          // create a network
        var container = document.getElementById('ec');
        var data = {
            nodes: nodes,
            edges: edges
        };
        var options = {
            nodes: {
                font:{
                   color: "white", //字体的颜色
                   size: 30  //显示字体大小
                },
               
                scaling: {
                  min: 16,
                  max: 32   //缩放效果比例
                },
                borderWidth: 0,
                color: {
                border: 'white',   
                background: 'white'  若是引用图标,背景颜色
               },
            },


            groups: {
                  "ws":{  //系统定义的形状 dot等  这些官网都可以找到
                       shape:'dot',
                       color:"white"
                  }
            },
            edges: { 连接线的样式
             color: {
                  color:'white',
                  highlight:'white',
                  hover: '#848484',
                  inherit: 'from',
                  opacity:1.0
                },
            },
            layout:{
                 randomSeed:1,//配置每次生成的节点位置都一样,参数为数字1、2等
             },
            physics:{
              barnesHut:{gravitationalConstant:-30000},
              stabilization: {iterations:2500}
            },
            interaction: {
//                navigationButtons: true,
                 hover: true,//鼠标移过后加粗该节点和连接线
                 selectConnectedEdges:false,//选择节点后是否显示连接线
                 hoverConnectedEdges:false,//鼠标滑动节点后是否显示连接线
                 tooltipDelay:200,
                 zoomView:true//是否能缩放画布
             },

            edges: {
                 shadow:true,//连接线阴影配置
                 smooth: true,//是否显示方向箭头
//                 arrows: {to : true }//箭头指向from节点
             }
          };
        network = new vis.Network(container, data, options);
        var nodes_data = network.body.data.nodes._data;
        network.on("click", function(params) {  //每个点的操作时间,官网有详细案例可查询
            // var ip = params.nodes;  
            // console.log(params)
            // if(ip != ""){
            //     $.ajax({
             //     url:"/homes/",
             //     type:"get",
             //     dataType:"JSON",
             //     data:{
             //         whichIP:ip
             //     },
             //     beforeSend:function(xhr){
             //
             //     },
             //     success:function(data){
             //      },
             //     error:function(XMLHttpRequest, textStatus, errorThrown){
             //        console.log("连接主机错误,请重启~~!")
             //       }
             //  })
            // }
        });

  最重要的是nodes 和edges的拼接,

point = {"id":id, "label":"显示数据", "shape": 'image', "image": '..\\static\\img\\sypic\\'+group+'.svg'}  //image  指的是显示图片形状,官网还有另外圆形显示,后面的是图片路径line = {"from": y, "to": m}  //线就是简单的from to  。。当然,这都是point固定的id,

接收之后就能只做自己想要的canvas 关系图了,感觉还是蛮不错的效果的,关键是 唬人。。

visjs 绘图 图标  动态添加数据

 但是又有了新的需求了,要求发现一个新的数据就要实时显示在上面,这就用到了一个新的属性(DataSet)

function draw(data) {
            //    vis
        var nodes = null;
        var edges = null;
        var network = null;
        var  nodesArray, nodes, edgesArray, edges, network;
        var LENGTH_MAIN = 350,
            LENGTH_SERVER = 150,
            LENGTH_SUB = 50,
            WIDTH_SCALE = 2,
            RED = 'red',
            ORANGE = 'orange',
            ERROR='black',
            GRAY = 'yellow';

            nodesArray = [];
            edgesArray = [];

            for(var i = 0;i < data.hostlist.length;i++){
                nodesArray.push(obj.hostlist[i]);
            }
             for(var i = 0;i < data.line.length;i++){
                edgesArray.push(obj.line[i]);
            }
            nodes = new vis.DataSet(nodesArray);
            edges = new vis.DataSet(edgesArray);
            setTimeout(function(){
                nodes.add({id:"55854663541321654", shape: "image",label:"haha", image: "../static/img/sypic/web.svg"});
                console.log(nodes)
            },1000)
            setTimeout(function(){
                edges.add({from:"55854663541321654", to:"5b569a9e812e721634a6b2c3",value:"5"});
            },1000)

           removeLoading('test');
           //    create a network
            var container = document.getElementById('ec');
            var data = {
                nodes: nodes,
                edges: edges
            };
            var options = {
                nodes: {
                    font:{
                       color: "white",
                       size: 30
                    },

                    scaling: {
                      min: 16,
                      max: 32
                    },
                    borderWidth: 0,
                    color: {
                    border: 'white',
                    background: 'white'
                   },
                },


            groups: {

            },
            edges: {
             color: {
                  color:'white',
                  highlight:'white',
                  hover: '#848484',
                  inherit: 'from',
                  opacity:1.0
                },
            },
            layout:{
                 randomSeed:1,//配置每次生成的节点位置都一样,参数为数字1、2等
             },
            physics:{
              barnesHut:{gravitationalConstant:-30000},
              stabilization: {iterations:2500}
            },
            interaction: {
//                navigationButtons: true,
                 hover: true,//鼠标移过后加粗该节点和连接线
                 selectConnectedEdges:false,//选择节点后是否显示连接线
                 hoverConnectedEdges:false,//鼠标滑动节点后是否显示连接线
                 tooltipDelay:200,
                 zoomView:true//是否能缩放画布
             },

            edges: {
                 shadow:true,//连接线阴影配置
                 smooth: true,//是否显示方向箭头
//                 arrows: {to : true }//箭头指向from节点
             }
          };
               network = new vis.Network(container, data, options);
        }

  关键看两个定时器添加,到时候把定时器添加的过程用websocket 替换掉就可以,当然,websocket传递过来的数据一定要是新添加过来的数据了,就得数据不能重复了,一定要看清数据数组的名称,以免混乱造成不必要的浪费时间,

只要是新数据添加进去了,dataset就会自动将数据添加到图形当中。

visjs 绘图 图标  动态添加数据

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
待兔 待兔
2个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
2年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
8个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这