d3.js入门

d3入门

D3是一个强大的数据可视化工具,它是基于Javascript库的,用于创建数据可视化图形。在生成可视化图形的过程中,需要以下几步:
  1. 把数据加载到浏览器的内存空间;
  2. 把数据绑定到文档中(这里的文档指的是html文档)的元素,根据需要创建新元素;
  3. 解析每个元素范围内的数据并为其设置相应的可视化属性,实现元素的变换(transforming);
  4. 响应用户输入实现元素状态的过渡(transitioning);

SVG

D3最适合用来生成和操作SVG(Scalable Vector Graphics,可伸缩矢量图形)。SVG是一种文本格式,每个SVG都是使用类似于html标记来定义的。在SVG标签中可以嵌入很多可见的元素,包括rect(矩形)、circle(圆形)、ellipse(椭圆形)、line(直线)、text(文本)和path()。下面是简单的定义SVG以及各种嵌入其中的图形。
  • SVG

<svg width="500" height="50"></svg>

在这里像素是默认的计量单位,不必加上"px"。

  • rect
rect用于绘制矩形。x和y用于指定矩形左上角的坐标(基于像素的坐标系统的原点通常位于画布的左上角),而width和height用于指定其宽和高。
<rect x="0" y="0" width="500" height="50"/>
  • circle
circle用于绘制圆形。cx和cy用于指定圆心坐标,而r用于指定半径。
<circle cx="250" cy="25" r="25"/>
ellipse与circle 类似,只不过每个轴要分别指定半径。因此,半径属性不再是r,而是rx和ry。
<ellipsecx="250" cy="25" rx="100" ry="25"/>
  • line
line用于绘制直线。x1和y1用于指定起点坐标,x2和y2用于指定终点坐标。另外,必须用stroke指定直线的颜色才能看得见。
<linex1="0" y1="0" x2="500" y2="50" stroke="black"/>
  • text
text用于绘制文本。x用于指定文本左上角的位置,y用于指定字体的基线位置。<text x="250" y="25">Easy-peasy</text>
  • path
path用于绘制前面图形之外的其他复杂图形(如地图上的国境线)。
1.3 svg元素的样式
常见的svg属性有下面这些。
fill
图形填充的颜色值
stroke
图形轮廓的颜色值
stroke-width
图形轮廓的宽度
opacity
0.0(完全透明)到1.0(完全不透明)之间的数值
对于文本d3还可以使用font-famliy和font-size这两个属性。
svg中没有"层"和深度的概念,如果多个图形重叠,那么就会出现遮盖的情况。可以在为fill或stroke属性指定颜色的时候使用rgba()。rgba()接受0到255
(包含及)之间的三个值,分别代表红、绿、蓝,还接受第四个0.0到1.0(包含及) 之间的透明度值。
例如下面的这段代码:
<rect x="0" y="0" width="30" height="30" fill="purple"/>
<rect x="20" y="5" width="30" height="30" fill="blue"/>
<rect x="40" y="10" width="30" height="30" fill="green"/>
<rect x="60" y="15" width="30" height="30" fill="yellow"/>
<rect x="80" y="20" width="30" height="30" fill="red"/>

d3.j3语法

基本语法

d3对DOM元素的选择类似于JQuery,如下:
d3.select("body").append("p").text("New paragraph!");
记住一点:在连缀方法时,次序很重要。每个方法的输出必须与下一个方法 期待的输入匹配。如果相邻的输出和输入不匹配,那么结果就像在接力赛跑中把接力棒扔到地上一样。
将数据绑定到DOM元素上,绑定的意思就是把数据“附加”或关联到特定的元素。
    var dataset = [ 5, 10, 15, 20, 25 ];
    d3.select("body").selectAll("p")
    .data(dataset)
    .enter()
    .append("p")
    .text("New paragraph!");
  • 选择DOM中的body元素,把它交给连缀方法中的下一个方法。
  • 选择DOM中的所有段落。因为还没有段落,所以返回空元素。可以认为这个空 元素代表马上就会创建的段落。
  • 解析并数出数据值。dataset数组中有5个值,因而此后的所有方法都将执行五 遍,每次针对一个值。
  • 要创建新的绑定数据的元素,必须使用enter()。这个方法会分析当前选择的 DOM元素和传给它的数据,如果数据值比对应的DOM元素多,就创建一个新的占位元素。然后把这个新占位元素的引用交给链中的下一个方法。
  • 取得由enter()创建的空占位元素,并把一个p元素追加到相应的DOM中。然后它再把自己刚创建的元素交给链中的下一个方法。
  • 取得新创建的p元素,插入文本值。

