css3实现圆形进度条的方法

在开发微信小程序的时候,遇到圆形进度条的需求。本文主要介绍了使用 css3 实现圆形进度条的示例,这里整理了详细的代码,非常具有实用价值,需要的朋友可以参考下,希望能帮助到大家。

使用canvas绘图比较麻烦:

1、为了实现在不同屏幕上面的适配,必须动态的计算进度条的大小;

2、在小程序中,canvas的画布具有最高的层级,不易于扩展。

但使用css3和js实现进度条就很容易的避免了这方面的问题。

立即学习“前端免费学习笔记(深入)”;

注:这篇文章里面使用jquery实现,但原理是一样的,在小程序中只要定义并改变相应的变量就行了

一、进度条样式的样式

在平时的开发中,经常使用元素的border来显示圆形图案,在使用css3实现圆形进度条时,同样也是使用这个技巧。为了实现上面的圆形边框,动态的覆盖下面圆形边框,总共需要一个圆形,2个长方形和2个半圆形:一个圆形用来显示底层背景,两个半圆形用来覆盖底层背景显示进度,另外两个长方形用来覆盖不需要显示的进度。如下图:

css3实现圆形进度条的方法

最下面的bottom圆形是进度条的背景,在bottom上面有left和right两个长方形,用来覆盖不要显示的进度条。在两个长方形的里面分别有一个半圆形用来显示进度。正常情况下,使用正方形绘制出来的半圆,直径和水平下都是有45度夹角的。为了能使两个半圆刚好可以覆盖整个圆形,就需要使用css3中的rotate使原有正方形旋转,达到覆盖整个背景的效果。如下图(为了显示清楚,这里用正方形表示):

css3实现圆形进度条的方法

如图,将长方形内部的半圆向右(顺时针)旋转45度,就可以得到进度覆盖整个背景的图像。将半圆向左(逆时针)旋转135度就能得到只有进度条背景的图像。为什么又要向左旋转,而不是一直向右旋转,当然是因为要实现的效果是:进度是从顶部开始,顺时走完的。到这里,思路就很清晰了,只需要再按百分比的多少来控制左边和右边进度的显示就可以了。

实现这部分的html和css代码如下:

html代码

登录后复制

css代码:

.progressbar{    position: relative;    margin: 100px auto;    width: 100px;    height: 100px;    border: 20px solid #ccc;    border-radius: 50%;}.left-container,.right-container{    position: absolute;    width: 70px;    height: 140px;    top:-20px;    overflow: hidden;    z-index: 1;}.left-container{    left: -20px;}.right-container{    right: -20px;}.left-circle,.right-circle{    position: absolute;    top:0;    width: 100px;    height: 100px;    border:20px solid transparent;       border-radius: 50%;    transform: rotate(-135deg);    transition: all .5s linear;    z-index: 2;}.left-circle{    left: 0;    border-top-color: 20px solid blue;    border-left-color: 20px solid blue;}.right-circle{    border-right-color: 20px solid blue;    border-bottom-color: 20px solid blue;    right: 0;}

登录后复制

二:控制进度条的js

为了使进度条的逻辑更健壮,js部分的实现需要考虑四中情况:

1、基础值个更改后的值在同在右边进度,

2、基础值在右边,更改后的值在左边,

3、基础值更改后的值同在左边,

4、基础值在左边,更改后的值在右边。

不管在那种情况下,核心需要考虑只有两点:角度的变化和使用时间的多少。

第一种情况下,比较简单,可以很简单计算出角度的变化和使用时间的多少。首先,需要设定改变整个半圆的所需的时间值。设定之后,只要根据比例计算出改变的角度所需要的时间值即刻。代码如下:

time = (curPercent - oldPercent)/50 * baseTime;     //确定时间值为正     curPercent - oldPercent > 0 ? '' : time = - time;     deg = curPercent/50*180-135;

登录后复制

第二种情况,稍微麻烦一点。因为中间有一个从右边进度,到左边进度的过渡。为了让进度顺畅的改变,这里我们需要使用定时器,在改变完右边的部分之后,再修改左边的部分。代码如下:

//设置右边的进度  time = (50 - oldPercent)/50 * baseTime;deg = (50 - oldPercent)/50*180-135;$rightBar .css({    transform: 'rotate('+ deg+ 'deg)',    transition : 'all '+ time + 's linear'})//延时设置左边进度条的改变setTimeout(function(){    time = (curPercent - 50)/50;    deg = (curPercent - 50)/50*180 -135;    $leftBar.css({        transform: 'rotate('+ deg+ 'deg)',        transition : 'all '+ time + 's linear'    })}, Math.floor(time*1000));000));

登录后复制

第三种情况和第四种情况同前面情况类似,这里不再讨论。

完整的控制进度条的函数的代码如下(使用jQuery实现):

/**    *设置进度条的变化    *@param {number} oldPercent    进度条改变之前的半分比    *@param {number} curPercent    进度条当前要设置的值     *@return {boolean} 设置成功返回 true,否则,返回fasle    */    function setProgessbar(oldPercent, curPercent){        var $leftBar = $('#left-bar');        var $rightBar = $('#right-bar');        //将传入的参数转换,允许字符串表示的数字        oldPercent =  + oldPercent;        curPercent =  + curPercent;        //检测参数,如果不是number类型或不在0-100,则不执行        if(typeof oldPercent ==='number' && typeof curPercent ==='number'            && oldPercent >= 0 && oldPercent <= 100 && curPercent = 0){                var baseTime = 1;    //默认改变半圆进度的时间,单位秒               var time = 0;    //进度条改变的时间            var deg = 0;     //进度条改变的角度            if(oldPercent > 50){//原来进度大于50                if(curPercent>50){                    //设置左边的进度                    time = (curPercent - oldPercent)/50 * baseTime;                    //确定时间值为正                    curPercent - oldPercent > 0 ? '' : time = - time;                    deg = curPercent/50*180-135;                    $leftBar .css({                        transform: 'rotate('+ deg+ 'deg)',                        transition : 'all '+ time + 's linear'                    })                    }else{                    //设置左边的进度                    time = (oldPercent - 50)/50 * baseTime;                    deg = (oldPercent - 50)/50*180-135;                    $leftBar .css({                        transform: 'rotate('+ deg+ 'deg)',                        transition : 'all '+ time + 's linear'                    })                    //延时设置右边进度条的改变                    setTimeout(function(){                        time = (50 - curPercent)/50;                        deg = (50 - curPercent)/50*180 -135;                        $rightBar.css({                            transform: 'rotate('+ deg+ 'deg)',                            transition : 'all '+ time + 's linear'                        })                    }, Math.floor(time*1000));                }            }else{//原来进度小于50时                    if(curPercent>50){                    //设置右边的进度                    time = (50 - oldPercent)/50 * baseTime;                    deg = (50 - oldPercent)/50*180-135;                    $rightBar .css({                        transform: 'rotate('+ deg+ 'deg)',                        transition : 'all '+ time + 's linear'                    })                    //延时设置左边进度条的改变                    setTimeout(function(){                        time = (curPercent - 50)/50;                        deg = (curPercent - 50)/50*180 -135;                            $leftBar.css({                            transform: 'rotate('+ deg+ 'deg)',                            transition : 'all '+ time + 's linear'                        })                    }, Math.floor(time*1000));                }else{                    //设置右边的进度                    time = (curPercent - oldPercent)/50 * baseTime;                    //确定时间值为正                    curPercent - oldPercent > 0 ? '' : time = - time;                    deg = curPercent/50*180-135;                    $rightBar .css({                        transform: 'rotate('+ deg+ 'deg)',                        transition : 'all '+ time + 's linear'                    })                    }                return true;            }        }else{            return false;        }    }

登录后复制

大家学会了吗?赶紧动手尝试一下吧。

相关推荐:

微信小程序实现下载进度条的方法

微信小程序实现下载进度条的方法

微信小程序实现下载进度条的方法

以上就是css3实现圆形进度条的方法的详细内容,更多请关注【创想鸟】其它相关文章!

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

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

(0)
上一篇 2025年3月11日 00:07:53
下一篇 2025年3月11日 00:08:14

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

相关推荐

  • 详解CSS3实现无限循环的无缝滚动

    有时候在页面的某个模块中,需要无限循环的滚动一些消息。那么如果我们用js实现无缝衔接滚动的思路是什么呢(比如我们这个模块是向上滚动的)?本文主要介绍了用css3实现无限循环的无缝滚动的实例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一…

    2025年3月11日
    200
  • CSS如何将网站网页变灰色

    本文主要给大家介绍了关于利用CSS将网站网页变灰色的相关资料,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧,希望能帮助到大家。 想要实现上图灰色效果,方法如下: 这段CSS代码可以变网页…

    2025年3月11日
    200
  • css3设置没有上下边的列表间隔线方法实例

    本文主要给大家介绍了利用css3如何设置没有上下边的列表间隔线,文中分享了两种解决方法,分别是利用通用兄弟选择器( ~ )和伪类选择器( :first-of-type / :last-of-type )来实现的,给出了详细的示例代码供大家参…

    2025年3月11日
    200
  • css3画同心圆示例代码

    本文主要给大家介绍了利用css3如何画个同心圆的相关资料,文中给出了详细的css3示例代码,并对代码进行了详细的解析方法大家理解和学习css3画同心圆,对大家具有一定的参考学习价值,希望能帮助到大家。 基本思路 首先你得画三个圆吧,那三个圆…

    2025年3月11日
    200
  • 详解CSS和HTML自定义checkbox效果

    checkbox应该是一个比较常用的html功能了,不过浏览器自带的checkbox往往样式不怎么好看,而且不同浏览器效果也不一样。出于美化和统一视觉效果的需求,checkbox的自定义就被提出来了。本文主要给大家分享css+html自定义…

    编程技术 2025年3月11日
    200
  • 详解CSS3的filter滤镜属性

    最近发现了一个非常强大的css3属性,就是filter(滤镜)属性,喜欢p图的朋友看名字都应该知道这是什么神器了吧。当然,这个属性的效果肯定不能跟ps相比,但是利用的好的话可以在节约很多空间下,把一张图做成两张图的效果。本文主要介绍了详解c…

    2025年3月11日 编程技术
    200
  • CSS中margin的用法和常见问题的分析

    关于margin我们是在熟悉不过的了,本文主要给大家介绍了css中margin的用法和常见问题的分析,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 一、简介 margin我们一般习惯的叫它外边距,分别可以…

    2025年3月11日
    200
  • 详解CSS3中linear-gradient和radial-gradient

    本文主要介绍了关于css中渐变的相关资料,主要分享css3中linear-gradient和radial-gradient的知识,带给大家使用渐变的另一个角度,文中通过示例代码介绍的非常详细,需要的朋友可以参考下,希望能帮助到大家。 一、线…

    2025年3月11日 编程技术
    200
  • HTML+CSS实现美观样式的单选框、复选框

    单选框、复选框都是前端需要的功能,本文主要介绍了html+css实现单选框、复选框美观的样式,需要的朋友可以参考下,希望能帮助大家完成更美观样式的单选框、复选框。 1.背景图 html                      登录后复制 …

    2025年3月11日
    200
  • 详解CSS中margin和padding的区别

    本文给大家分享css中很基础的知识,我们知道css中margin和padding是有区别的,在css中margin是指从自身边框到另一个容器边框之间的距离,就是容器外距离。在css中padding是指自身边框到自身内部另一个容器边框之间的距…

    2025年3月11日
    200

发表回复

登录后才能评论