SVG path绘制百分比圆弧,给力啊

简介: 版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/51500220 利用SVG的circle可以绘制百分比圆弧,但总觉得有点不够高端,相比起来,我更喜欢利用SVG的path来绘制百分比圆弧,因为其中会利用到绘制圆弧的基本数学知识(我已经把数学还给了老师,从网络上抓取别人的成果,进行了改造),这样就觉得很有装逼范。
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/51500220

利用SVG的circle可以绘制百分比圆弧,但总觉得有点不够高端,相比起来,我更喜欢利用SVG的path来绘制百分比圆弧,因为其中会利用到绘制圆弧的基本数学知识(我已经把数学还给了老师,从网络上抓取别人的成果,进行了改造),这样就觉得很有装逼范。

一、效果图

这里写图片描述

二、实现方法

页面元素构成

<svg height="108" version="1.1" width="108" xmlns="http://www.w3.org/2000/svg"
 style="overflow: hidden; position: relative; left: -0.5px;">
    <path class="ring" rate="${deal.attrs.rate}" fill="none" x="54" y="7" r="47" stroke="#fd30ae" d="M54,7A47,47,0,1,1,11,71" stroke-width="4" />
</svg>

是不是看的有点晕,如果你不熟悉SVG的话,先看svg中path标签的用法,对path的基本属性进行了解。

另外呢,我给path赋予了rate(百分比)、x(moveto的x坐标)、y(moveto的y坐标)、r(圆弧的半径)的属性。

赋值

// 圆弧
$("path.ring", $p).each(function() {
    var $this = $(this);

    YUNM.debug('path.ring' + $this.selector);

    var r = $this.attr("r");
    var x = $this.attr("x"), rate = $this.attr("rate");

    // 给path 设置属性
    if (rate < 100) {
        var progress = rate / 100;

        // 将path平移到我们需要的坐标位置
        $this.attr('transform', 'translate(' + x + ',' + x + ')');

        // 计算当前的进度对应的角度值
        var degrees = progress * 360;

        // 计算当前角度对应的弧度值
        var rad = degrees * (Math.PI / 180);

        // 极坐标转换成直角坐标
        var x = (Math.sin(rad) * r).toFixed(2);
        var y = -(Math.cos(rad) * r).toFixed(2);

        // 大于180度时候画大角度弧,小于180度的画小角度弧,(deg > 180) ? 1 : 0
        var lenghty = window.Number(degrees > 180);

        // path 属性
        var descriptions = [ 'M', 0, -r, 'A', r, r, 0, lenghty, 1, x, y ];

        $this.attr('d', descriptions.join(' '));
    }
});

这段代码就主要根据圆弧的起始点、半径、圆弧的进度来计算圆弧的终点。这段代码中用到的数学知识我肯定是不记得了,网络上其他程序员提供的demo。

三、简单改造后的源码,可直接运行

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>HTML5中的SVG属性实现圆形进度条效果</title>
</head>
<body>


    <svg width="500px" height="500px" version="1.1" xmlns="http://www.w3.org/2000/svg">   
    <path id="ring" fill="none" stroke="#fd30ae" />
    </svg>
    <script>



    var path = document.getElementById('ring');
    var r=100;

    var progress=0.6;

    //将path平移到我们需要的坐标位置
    ring.setAttribute('transform', 'translate('+r+','+r+')');

    // 计算当前的进度对应的角度值
    var degrees = progress * 360;  

    // 计算当前角度对应的弧度值
    var rad = degrees* (Math.PI / 180);

    //极坐标转换成直角坐标
    var x = (Math.sin(rad) * r).toFixed(2);
    var y = -(Math.cos(rad) * r).toFixed(2);

    //大于180度时候画大角度弧,小于180度的画小角度弧,(deg > 180) ? 1 : 0
    var lenghty = window.Number(degrees > 180);

    //path 属性
    var descriptions = ['M', 0, -r, 'A', r, r, 0, lenghty, 1, x, y];

    // 给path 设置属性
    path.setAttribute('d', descriptions.join(' '));
    </script>
</body>
</html>

这是网络上其他朋友提供的计算方法,我只做了简单的修改,插入到我的项目中。本篇主要用来推广SVG的path绘制百分比圆弧的方法,希望需要的人能够及早得到帮助,感谢!

相关文章
|
Java BI 图形学
java实现图片压缩功能
java实现图片压缩功能
1013 0
G2Plot Tooltip 自定义头部、尾部、辅助线
G2Plot Tooltip 自定义头部、尾部、辅助线
475 0
|
10月前
|
数据采集 存储 DataWorks
DataWorks Copilot:让你的数据质量覆盖率一键飞升!
在数据加工链路中,如何确保高质量的数据产出是一个一直需要重点解决的问题。阿里云DataWorks的数据质量规则模板可以帮助用户建设数据质量,在离线表上定义相关的规则。为优化手动配置规则的工作量,DataWorks的智能助手 DataWorks Copilot 推出了数据质量规则推荐功能,您可以使用这一功能,一键提升数据质量覆盖度。
811 20
DataWorks Copilot:让你的数据质量覆盖率一键飞升!
|
JavaScript
Vue项目中强制刷新页面的方法
Vue项目中强制刷新页面的方法
262 0
|
JavaScript 前端开发
将base64格式的图片画到canvas上(js和vue两种)
将base64格式的图片画到canvas上(js和vue两种)
1014 1
|
小程序
【干货】微信小程序如何设置背景图片
【干货】微信小程序如何设置背景图片
|
架构师 微服务
什么是软件架构?架构的本质是什么?
定义 ”架构是什么“ 是件非常困难的事情,不同的组织对于软件架构有不同的定义,每个人心中也有自身对于系统架构定义的认知。就好比我们无法百分之百表述模型而只能产出模型不同维度的视图,对架构进行完备的定义是不可能的。
332 4
|
JavaScript
vue点击瞄点平滑滚动 | 锚点随页面滚动高亮显示 | 点击平滑滚动到页面顶部
vue点击瞄点平滑滚动 | 锚点随页面滚动高亮显示 | 点击平滑滚动到页面顶部
442 1
|
Web App开发 前端开发 JavaScript
如何快速与呼叫中心系统CTI/API/SDK接口集成
由于呼叫中心系统涉及通信、CTI、终端设备、中继线路等技术与概念,从事信息管理系统、ERP、CRM、工单系统等的研发人员一般不是非常熟悉这部分技术,当需要提供具备呼叫中心能力的解决方案时,往往要用较多的时间来研究这些相对复杂的技术,对接过程比较长,开发调试有一定的阻力,基于此,我们提出一种更加简便高效的集成方法,可以零代码集成呼叫中心平台,实现项目快速上线。
如何快速与呼叫中心系统CTI/API/SDK接口集成