D3.js 绘制动态进度条

这次给大家带来D3.js 绘制动态进度条,D3.js 绘制动态进度条的注意事项有哪些,下面就是实战案例,一起来看一下。

D3 是什么

D3 的全称是(Data-Driven Documents),顾名思义可以知道是一个被数据驱动的文档。听名字有点抽象,说简单一点,其实就是一个 JavaScript 的函数库,使用它主要是用来做数据可视化的。如果你不知道什么是 JavaScript ,请先学习一下 JavaScript,推荐阮一峰老师的教程。

JavaScript 文件的后缀名通常为 .js,故 D3 也常使用 D3.js 称呼。D3 提供了各种简单易用的函数,大大简化了 JavaScript 操作数据的难度。由于它本质上是 JavaScript ,所以用 JavaScript 也是可以实现所有功能的,但它能大大减小你的工作量,尤其是在数据可视化方面,D3 已经将生成可视化的复杂步骤精简到了几个简单的函数,你只需要输入几个简单的数据,就能够转换为各种绚丽的图形。有过 JavaScript 基础的朋友一定很容易理解它。

在网站页面加载以及表单提交时,常使用进度条表达加载过程来优化用户体验,常见的进度条有矩形进度条和圆形进度条,如下图所示:

D3.js 绘制动态进度条 

我们经常使用svg或canvas来实现动态图形的绘制,但绘制过程相对较繁琐。对于直观漂亮的进度条,社区也有提供成熟的方案例如highcharts/ECharts等等,但基于配置的开发方式终究无法实现100%的自定义绘制。本文将带你使用D3.js从零一步一步实现动态进度条,并分享代码逻辑原理。

基础要求

了解svg如何绘制基础图形

了解D3.js v4版本

了解如何使用D3.js (v4)绘制svg的基础图形

绘制圆形进度条

对于一个圆形进度条,我们先对其进行任务拆分:

绘制嵌套圆弧

圆心处的实时数据展示

展现动画

美化

1.绘制嵌套圆弧

对于圆形,svg提供现成的 circle 标签供使用,但是其劣势在于,对于圆形进度条使用 circle 可以满足,但对图形进一步扩展时比如绘制半圆, circle 的处理就棘手了。D3.js提供 arc 相关API对圆形的绘制方法进行了封装:

var arc = d3.arc()   .innerRadius(180)   .outerRadius(240)   //.startAngle(0)   //.endAngle(Math.PI)arc(); // "M0,-100A100,100,0,0,1,100,0L0,0Z"

登录后复制

上述代码实现了对两个嵌套圆的绘制逻辑, d3.arc() 返回一个圆弧构造函数,并通过链式调用设置内圆与外圆的半径大小,起始角度与结束角度。执行 arc() 构造函数即可获得用于绑定在 上的路径数据。完整代码如下:

 var arcGenerator = d3.arc().innerRadius(80).outerRadius(100).startAngle(0); var picture = d3.select('svg').append('g').attr('transform','translate(480,250)');

登录后复制

上述代码实现了2个步骤:

1.生成将0度作为起点的圆弧构造器 arcGenerator

2.设置 transform 图形偏移量,令图形在画布中央

目前画布上还没有任何元素,接下来我们实际图形的绘制。

var backGround = picture.append("path")  .datum({endAngle: 2 * Math.PI})  .style("fill", "#FDF5E6")  .attr("d", arcGenerator);

登录后复制

我们对画布 picture 添加 元素,依据 endAngle() 特性,使用 datum() 方法将 {endAngle:Math.PI} 也就是终点角度 2π 绑定到 元素上,并将圆弧构造器赋值给 path 路径 d 。这样就生成了指定背景颜色的圆弧,实际图形如下:

D3.js 绘制动态进度条

第一个圆弧画好了,那么依据svg的层级关系 z-index ,所谓的进度条其实就是覆盖在第一层圆弧之上的第二层圆弧。同理可得:

var upperGround = picture.append('path')  .datum({endAngle:Math.PI / 2})  .style('fill','#FFC125')  .attr('d',arcGenerator)

登录后复制

代码运行后可得:

D3.js 绘制动态进度条 

2.圆心处的实时数据展示

第一部分我们已经实现了基于两个 path 的嵌套圆。第二部分我们来实现圆心处的实时数据展示。 在进度条进行加载时,我们在圆心处添加数据来表达当前的加载进度,使用 标签做展示即可:

var dataText = g.append('text')  .text(12)  .attr('text-anchor','middle')  .attr('dominant-baseline','middle')  .attr('font-size','38px')

登录后复制

暂时将数据设置为12,并设置水平居中和垂直居中,效果如下图:

D3.js 绘制动态进度条 

3.展现动画

通过1,2两部分内容我们已经知道了:

绘制进度条的实质是改变上层弧的角度

