【 D3.js 进阶系列 — 6.1 】 缩放的应用(Zoom)
2016-11-25 17:46
344 查看
缩放(Zoom)是另一种重要的可视化操作,主要是使用鼠标的滚轮进行。
第 3 行:当 zoom 事件发生时,调用 zoomed 函数
第 5 - 8 行:zoomed 函数,用于更改需要缩放的元素的属性,d3.event.translate 是平移的坐标值,d3.event.scale 是缩放的值。
源代码单击以下链接后查看:
http://www.ourd3js.com/demo/J-6.1/zoom.html
谢谢阅读。
发表日期:2014 年 12 月 28 日
更多内容:OUR D3.JS - 数据可视化专题站 和 CSDN个人博客
备注:本文发表于 OUR D3.JS ,转载请注明出处,谢谢
1. zoom 的定义
缩放是由 d3.behavior.zoom() 定义的。var zoom = d3.behavior.zoom() .scaleExtent([1, 10]) .on("zoom", zoomed); function zoomed() { circles_group.attr("transform", "translate(" + d3.event.translate + ")scale(" + d3.event.scale + ")"); }第 2 行:scaleExtent 用于设置最小和最大的缩放比例
第 3 行:当 zoom 事件发生时,调用 zoomed 函数
第 5 - 8 行:zoomed 函数,用于更改需要缩放的元素的属性,d3.event.translate 是平移的坐标值,d3.event.scale 是缩放的值。
2. 绘制圆
与【进阶 - 第 6.0 章】一样,绘制两个圆用于测试。只是将圆 circle 元素添加到一个组 g 里,g 元素调用 call(zoom),zoom 为刚才定义的缩放行为。var circles_group = svg.append("g") .call(zoom); circles_group.selectAll("circle") .data(circles) .enter() .append("circle") .attr("cx",function(d){ return d.cx; }) .attr("cy",function(d){ return d.cy; }) .attr("r",function(d){ return d.r; }) .attr("fill","black");
3. 结果
结果如下,在圆上滑动鼠标滚轮试试:源代码单击以下链接后查看:
http://www.ourd3js.com/demo/J-6.1/zoom.html
谢谢阅读。
文档信息
版权声明:署名(BY)-非商业性(NC)-禁止演绎(ND)发表日期:2014 年 12 月 28 日
更多内容:OUR D3.JS - 数据可视化专题站 和 CSDN个人博客
备注:本文发表于 OUR D3.JS ,转载请注明出处,谢谢
相关文章推荐
- 【 D3.js 进阶系列 — 6.1 】 缩放的应用(Zoom)
- 【 D3.js 进阶系列 — 6.0 】 拖拽的应用(Drag)
- 【 D3.js 进阶系列 — 1.0 】 CSV 表格文件的读取
- Win10系列:C#应用控件进阶2
- 【 D3.js 进阶系列 — 1.1 】 其它表格文件的读取
- 【 D3.js 进阶系列 — 6.2 】 饼状图的拖拽
- Win10系列:C#应用控件进阶3
- Windows Mobile 进阶系列.多窗体应用的性能与编程调试
- JavaScript进阶系列02,函数作为参数以及在数组中的应用
- 【 D3.js 进阶系列 — 6.2 】 饼状图的拖拽
- Win10系列:C#应用控件进阶4
- 【 D3.js 进阶系列 — 1.0 】 CSV 表格文件的读取
- 【 D3.js 进阶系列 — 3.0 】 分区图
- 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定
- Win10系列:C#应用控件进阶5
- 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定
- 【 D3.js 进阶系列 — 2.2 】 力学图的参数
- IOS自动布局进阶系列视频教程-02scrollView自动布局中的应用
- 【 D3.js 进阶系列 — 3.1 】 圆形分区图
- Win10系列:C#应用控件进阶6