【CSS】环形进度条

本文详细介绍了一种使用HTML和CSS实现环形进度条的方法,包括创建半圆、使用白色圆形进行遮挡、动画衔接等步骤,并提供了完整的代码示例。

效果图

 

原理剖析

1.先完成这样一个半圆(这个很简单吧)

 

2.overflow: hidden;

 

3.在中间定位一个白色的圆形做遮挡

 

4.完成另一半

 

5.使用animate配合时间完成衔接

 

源码

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>环形进度条</title>
    <style>
        .wrapper {
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            width: 4em;
            height: 4em;
            margin: auto;
        }
        .container {
            position: absolute;
            top: 0;
            bottom: 0;
            width: 2em;
            overflow: hidden;
        }
        .halfCir {
            width: 2em;
            height: 4em;
            background: red;
        }
        .container1 {
            left: 2em;
        }
        .container1 .halfCir {
            left: 0;
            border-radius: 0 4em 4em 0;
            transform-origin: 0 50%;
            animation: halfCir1 4s infinite linear;            
        }
        .container2 {
            left: 0;
        }
        .container2 .halfCir {
            border-radius: 4em 0 0 4em;
            transform-origin: 2em 2em;
            animation: halfCir2 4s infinite linear;
        }
        @keyframes halfCir1 {
            50%, 100% {
                transform: rotateZ(180deg);
            }
        }
        @keyframes halfCir2 {
            0%, 50% {
                transform: rotateZ(0);
            }
            100% {
                transform: rotateZ(180deg);
            }
        }
        .wrapper::after {
            position: absolute;
            top: 0.5em;
            left: 0.5em;
            width: 3em;
            height: 3em;
            background: #fff;
            border-radius: 50%;
            content: "";    
        }
        .cir {
            position: absolute;
            top: 0;
            right: 0;
            left: 0;
            width: 0.5em;
            height: 0.5em;
            margin: auto;
            background: red;
            border-radius: 50%;
        }
        .cir2 {
            transform-origin: 50% 2em;
            animation: cir2 4s infinite linear;
        }
        @keyframes cir2 {
            100% {
                transform: rotateZ(360deg);
            }
        }
    </style>
</head>
<body>
    <div class="wrapper"> 
        <div class="container container1"> 
            <div class="halfCir"></div> 
        </div> 
        <div class="container container2"> 
            <div class="halfCir"></div> 
        </div>
        <div class="cir cir1"></div> 
        <div class="cir cir2"></div>
    </div>
</body>
</html>

转载于:https://www.cnblogs.com/linxian95/p/10141653.html

在微信小程序中实现环形进度条CSS 样式,可以通过组合使用 HTML 结构和 CSS 动画来完成。以下是一种基于 CSS 的实现方式,它利用了伪元素和旋转动画来模拟进度效果。 ### 环形进度条的结构与样式 1. **HTML 结构**:创建一个容器用于包裹整个环形进度条,并通过两个子元素分别表示背景圆环和前景进度部分。 2. **CSS 样式**:使用 `border-radius` 和 `border` 属性绘制圆形,通过伪元素 `::before` 或 `::after` 来控制进度的显示,并结合 `transform` 实现旋转动画。 #### 示例代码 ##### WXML ```xml <view class="progress-ring"> <view class="progress-ring__circle"> <view class="progress-ring__fill"></view> </view> <text class="progress-ring__label">{{progress}}%</text> </view> ``` ##### WXSS ```css .progress-ring { position: relative; width: 100px; height: 100px; display: flex; align-items: center; justify-content: center; } .progress-ring__circle { position: absolute; width: 100%; height: 100%; border-radius: 50%; border: 4px solid #e6e6e6; /* 背景颜色 */ } .progress-ring__fill { position: absolute; width: 100%; height: 100%; border-radius: 50%; border: 4px solid transparent; /* 进度条颜色 */ border-top-color: #3498db; transform: rotate(0deg); animation: spin 2s linear forwards; } @keyframes spin { to { transform: rotate(360deg); } } .progress-ring__label { font-size: 16px; color: #333; } ``` ##### JS 控制进度 在 `index.js` 中可以动态更新进度值并触发视图刷新: ```javascript Page({ data: { progress: 0 }, onLoad() { let currentProgress = 0; const interval = setInterval(() => { if (currentProgress >= 100) { clearInterval(interval); } else { currentProgress += 10; this.setData({ progress: currentProgress }); } }, 500); } }); ``` ### 关键点说明 - **圆形绘制**:通过设置 `border-radius: 50%` 将矩形变为圆形。 - **进度填充**:使用 `border` 属性为 `.progress-ring__fill` 设置边框,并仅保留顶部边框以形成扇形区域。 - **动画效果**:利用 `@keyframes spin` 定义旋转动画,并将其应用到 `.progress-ring__fill` 上,使其从 0° 旋转到 360°,从而显示出进度增加的效果[^2]。 这种方法不依赖于 Canvas,而是完全依靠 CSS 和 HTML 构建,适用于需要轻量级解决方案或希望保持 UI 组件一致性的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值