svg画的圆形进度条

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

<style>

body {

background: #000;

text-align: center;

}

svg {

margin-top: 70px;

background: #fff;

}

path {

fill: none;

stroke: #ddd;

stroke-width: 6;

}

</style>

</head>

<body>

<svg xmlns='http://www.w3.org/2000/svg'

width='1000'

height='600'>

</svg>

<script>

var cx = 500,

cy = 300,

r = 150,

oSvg = document.querySelector('svg');

function d2r(deg) {

return deg * Math.PI / 180;

}

// inner ring  内环

ring(-150,150,'#ddd');

// outer ring  外环

var start = -150,

end = 150,

current = start,

step = 1,

timer = 0;

timer = setInterval(function() {

current += step;

if(current >= end) {

current = end;

clearInterval(timer);

}

ring(-150,current,'red');

},1000/20);

function ring(startAng,endAng,stroke) {

var x1 = cx + r * Math.sin(d2r(startAng));

var y1 = cy - r * Math.cos(d2r(startAng));

var x2 = cx + r * Math.sin(d2r(endAng));

var y2 = cy - r * Math.cos(d2r(endAng));

var oPath = document.createElementNS('http://www.w3.org/2000/svg','path');

oPath.setAttribute('d',`

M${x1},${y1}

A${r} ${r} 0 ${Math.abs(endAng - startAng) >= 180 ? 1 : 0} 1 ${x2} ${y2}

`);

oPath.style.stroke = stroke;

oSvg.appendChild(oPath);

}

console.log(ring );

</script>

</body>

</html>

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 作者: 阮一峰www.ruanyifeng.com/blog/2018/08/svg.html 一、概述 SVG ...
    grain先森阅读 2,887评论 0 12
  • <!DOCTYPE html> Document circle {-webkit-tr...
    talexie阅读 1,004评论 0 0
  • SVG API: SVG是一种可缩放矢量图形,一种二维图形表示语言 与canvas不同的是,在浏览器的开发工具中能...
    Iris_mao阅读 1,059评论 0 5
  • 最近遇到一个关于彩票中奖号码展示的项目,里面有很多技术难点,其中一个就是把各开奖号码之间用线段连接起来,这是一个典...
    codemarker阅读 737评论 0 4
  • 第一章 HTML5 (2014年10月29日发布)新特性: 10个 (1)新的语义标签 (2)增强型表单 (3)视...
    fastwe阅读 986评论 0 1