当弧度是 2π 时为整圆,当弧度是 π 时为半圆

圆形中的数据即为当前弧度相对 2π 的百分比

综上我们只要改变弧度值和数值同时设定改变过程所需时长即可实现所谓”动画”。在ECharts提供的官方实例中,通过 setInterval 来实现每隔固定一段时间进行数据更新,其实在D3.js中同样提供了类似方法来实现类似 setInterval 的功能:

d3.interval(function(){ foreground.transition().duration(750).attrTween('d',function(d){  var compute = d3.interpolate(d.endAngle,Math.random() * Math.PI * 2);  return function(t){   d.endAngle = compute(t);   return arcGenerator(d);  }   })},1000)

登录后复制

对这段代码进行拆解:

d3.interval() 方法提供了 setInterval() 的功能

selection.transition.duration() 设置了当前DOM属性过渡变化为指定DOM属性的过程所需时间,毫秒为单位

transation.attrTween 为插值功能API,那么何谓插值?

概括来说,在给定的离散数据中补插函数,可以使这条连续函数通过全部数据点。举个例子,给定一个p,想实现其背景颜色的从左边红(red)到右边绿(green)的线性渐变,每一区域的色值该如何计算呢?只需:

var compute = d3.interpolate(d3.rgb(255,0,0),d3.rgb(0,255,0));

登录后复制

compute 即为插值函数,参数范围为[0,1],只要你输入该范围内的数字,那么 compute 函数将返回对应的颜色值。这样的插值有什么用呢?可看下图:

D3.js 绘制动态进度条 

假设上图的p长度width为100,那么将[0,100]依比例关系转化为[0,10]的范围数据并输入 compute 函数中,即可得到某一区域对应的颜色。当然,对于线性面积的处理我们不应该使用离散数据作为输入和输出,所以D3.js提供更方便的线性渐变API d3.linear 等,这里就不展开描述了。

言归正传,代码 d3.interpolate(d.endAngle,Math.random() * Math.PI * 2); 实现了如下插值范围:

[“当前角度值”,”随机角度值”] //表达区间而非数组

而后返回一个参数为 t 的函数,那么该函数的作用是什么呢?

t 参数与 d 类似,是D3.js内部实现的插值,其范围为[0,1]。 t 参数根据设置的 duration() 时长自动计算在[0,1]内合适的插值数量,并返回插值结果,实现线性平稳的过渡动画效果。

完成滚动条的动画加载效果,我们接下来写圆心实时数据的变化逻辑,只要实现简单的赋值即可,完整代码如下:

