1、css代码

此处在制作进度条时,是旋转进度条的半圆(红色),背景使用灰白(如果使用红色作为背景,旋转灰白遮罩,在浏览器中可能会有渲染bug)

 .wrapper{ display:block;position:relative;width:100px;height:100px;border-radius:50px;overflow:hidden; }
.pie { position:absolute;background-color:#e74c3c;width:100px;height:100px; }
.pie1 { clip:rect(0px,50px,100px,0px); }
.pie2 { clip:rect(0px,100px,100px,50px); }
.hold { width:100px;height:100px;position:absolute;z-index:; }
.hold1 { clip:rect(0px,100px,100px,50px); }
.hold2 { clip:rect(0px,50px,100px,0px); }
.bg { width:100px;height:100px;background-color:#f4f6f6;position:absolute; }
.circle{position:absolute;background-color:#FFF;width:90px;height:90px;border-radius:45px;left:5px;top:5px;z-index:;}

以下的css的代码会产生渲染bug(导致灰白外侧有红色细线)

 .wrapper{ display:block;position:relative;width:100px;height:100px;border-radius:50px;overflow:hidden; }
.pie { position:absolute;background-color:#f4f6f6;width:100px;height:100px; }
.pie1 { clip:rect(0px,100px,100px,50px); }
.pie2 { clip:rect(0px,50px,100px,0px); }
.hold { width:100px;height:100px;position:absolute;z-index:; }
.hold1 { clip:rect(0px,100px,100px,50px); }
.hold2 { clip:rect(0px,50px,100px,0px); }
.bg { width:100px;height:100px;background-color:#e74c3c;position:absolute; }
.circle{position:absolute;background-color:#FFF;width:90px;height:90px;border-radius:45px;left:5px;top:5px;z-index:;}

2、html代码

 <div class="wrapper">
<div class="hold hold1">
<div class="pie pie1"></div>
</div>
<div class="hold hold2">
<div class="pie pie2"></div>
</div>
<div class="bg"></div>
<div class="circle"></div>
</div>
<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>

3、js代码

 var pie = {
run:function(opts){
if(!opts.pie1 || !opts.pie2) throw new Error('must be element pie1 and pie2.');
var pie1 = $(opts.pie1), pie2 = $(opts.pie2);
var percent = opts.percent || 0;
var step = opts.step || 3;
var delay = opts.delay || 50;
var callback = opts.callback || $.noop;
var i = 0, rage = 360 * percent;
var djs = function(){
i = i + step;
if(i <= rage){
if(i <= 180){
if((180 - i) < step){ i = 180; }
pie1.css("-webkit-transform","rotate(" + i + "deg)");
} else {
if((rage - i) < step){ i = rage; }
pie2.css("-webkit-transform","rotate(" + (i-180) + "deg)");
}
callback(i, rage);
setTimeout(djs, delay);
}
};
djs();
}
};
pie.run({
pie1:".pie1",
pie2:".pie2",
percent:0.75
});

参考demo:http://liumiao.me/demo/count/

最新Canvas版

.jqm-round-wrap{
display:block;position:relative;width:130px;height:130px;overflow:hidden;
border-radius:65px;
-webkit-border-radius:65px;
}
#jqm-round-sector{
position:absolute;width:130px;height:130px;
}
.jqm-round-bg {
position:absolute;width:130px;height:130px;background-color:#f4f6f6;
border-radius:65px;
-webkit-border-radius:65px;
}
.jqm-round-circle{
position:absolute;background-color:#FFF;width:120px;height:120px;left:5px;top:5px;z-index:;
border-radius:60px;
-webkit-border-radius:60px;
}
<div class="jqm-round-wrap">
<div class="jqm-round-bg"></div>
<canvas id="jqm-round-sector"></canvas>
<div class="jqm-round-circle">15<samp>%</samp></div>
</div>
var pie = {
run:function(opts){
if(!opts.id) throw new Error("must be canvas id.");
var canvas = document.getElementById(opts.id), ctx;
if(canvas && (ctx = canvas.getContext("2d"))){
canvas.width = canvas.height = "200";
var noop = function(){};
var before = opts.onBefore || noop;
var after = opts.onAfter || noop;
before(ctx);
ctx.fillStyle = opts.color || '#f4f6f6';
var step = opts.step || 1;
var delay = opts.delay || 10;
var i = 0, rage = 360 * (opts.percent || 0);
var sRage = -Math.PI * 0.5;
var djs = function(){
i = i + step;
if(i <= rage){
ctx.beginPath();
ctx.moveTo(100, 100);
ctx.arc(100, 100, 100, sRage, Math.PI * 2 * (i/360)+sRage);
ctx.fill();
setTimeout(djs, delay);
} else {
after(ctx);
}
};
djs();
}
}
};
pie.run({
id:"jqm-round-sector",
percent:0.75,
onBefore:function(ctx){
ctx.fillStyle = '#47b28b';
ctx.beginPath();
ctx.moveTo(100, 100);
ctx.arc(100, 100, 100, 0, Math.PI * 2);
ctx.fill();
}
});

CSS3制作同心圆进度条的更多相关文章

  1. 移动端纯CSS3制作圆形进度条所遇到的问题

    近日在开发的页面中,需要制作一个动态的圆形进度条,首先想到的是利用两个矩形,宽等于直径的一半,高等于直径,两个矩形利用浮动贴在一起,设置overflow:hidden属性,作为盒子,内部有一个与其宽高 ...

  2. css3 制作圆环进度条

    引子 移动端做一个 loadiing 加载的图标,跟以往沿用的都不太一样,是一个圆环进度条,圆环进度条也就罢了,还得能用百分比控制. CSS3 实现圆环 demo 刚开始写这个圆环的时候是参照帖子上给 ...

  3. css3圆形百分比进度条的实现原理

    原文地址:css3圆形百分比进度条的实现原理 今天早上起来在查看jquery插件机制的时候,一不小心点进了css3圆形百分比进度条的相关文章,于是一发不可收拾,开始折腾了... 关于圆形圈的实现,想必 ...

  4. CSS3时钟式进度条

    CSS3时钟式进度条,加载完成时生成一个圆,数字慢慢变成100,适时的显示加载进度.友情提醒,如果预览时网页左下角提示错误,刷新一下就可以看到效果了:实际使用中不会出现这样的问题. <!DOCT ...

  5. CSS3实现圆环进度条

    摘要:圆环进度条被应用于各个场景,比如我们可以用来表示加载进度等.通常我们可以用 css3 的动画去实现. 详解 css3 实现圆环进度条 简单的画一个圆环,我们都知道如何使用 css 画一个圆环.( ...

  6. 浅谈一下关于使用css3来制作圆环进度条

    最近PC端项目要做一个这样的页面出来,其他的都很简单,关键在于百分比的圆环效果.我最初打算是直接使用canvas来实现的,因为canvas实现一个圆是很简便的. 下面贴出canvas实现圆环的代码,有 ...

  7. CSS制作环形进度条

    参考来源 <Radial progress indicator using CSS>,该文核心是用纯CSS来做一个环形的进度条.纯css的意思就是连百分比这种数字,都是css生成的.文章作 ...

  8. CSS3实现圆形进度条

    介绍 闲来无事,去了CSS3Plus网站逛了逛,发现了一个很有意思的实现--css3实现进度条.粗略看了下代码,发现原理其实很简单,不难理解. 现在在此讲述下原理并实现一个1s更新的进度条. 技术细节 ...

  9. css3飞机起飞进度条

    效果:http://hovertree.com/texiao/css3/27/ 源码下载:http://hovertree.com/h/bjaf/pgwql1x2.htm 本效果使用Font Awes ...

随机推荐

  1. Gemfile分平台加载gem

    Gemfile分平台加载gem 区分平台以便加载不同的web server,象tzinfo-data只适用于windows # Windows does not include zoneinfo fi ...

  2. HTML DOM元素的Dragdrop

    在前端web页面中,为了提高用户体验,通常会希望将页面中的元素设计成可dragdop的,简化用户操作.这一设计特性在缺少鼠标的触摸屏设备上,显得更为重要. 在早期的应用中,我们通常需要借助第三方的ja ...

  3. js api 实现钉钉免登

    js api 实现钉钉免登,用于从钉钉微应用跳转到企业内部的oa,erp等,我刚刚实施完了我公司的这个功能,钉钉用起来还不错. 1 js api 实现钉钉免登,页面配置. <title>利 ...

  4. 集合Collection

    /* * 集合的由来: * 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储. * 而要想存储多个对象,就不能是一个基本 ...

  5. SQL语句之备份表

    SELECT INTO 语句:表示从一个表中选取数据,然后把数据插入另一个表中,常用来备份一张表 1.全表结构备份: SELECT * INTO new_table_name FROM old_tab ...

  6. ajax批删

  7. udacity google deep learning 学习笔记

    1.为什么要在卷积网络中加入pooling(池化) 如果只利用卷积操作来减少feature map的大小,会失去很多信息.所以想到一种方法,减小卷积时的stride,留下大部分信息,通过池化来减小fe ...

  8. 在亚马逊amazon的AWS上安装Node和MongoDB服务器

    在亚马逊amazon的AWS上安装Node和MongoDB服务器 在建立AWS上账号.创建EC2 ,用putty链接上之后,就可以用下面的方法开始安装. !!! 如果不是是自己建立的EC2, 而是由B ...

  9. jquery文件上传控件 Uploadify

    (转自 http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html) 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...

  10. form中的GET与POST

     form标签是强大的:如果没有form标签,Internet将变成一个枯燥文档的只读存储库.Web Forms没有完全利用form标签的强大功能(也可以说是Web Forms为实现自己的目标才管理和 ...