一个简单的矩形绘制

    //svg元素的宽和高
var w = 500;
var h = 100;
//不同div元素之间的间隔
var barPadding = 1; var dataset = [ 5, 10, 13, 19, 21, 25, 22, 18, 15, 13,
11, 12, 15, 20, 18, 17, 16, 18, 23, 25 ]; //创建svg元素,制定svg元素的宽和高
var svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
//创建矩形
svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("x", function(d, i) {
//返回每个矩形的x坐标轴,从左到右
return i * (w / dataset.length);
})
.attr("y", function(d) {
//返回每个矩形的Y坐标轴,从上到下
return h - (d * 4);
})
//每个矩形的宽度,减去barPadding,是为了元素之间存在间隔
.attr("width", w / dataset.length - barPadding)
//每个矩形的高度
.attr("height", function(d) {
return d * 4;
})
//为每个矩形填充颜色
.attr("fill", function(d) {
return "rgb(0, 0, " + (d * 10) + ")";
});
//为每个矩形添加标记
svg.selectAll("text")
.data(dataset)
.enter()
.append("text")
.text(function(d) {
return d;
})
.attr("text-anchor", "middle")
//这里文本选择在矩形的中央偏下方
.attr("x", function(d, i) {
return i * (w / dataset.length) + (w / dataset.length - barPadding) / 2;
})
.attr("y", function(d) {
return h - (d * 4) + 14;
})
//为文本添加css
.attr("font-family", "sans-serif")
.attr("font-size", "11px")
.attr("fill", "white");


创建散点图

//Width and height
var w = 500;
var h = 100;
//主数组表示每个数据“点”元素,每个子数组包含x坐标和y坐标
var dataset = [
[5, 20], [480, 90], [250, 50], [100, 33], [330, 95],
[410, 12], [475, 44], [25, 67], [85, 21], [220, 88]
]; //Create SVG element
var svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("circle")
.data(dataset)
.enter()
.append("circle")
.attr("cx", function(d) {
return d[0];
})
.attr("cy", function(d) {
return d[1];
})
.attr("r", function(d) {
return Math.sqrt(h - d[1]);
});
//这里是绘制标签
svg.selectAll("text")
.data(dataset)
.enter()
.append("text")
.text(function(d) {
return d[0] + "," + d[1];
})
.attr("x", function(d) {
return d[0];
})
.attr("y", function(d) {
return d[1];
})
.attr("font-family", "sans-serif")
.attr("font-size", "11px")
.attr("fill", "red");




