【D3.js数据可视化系列教程】(三十五)-- 矩形树
来源:互联网 发布:有网络app store连不上 编辑:程序博客网 时间:2024/05/17 02:06
背景介绍
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数据可视化系列教程】(三十五)-- 矩形树
- 【D3.js数据可视化系列教程】--(三)数据绑定
- 【D3.js数据可视化系列教程】--(四)使用数据
- 【D3.js数据可视化系列教程】--(一)简介
- 【D3.js数据可视化系列教程】--(六)生成测试数据
- 【D3.js数据可视化系列教程】--(七)SVG初探
- 【D3.js数据可视化系列教程】--(十一)散点图
- 【D3.js数据可视化系列教程】--(十二)比例尺
- 【D3.js数据可视化系列教程】--(十三)坐标轴
- 【D3.js数据可视化系列教程】(二十八)--弦图
- 【D3.js数据可视化系列教程】(三十四)-- sankey图
- 【D3.js数据可视化系列教程】(三十六)-- 冰柱图
- 【D3.V3.js数据可视化系列教程】--(一)简介
- 【D3.V3.js数据可视化系列教程】--(十一)散点图
- 【D3.js数据可视化系列教程】(二十八)--弦图
- 【D3.js数据可视化系列教程】(二十七)--径向树
- 【D3.js数据可视化系列教程】(二十九)--折叠树
- 【D3.js数据可视化系列教程】--(八)使用D3绘制SVG
- hdu 2594 Simpsons’ Hidden Talents(KMP)
- 1.1 编写一个简单的C++程序【C++ Primer中文版(第5版)】
- Unity手游之路<二>Java版服务端使用protostuff简化protobuf开发
- SVN单机版配置
- TDD与FDD技术对比
- 【D3.js数据可视化系列教程】(三十五)-- 矩形树
- 如何获取设备唯一标识
- 1.1.1 编译、运行程序【C++ Primer中文版(第5版)】
- DJANGO book学些笔记之:URLConf技巧
- 1782:谁是你的潜在朋友
- 不要被阶乘吓倒(二进制表示中最低位1的位置 )
- 1782:谁是你的潜在朋友
- 2013-12-5关于指针的一个注意
- php.ini详解