TWaver HTML5之树形布局

转眼间春节假期已经过完,作为一个职业的程序猿,不知道大家有没有这样的感觉,一天不碰电脑,总觉得生活少点什么。今天是春节后上班的第三天,给大家分享一下我们前段时间的一个需求,需求是这样的:界面中的网元分为不同的域,比如一级域,二级域,三级域,….N级域,而且不同域之间会有连线。对于这个需求,按照常规的想法,使用group岂不是很简单,一级域是一个group,二级域也是一个group,二级域的group是一级域的父亲,以此类推。但是这样有个问题,如果域比较多,会造成group的过度嵌套,界面中group多了之后,不仅用户体验下降,而且会严重影响性能,所以倒不如直接用树,可以很直观的体现各个域之间的层级关系。

下面是布局的代码,代码很简单,相信熟悉twaver的人很容易看懂。

function layoutRing(){
    //setup all group rings.
    var groups={};
    box.forEach(function(data){
      if(data instanceof twaver.Node){
        var node=data;
        node.setClient(‘x‘, node.getLocation().x);
        node.setClient(‘y‘, node.getLocation().y);
        var groupName=data.getClient(‘group‘);
        if(!groups[groupName]){
          groups[groupName]=[];
        }
        var rings=groups[groupName];
        var level=parseInt(node.getClient(‘level‘));
        if(rings.length<=level){
          rings.push([]);
        }
        var ring=rings[level];
        ring.push(node);
      }
    });

    cleanConnections();
    layouter.doLayout(‘topbottom‘);   

    for(var groupName in groups){
      //get this group bounds.
      var x1=undefined, y1=undefined, x2=undefined, y2=undefined;
      var rings=groups[groupName];
      for(var level=0;level<rings.length; level++){
        var ring=rings[level];
        for(var index=0;index<ring.length;index++){
          var node=ring[index];
          x1=x1 ? Math.min(x1, node.getLocation().x) : node.getLocation().x;
          y1=y1 ? Math.min(y1, node.getLocation().y) : node.getLocation().y;
          x2=x2 ? Math.max(x2, node.getLocation().x) : node.getLocation().x;
          y2=y2 ? Math.max(y2, node.getLocation().y) : node.getLocation().y;

          var target=box.getDatas().get(Math.floor(Math.random()*box.size()));
          if(target instanceof twaver.Node && target!==node){
            var connection=new twaver.Link(node, target);
            connection.setStyle(‘link.width‘,0.2);
            connection.setStyle(‘link.color‘, ‘#aaaaaa‘);
            connection.setClient(‘connection‘,true);
            connection.setClient(‘angle‘, (target.getClient(‘angle‘)+node.getClient(‘angle‘))/2);
            box.add(connection);
          }
        }
      }
      var width=x2-x1;
      var height=y2-y1;           

      //layout each ring for this group.
      for(var level=0;level<rings.length; level++){
        var ring=rings[level];
        for(var index=0;index<ring.length;index++){
          var node=ring[index];
          var radius=node.getLocation().y-y1;
          var range=Math.PI*2;
          var angle=(node.getLocation().x-x1)/width * range;
          if(level>1 && (level==rings.length-1 || rings.length<4)){
            angle=node.getParent().getClient(‘angle‘)+(angle-node.getParent().getClient(‘angle‘))/3;
          }
          var x=radius*Math.cos(angle);
          var y=radius*Math.sin(angle);

          node.setLocation(node.getClient(‘x‘),node.getClient(‘y‘));
          node.setClient(‘angle‘, angle);
          move(node, x, y);
        }
      }
    }
   }

  

布局中的可以加入动画效果,提升用户体验,关于动画的相关文档可以参考文档:

function move(node, x, y){
    var x0=node.getClient(‘x‘);
    var y0=node.getClient(‘y‘);
    new twaver.Animate({
          from: { x: x0, y: y0 },
          to: { x: x, y: y },
          type: ‘point‘,
          delay: 100,
          dur: 1000,
          easing: ‘easeNone‘,
          onUpdate: function (value) {
            node.setLocation(value.x, value.y);
          }
        }).play();
   }

如果有对这个示例感兴趣的朋友,可以发邮件索取相关代码,邮箱地址:[email protected]

时间: 2024-07-28 16:40:47

TWaver HTML5之树形布局的相关文章

TWaver HTML5 (2D)----数据元素

概述 数据元素是数据模型的基本要素,用于描述图形网元,业务网元,或者纯数据.TWaver HTML5中所有数据元素都继承自twaver.Data.为不同功能的需求,预定义了三类数据类型:twaver.Element,twaver.Alarm,twaver.Layer,分别用来描述拓扑的网元,告警和图层.其中拓扑网元扩展定义了十几种网元类型,用以描述丰富的拓扑网元特性,其中最常用的几类拓扑网元包括:Node.Link.Group.SubNetwork.Grid等,TWaver中网元的继承关系如下图

TWaver html5 + NodeJS + express + websocket.io + redis 快速搭建项目(一)

最近看到TWaver 的html5版本即将发布了,于是今天用TWaver HTML5 + NodeJS + express + websocket.io + redis搭建了一个简单原型.先发出几张效果图给大家尝尝鲜.界面添加.修改以及删除网元后,会自动增量存库,并广播更新. 看看这个广播实现的效果,可以在手机上接受任何操作: 最后再来个告警广播的效果图 在后续的文章中会给大家详细的讲解具体技术的实现.

html5 响应式布局(媒体查询)

响应式布局 响应式布局,简而言之,就是一个网站能够兼容多个终端--而不是为每个终端做一个特定的版本.这个概念是为解决移动互联网浏览而诞生的. 响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验,而且随着目前大屏幕移动设备的普及,用"大势所趋"来形容也不为过.随着越来越多的设计师采用这个技术,我们不仅看到很多的创新,还看到了一些成形的模式. html5/css3响应式布局介绍及设计流程,利用css3的media query媒体查询功能.移动终端一般都是对css3支持比较好的

浅谈html5 响应式布局

一.什么是响应式布局? 响应式布局是Ethan Marcotte在2010年5月份提出的一个概念,简而言之,就是一个网站能够兼容多个终端——而不是为每个终端做一个特定的版本. 这个概念是为解决移动互联网浏览而诞生的.响应式布局可以为不同终端的用户提供更加舒适的界面和更好的用户体验,而且随着目前大屏幕移动设备的普及,用大势所趋来形容也不为过. 随着越来越多的设计师采用这个技术,我们不仅看到很多的创新,还看到了一些成形的模式. 二.响应式布局有哪些优点和缺点?   优点: 面对不同分辨率设备灵活性强

html5新增的布局标签

article 表示一篇任何形式的文章.即新闻报道.论坛帖子或博客文章(标题.时间.作者等与文章息息相关的信息) aside 独立于页面主体的一个完整的内容块.例如,附注栏,其中包含与主体文章相关的内容或链接 figure.figcaption 表示一幅插图.figcaption为标注图题,figure标注figcaption和插入图片的img.图片和图题是关联的 footer 表示页面底部的页脚.html5规范规定,只能包括版权声明.简单的链接等.当页脚很庞大时,应该用div之类的元素包含,然

html5 响应式布局

响应式布局 第一:正确理解响应式布局 响应式网页设计就是一个网站能够兼容多个终端-而不是为每个终端做一个特定的版本.打个比方来说:现在社会有很多响应产品,例如折叠沙发,折叠床等等,当我们需要把沙发放到一个角落的时候,此刻沙发就好比div吧,而角落里的某个地方就好比父元素,由于父元素空间的改变,我们不得不调整div,让它能够依然放在角落里.在项目中你会遇到不同的终端,由于终端分辨率不同,所以你要想让用户体验更好,就必要让你的页面能够兼容多个终端. 第二:响应式设计的步骤 响应式设计的步骤就是1.编

html5响应式布局

1.media控制布局 <link type="text/css" rel="stylesheet" href="css04.css" media="only screen and (max-width:640px)"> <style> @media screen and (max-width:600px) { body{ background-color: aquamarine; } } @media

Html5笔记 表格 布局

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>HTML5学习笔记</title> <style type="text/css"> p{ color: #ffff00; } body { margin: 0px; } #container { width: 100%; he

html5/css3常规布局

<!DOCTYPE html><html><head><meta charset="utf-8"><meta name="viewport"content="initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"><meta name="apple-mobile-web-app-