d3.js读书笔记-1的更多相关文章

  1. d3.js读书笔记-2

    比例尺 比例尺基本内容 比例尺是一组把输入域映射为输出范围的函数.任意数据集中的值不可能恰好与图表中的像素尺度一一对应.比例尺就是把这些数据值映射为可视化图形中使用的新值的便捷手段.D3的比例尺就是那 ...

  2. js读书笔记

    js读书笔记 基本类型的基本函数总结 1. Boolean() 数据类型 转换为true的值 转换为false的值 Boolean true false String 任何非空字符串 "&q ...

  3. D3.js学习笔记(六)——SVG基础图形和D3.js

    目标 在这一章,我们将会重温SVG图形,学习如何使用D3.js来创建这些图形. 这里会包括前面例子中的SVG基础图形以及如何使用D3.js设置图形的属性. 使用D3.js画一个SVG 的 圆 circ ...

  4. d3.js学习笔记(五)——将数据结构化为D3.js可处理的

    目标 在这一章,你将会理解如何对数据进行结构化,来更好的使用D3.js. 我们将会回顾我们之前已经学习的,学习D3.js如何使用选集(selections),JavaScript对象基础,以及如何最优 ...

  5. D3.js学习笔记(四)—— 使用SVG坐标空间

    目标 在这一章,你将要使用D3.js基于一些数据把SVG元素添加到你想要的坐标位置上. 我们的目标就是使用下面的数据集: var spaceCircles = [30,70,110]; 并使用D3.j ...

  6. D3.js学习笔记(三)——创建基于数据的SVG元素

    目标 在这一章,你将会使用D3.js,基于我们的数据来把SVG元素添加到网页中.这一过程包括:把数据绑定到元素上,然后在使用这些元素来可视化我们的数据. 注意:不同于前几章,我们从一个完整的代码开始, ...

  7. D3.js学习笔记(二)——使用绑定在DOM上的数据

    简单例子 在这个例子中,你将会使用D3.js来将数据绑定到DOM元素上.然后再使用D3.js利用绑定到DOM元素上的数据来更新网页. 在上一章中,我们以下面这个页面作为开始的: <!DOCTYP ...

  8. D3.js学习笔记(一)——DOM上的数据绑定

    开始学习D3.js,网上没有找到很满意的中文教程,但是发现了一个很好的英文教程,讲解的非常详细.从一个初始简单的HTML网页开始,逐步加入D3.js的应用,几乎是逐句讲解.学习的时候,就顺便翻译成中文 ...

  9. 精通D3.js学习笔记(2)比例尺和坐标

    1.线性比例尺 d3.scale.linear()   创建一个线性比例尺           .domain([0,500]) 定义域           .range([0,1000]) 值域 l ...

随机推荐

  1. 基于Redis的爬虫平台的实现

    一.需求: 1.数据抓取:目标数据的下载.解析.入库功能. 2.数据服务:黑名单.灰名单等查询服务. 3.平台监控:平台各个模块的数据实时监控. 二.WEB端效果展示: 三.架构设计 下载器.解析器. ...

  2. Sublime、Webstorm,还有CLI、Atom,这些开发工具的更新你清楚吗?

    APICloud App开发平台一直在不断升级开发工具库,这一年增加了众多开发工具.目的就是让开发者可以选择使用任何自己喜欢的HTML5开发工具去开发App. 那么2016年到现在,这些开发工具都有了 ...

  3. winserver2008 management note

    1,磁盘online及介质保护 Windows server 2008 增加的磁盘无法初始化-提示:介质受写入保护.插了下相关说明,在VMware的帖子找到了解决办法: 开始-运行,cmd.打开命令提 ...

  4. python入门到精通[三]:基础学习(2)

    摘要:Python基础学习:列表.元组.字典.函数.序列化.正则.模块. 上一节学习了字符串.流程控制.文件及目录操作,这节介绍下列表.元组.字典.函数.序列化.正则.模块. 1.列表 python中 ...

  5. Quartus II USB-Blaster驱动解决

    Quartus II USB-Blaster驱动解决 之前安装Quartus II 13.0,但FPGA开发板链接的USB-Blaster链接无法被Quartus识别,改装Quartus II 11. ...

  6. c++ 解包tar

    首先我们来看tar文件组成 tar中的数据都是以512字节为单位:tar由三部分组成 “头部+内容+尾部”,其中头部是512字节的头部结构,内容是存放一个文件内容的地方,最后尾部是一个512字节的全零 ...

  7. 与资源库同步时,我的svn报错 Previous operation has not finished; run 'cleanup' if it was interrupted

    解决办法:选择你的项目,右键,小组(Team),刷新或清理(Refresh or Clean)即可.

  8. 19.在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?)写出http常见的状态码和含义,至少5个.[完善题目]

    状态401代表未被授权,header("Location:www.xxx.php"); 100-199 用于指定客户端应相应的某些动作. 200-299 用于表示请求成功. 300 ...

  9. TCPReplay使用---张子芳

    TCPReplay主要功能是将PCAP包重新发送,用于性能或者功能测试.但是在测试环境与原转包系统结构一般是不同的.比如被测试机的二层MAC地址与抓包机器的MAC不同,所以被测试机在二层处理时发现目的 ...

  10. 在ABP模板工程中使用MySql

    1 下载一个新的ABP模板项目 http://www.aspnetboilerplate.com/ 2 在Windows上安装MySql, 创建一个新的数据库 sampledb https://dev ...