d3.interval(function(){  foreground.transition().duration(750).attrTween('d',function(d){   var compute = d3.interpolate(d.endAngle,Math.random() * Math.PI * 2);   return function(t){    d.endAngle = compute(t);    var data = d.endAngle / Math.PI / 2 * 100;    //设置数值    d3.select('text').text(data.toFixed(0) + '%');    //将新参数传入,生成新的圆弧构造器    return arcGenerator(d);   }  }) },2000)

登录后复制

最终效果如下:

D3.js 绘制动态进度条 

4.美化

1,2,3部分我们实现了最基本的进度条样式和功能,但样式看起来还是很单调的,我们接下来我们对进度条进行线性渐变处理。我们使用D3.js提供的线性插值API:

var colorLinear = d3.scaleLinear().domain([0,100]).range(["#EEE685","#EE3B3B"]);

登录后复制

colorLinear 同样是一个插值函数,我们输入[0,100]区间中的数值,就会返回对应[“#EEE685″,”#EE3B3B”]区间内的颜色值。比如当进度条显示进度为”80%”时:

var color = colorLinear(80);//color即为"80%"对应的色值

登录后复制

实现了颜色取值后,我们只需在进度条变化时,将原有颜色改变即可:

d3.interval(function(){  foreground.transition().duration(750).attrTween('d',function(d){   var compute = d3.interpolate(d.endAngle,Math.random() * Math.PI * 2);   return function(t){    d.endAngle = compute(t);    var data = d.endAngle / Math.PI / 2 * 100;    //设置数值    d3.select('text').text(data.toFixed(0) + '%');    //将新参数传入,生成新的圆弧构造器    return arcGenerator(d);   }  })  .styleTween('fill',function(d){   return function(t){    var data = d.endAngle / Math.PI / 2 * 100;    //返回数值对应的色值    return colorLinear(data);   }  }) },2000)

登录后复制

styleTween 与 attrTween 类似,是实现改变样式的插值函数。采用链式调用的形式同时对进度条数值和颜色的设置即可。最终实现的效果如下:

D3.js 绘制动态进度条 

综上我们实现了在不同数值下颜色变化的圆形进度条,可常用于告警,提醒等业务场景。

绘制矩形进度条

矩形进度条相比圆形进度条简单了很多,同样基于插值原理,平滑改变矩形的长度即可。直接上代码:

   #slider {   height: 20px;   width: 20px;   background: #2394F5;   margin: 15px;  }  

d3.interval(function(){ d3.select("#slider").transition() .duration(1000) .attrTween("width", function() { var i = d3.interpolate(20, 400); var ci = d3.interpolate('#2394F5', '#BDF436'); var that = this; return function(t) { that.style.width = i(t) + 'px'; that.style.background = ci(t); }; }); },1500)

登录后复制

实现的效果如下:

D3.js 绘制动态进度条 

总结

基于D3.js绘制进度条的关键点在于插值,从而正确地使图形平滑过渡。如果一定要使用svg或纯css实现矩形和圆形的进度条当然也是可行的,但对于路径和动画的处理,以及css的书写要求都复杂了不少。我们观察到使用D3.js绘制上述两种进度条的逻辑代码几乎完全使用js实现,同时代码量可以控制在20行左右并可封装复用,已经非常精炼了,在自定义图表开发上非常有优势。

对于进度条的衍生版仪表盘图表,相比基础进度条增加了刻度描述和指针计算,但万变不离其宗,只要掌握插值原理和使用,处理类似图表都将得心应手。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

bootstrap table怎样设置为高度百分比

在React组件中的this如何使用

以上就是D3.js 绘制动态进度条的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2781408.html

(0)
上一篇 2025年3月8日 16:16:22
下一篇 2025年3月8日 16:16:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JS中的Array filter() 方法如何使用

    这次给大家带来JS中的Array filter() 方法如何使用,使用JS中的Array filter()方法的注意事项有哪些,下面就是实战案例,一起来看一下。 什么是稀疏数组     数组元素的索引不一定要连续的,它们之间可以有空缺。每个…

    编程技术 2025年3月8日
    200
  • JS做出均匀的抛物线动画

    这次给大家带来JS做出均匀的抛物线动画,JS做出均匀的抛物线动画的注意事项有哪些,下面就是实战案例,一起来看一下。 在做无人便利小程序的项目中,某一天产品说要像某产商产品学习,给添加购物车增加抛物线小球动画。好吧,产品你最大,做! 先给大家…

    2025年3月8日
    200
  • 用JS做计算题

    这次给大家带来用JS做计算题,用JS做计算题的注意事项有哪些,下面就是实战案例,一起来看一下。 我们先来看下运行后的效果: 接下来我们分享给大家全部代码: document /*计算器的style*/ .jisuanqi { width: …

    2025年3月8日
    200
  • js动态创建标签以及设置属性的方法

    这次给大家带来js动态创建标签以及设置属性的方法,js动态创建标签以及设置属性的注意事项有哪些,下面就是实战案例,一起来看一下。 当我们在写jsp页面时,往往会遇到这种情况:从后台获取的数据个数不确定,此时在前端写jsp页面时也就不确定怎么…

    编程技术 2025年3月8日
    200
  • js随机产生6位随机数

    大家在制作网页或者小程序的时候经常用到随机数,作者整理了一个很简单的JS生成随机数的程序,一起学习下。 我们先来看下本次源码的效果图 大家可以灵活运用,我们把具体JS代码分享给大家: Document #count{ font-size: …

    2025年3月8日
    200
  • JS怎么改变当前页面的颜色

    这次给大家带来JS怎么改变当前页面的颜色,JS改变当前页面颜色的注意事项有哪些,下面就是实战案例,一起来看一下。 我们先来看下具体的演示效果图 以下就是完整的HTML页面代码,大家可以测试下。 Document .big_box{ widt…

    2025年3月8日
    200
  • JS常用的消息框有哪些

    这次给大家带来JS常用的消息框有哪些,JS常用消息框的注意事项有哪些,下面就是实战案例,一起来看一下。 首先来看下运行效果 加下来分享一下全部代码: Document function warn_info(){ alert(“提示消息框”)…

    2025年3月8日
    200
  • jS怎么添加Li元素

    这次给大家带来jS怎么添加Li元素,jS添加Li元素的注意事项有哪些,下面就是实战案例,一起来看一下。 html代码块 **javaScript动态添加Li元素** ul li{list-style:none;display:block;t…

    编程技术 2025年3月8日
    200
  • plotly.js 绘图库怎样使用

    这次给大家带来plotly.js 绘图库怎样使用,使用plotly.js 绘图库的注意事项有哪些,下面就是实战案例,一起来看一下。 本文介绍了plotly.js 绘图库入门使用教程,分享给大家,具体如下: Plotly 缘起 这两天想在前端…

    2025年3月8日
    200
  • JS仿经典传奇游戏

    这次给大家带来JS仿热血传奇游戏,JS仿热血传奇游戏的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 游戏的第一个版本开发于14年,浏览器端使用html+css+js,服务端使用asp+php,通讯采用ajax,数据存储使用acce…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论