【D3.js数据可视化系列教程】(三十五)-- 矩形树

原创 2013年12月05日 23:11:42

背景介绍

TreeMap由Ben Shneiderman于1991年推出,TreeMap递归细分面积成矩形。与邻接图相比,树中任何节点的大小迅速显现出来。树形图是使用颜色区分类别,用嵌套的方形表示层次关系的布局。例如本例中,A包含B,B包含C...D包含E,每一类的颜色都一样,且每一类互不相同。

D3中相关API可以参考Treemap-Layout

主要应用:NewsMap是一个TreeMap的典型应用,它是一个新闻聚合网站,该网站在2007年11月就已经上线近4年,数据来源于Google News。NewsMap用树形图可视化展现新闻标题,其中不同颜色代表不同新闻类别,不同大小代表不同数量。

知乎上有一个Treemap的简介,讲诉了树形图的历史,实现技术和主要应用:来,认识一下这个数据可视化中的90后:Treemap

NewsMap示例


D3矩形树示例

绘制矩形树

<!DOCTYPE html>
<head>
<meta charset="utf-8">
<title>testD3-33-paddingTree.html</title>
<style>

.node {
  border: solid 1px white;
  font: 10px sans-serif;
  line-height: 12px;
  overflow: hidden;
  position: absolute;
  text-indent: 2px;
}

</style>
</head>
<body>
<script src="http://localhost:8080/spring/js/d3.v3.js" charset="utf-8" ></script>


<script type="text/javascript">
var width = 960,
    height = 500;

var color = d3.scale.category20c();//20种颜色

//(1)填充树
var treemap = d3.layout.treemap()//使用递归的空间分割来显示节点的树。
    .size([width, height])//指定x和y的布局大小。
    .padding(4)//指定一个父及其子之间的填充。
    .value(function(d) { //获取或设置树形细胞的大小。
    return d.size/2; 
    });
    
//(2)设置每个树细胞用div存放
var div = d3.select("body").append("div")
    .style("position", "relative")//位置相依,作用没看出来?
    .style("width", width + "px")
    .style("height", height + "px");
//(3)设置每个树细胞各个属性
d3.json("http://localhost:8080/spring/D3data/paddingTree.json", 
	function(error, root) {
  div.selectAll(".node")
      .data(treemap.nodes(root))//计算树形布局和返回节点的数组。
    .enter().append("div")
      .attr("class", "node")
      .style("left", function(d) { return d.x + "px"; })
      .style("top", function(d) { return d.y + "px"; })
      .style("width", function(d) { return Math.max(0, d.dx - 1) + "px"; })
      .style("height", function(d) { return Math.max(0, d.dy - 1) + "px"; })
      
      .style("background", function(d) { //只为有孩子的节点赋值,也就是说叶子节点的背景颜色都是他爸爸的颜色
      	return d.children ? color(d.name) : null; 
      })
      .text(function(d) { //同理,孩子设置文字,爸爸没有
      	return d.children ? null : d.name; 
      });
});
</script>


</body>


 

版权声明:本文为博主原创文章,未经博主允许不得转载。

【 D3.js 高级系列 — 4.0 】 矩阵树图

矩阵树图(Treemap),也是层级布局的扩展,根据数据将区域划分为矩形的集合。矩形的大小和颜色,都是数据的反映。...
  • lzhlzz
  • lzhlzz
  • 2015年04月04日 10:37
  • 6035

D3treemap布局

form{ font-family:"Helvetica Neue",Arical, sans-serif; } svg{ font: 10px sans-serif; } va...
  • a197p
  • a197p
  • 2017年12月16日 11:47
  • 36

d3:data and datum

datum是在一项元素后面添加,把所有数据添加到一项元素中。 data则是运用data enter exit3个函数去捆绑数据...
  • a197p
  • a197p
  • 2018年01月12日 15:48
  • 11

D3.js中Treemap(矩形树图)源码详解

Treemap(矩形树图)聊一聊Treemap,即矩形树图,树形结构非常有意思的一种展现方式,外形规整而不失表达力。 矩形树状结构图(Treemap)是一种有效的实现层次结构可视化的图表结构,简称...
  • wan353694124
  • wan353694124
  • 2018年01月03日 10:35
  • 174

【 D3.js 入门系列 --- 9 】 常见可视化图形

Layout 是 D3 中 “制作常见图形的函数”,用 Layout 可以轻松地对输入数据进行转换,使得它能容易地适应可视化图形使用的需要。...
  • lzhlzz
  • lzhlzz
  • 2014年07月13日 10:39
  • 11540

D3树图数据结构例子

  • 2015年01月12日 12:00
  • 10KB
  • 下载

【 D3.js 入门系列 --- 10.2 】 可拖动的地图

本文是结合地图和力学图制作的一个可拖动的地图。用户可以自由的用手拖动中国的各省。...
  • lzhlzz
  • lzhlzz
  • 2014年09月03日 10:35
  • 12425

大量 D3.js 示例

D3.js 是一个基于数据操作文档JavaScript库。D3帮助你给数据带来活力通过使用HTML、SVG和CSS。D3重视Web标准为你提供现代浏览器的全部功能,而不是给你一个专有的框架。结合强大的...
  • npf_java
  • npf_java
  • 2015年10月16日 22:34
  • 10741

大量 D3.js 示例 (open经验库)

D3.js 是一个基于数据操作文档JavaScript库。D3帮助你给数据带来活力通过使用HTML、SVG和CSS。D3重视Web标准为你提供现代浏览器的全部功能,而不是给你一个专有的框架。结合强大的...
  • wanziidianxia
  • wanziidianxia
  • 2014年10月09日 16:07
  • 3962

[d3.js] D3.JS 基于javascript的图表展示库<一>----简单介绍

先什么都不说。一起来看看d3.js神奇效果。 打开https://github.com/mbostock/d3/wiki/Gallery 这里有很多d3.js的Demo。 这个东西图表确实很不错吧...
  • a6383277
  • a6383277
  • 2013年03月15日 13:26
  • 15731
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【D3.js数据可视化系列教程】(三十五)-- 矩形树
举报原因:
原因补充:

(最多只允许输入30个字)