利用jQuery和CSS实现环形进度条

html代码


 1 <div class="circle" style="left:0">
2 <div class="pie_left"><div class="left"></div></div>
3 <div class="pie_right"><div class="right"></div></div>
4 <div class="mask"><span>0</span>%</div>
5 </div>
6 <div class="circle" style="left:220px">
7 <div class="pie_left"><div class="left"></div></div>
8 <div class="pie_right"><div class="right"></div></div>
9 <div class="mask"><span>15</span>%</div>
10 </div>
11 <div class="circle" style="left:440px">
12 <div class="pie_left"><div class="left"></div></div>
13 <div class="pie_right"><div class="right"></div></div>
14 <div class="mask"><span>30</span>%</div>
15 </div>
16 <div class="circle" style="left:660px">
17 <div class="pie_left"><div class="left"></div></div>
18 <div class="pie_right"><div class="right"></div></div>
19 <div class="mask"><span>60</span>%</div>
20 </div>
21 <div class="circle" style="left:880px">
22 <div class="pie_left"><div class="left"></div></div>
23 <div class="pie_right"><div class="right"></div></div>
24 <div class="mask"><span>90</span>%</div>
25 </div>

css 代码


 1  body {
2 font-family: "微软雅黑";
3 }
4 .circle {
5 width: 200px;
6 height: 200px;
7 position: absolute;
8 border-radius: 50%;
9 background: #0cc;
10 }
11 .pie_left, .pie_right {
12 width:200px;
13 height:200px;
14 position: absolute;
15 top: 0;left: 0;
16 }
17 .left, .right {
18 width:200px;
19 height:200px;
20 background:#00aacc;
21 border-radius: 50%;
22 position: absolute;
23 top: 0;
24 left: 0;
25 }
26 .pie_right, .right {
27 clip:rect(0,auto,auto,100px);
28 }
29 .pie_left, .left {
30 clip:rect(0,100px,auto,0);
31 }
32 .mask {
33 width: 150px;
34 height: 150px;
35 border-radius: 50%;
36 left: 25px;
37 top: 25px;
38 background: #FFF;
39 position: absolute;
40 text-align: center;
41 line-height: 150px;
42 font-size: 20px;
43 font-weight: bold;
44 color: #00aacc;
45 }

js代码


 1 $(function() {
2 $(‘.circle‘).each(function(index, el) {
3 var num = $(this).find(‘span‘).text() * 3.6;
4 if (num<=180) {
5 $(this).find(‘.right‘).css(‘transform‘, "rotate(" + num + "deg)");
6 } else {
7 $(this).find(‘.right‘).css(‘transform‘, "rotate(180deg)");
8 $(this).find(‘.left‘).css(‘transform‘, "rotate(" + (num - 180) + "deg)");
9 };
10 });
11
12 });

另外jquery的库推荐使用最新版本。

转载请注明:http://www.w3cplus.com/css3/create-radial-progress-bar-with-jQuery-and-css3.html

利用jQuery和CSS实现环形进度条,布布扣,bubuko.com

时间: 2024-10-20 17:03:36

利用jQuery和CSS实现环形进度条的相关文章

【CSS】环形进度条

效果图 原理剖析 1.先完成这样一个半圆(这个很简单吧) 2.overflow: hidden; 3.在中间定位一个白色的圆形做遮挡 4.完成另一半 5.使用animate配合时间完成衔接 源码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>环形进度条</title> <style> .wrapper { position: ab

页面效果:圆形进度条 环形进度条

环形进度条(1.5秒之内倒计时) 效果做的比较粗糙,就是css的 clip属性,先切右边一半,再切左边一半.根据三角函数计算y高度 http://www.w3school.com.cn/cssref/pr_pos_clip.asp css的clip属性 <script src="http://cdn.bootcss.com/jquery/1.12.1/jquery.min.js"></script> <script type="text/java

用初中数学知识撸一个canvas环形进度条

周末好,今天给大家带来一款接地气的环形进度条组件vue-awesome-progress.近日被设计小姐姐要求实现这么一个环形进度条效果,大体由四部分组成,分别是底色圆环,进度弧,环内文字,进度圆点.设计稿截图如下: 我的第一反应还是找现成的组件,市面上很多组件都实现了前3点,独独没找到能画进度圆点的组件,不然稍加定制也能复用.既然没有现成的组件,只有自己用vue + canvas撸一个了. 效果图 先放个效果图,然后再说下具体实现过程,各位看官且听我慢慢道来. 安装与使用 源码地址,欢迎sta

HTML5 Canvas绘制环形进度条

最近比较迷恋canvas,加之做了一个个人网站,有用到环形进度条,记录下来. canvas中没有直接绘制圆的方法,但有一个绘制弧线的context.arc方法, 下面讲下用该方法如何绘制出图片效果. arc()方法介绍 context.arc(x,y,r,sAngle,eAngle,counterclockwise); 参数说明: x: 圆的中心的 x 坐标 y: 圆的中心的 y 坐标 r: 圆的半径 sAngle: 起始角,以弧度计.(弧的圆形的三点钟位置是 0 度) eAngle: 结束角,

HTML5 canvas绘制倒计时+环形进度条

需求: 1.页面在进入时后台会提供一个固定时间和固定百分比,例如:18小时16分30秒,25%2.页面要求在进入时,有环形进度条从0推进到25%的效果,进度条旁的显示进度的黄色方块要始终保持跟随进度条最前方如图3.环形进度条中间计时器,要从获取到 具体时间后开始倒计时 设计图: JS代码如下: //补零function setDigit(num, n){ var str=''+num; if(str.length<n) { str='0'+str; } return str;}//设定时间fun

自定义环形进度条

自定义环形进度条 效果图: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 package com.qiao.circleprogress_forexample; import android.app.Activity; impo

图解CSS3制作圆环形进度条的实例教程

圆环形进度条制作的基本思想还是画出基本的弧线图形,然后CSS3中我们可以控制其旋转来串联基本图形,制造出部分消失的效果,下面就来带大家学习图解CSS3制作圆环形进度条的实例教程 首先,当有人说你能不能做一个圆形进度条效果出来时,如果是静态完整圆形进度条,那么就很简单了: .circleprogress{        width: 160px;        height: 160px;        border:20px solid red;        border-radius: 50

Swift - 环形进度条(UIActivityIndicatorView)的用法

Swift中,除了条形进度条外,还有环形进度条,效果图如下: 1,环形进度条的基本属性 (1)Style: Large White:比较大的白色环形进度条 White:白色环形进度条 Gray:灰色环形进度条 (2)Color: 设置环形进度条的颜色 (3)Behavior: Animating:勾选后环形进度条开始转动 Hides When Stopped:勾选后当环形进度条停止转动时自动隐藏 2,使用样例 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 1

仿MIUI音量变化环形进度条实现

Android中使用环形进度条的业务场景其实蛮多的,比如下载文件的时候使用环形进度条,会给用户眼前一亮的感觉:再比如我大爱的MIUI系统,它的音量进度条就是使用环形进度条,尽显小米"为发烧而生"的宗旨.今天就为大家揭开那些高大上设计背后的故事,让我们也来实现如此酷炫的效果. 其实环形进度条只是一个稍稍复杂点的自定义控件,看过前段时间<Android自定义控件>系列的同学,理解起来会更加容易.还没看过的同学,出门右转,查看历史消息,再回头看今天的内容,会更加容易上手. 一.定