css - 使用纯 CSS 的简单倒计时圆形动画
问题描述
有很多 scss 示例,但只有少数几个带有 CSS。有人知道用纯 CSS 制作圆形倒计时动画的简单方法。
解决方案
这是一个简单而简短的纯 CSS 示例:
.timer {
background: -webkit-linear-gradient(left, skyBlue 50%, #eee 50%);
border-radius: 100%;
height: calc(var(--size) * 1px);
width: calc(var(--size) * 1px);
position: relative;
-webkit-animation: time calc(var(--duration) * 1s) steps(1000, start) infinite;
-webkit-mask: radial-gradient(transparent 50%,#000 50%);
mask: radial-gradient(transparent 50%,#000 50%);
}
.mask {
border-radius: 100% 0 0 100% / 50% 0 0 50%;
height: 100%;
left: 0;
position: absolute;
top: 0;
width: 50%;
-webkit-animation: mask calc(var(--duration) * 1s) steps(500, start) infinite;
-webkit-transform-origin: 100% 50%;
}
@-webkit-keyframes time {
100% {
-webkit-transform: rotate(360deg);
}
}
@-webkit-keyframes mask {
0% {
background: #eee;
-webkit-transform: rotate(0deg);
}
50% {
background: #eee;
-webkit-transform: rotate(-180deg);
}
50.01% {
background: skyBlue;
-webkit-transform: rotate(0deg);
}
100% {
background: skyBlue;
-webkit-transform: rotate(-180deg);
}
}
<div class="timer" style="--duration: 3;--size: 30;">
<div class="mask"></div>
</div>
<div class="timer" style="--duration: 10;--size: 100;">
<div class="mask"></div>
</div>
如上所示,您可以使用变量控制大小和持续时间。
推荐阅读
- iphone - 长时间连接 Wifi 到 ESP8266 到 iOS
- apache - 如何在 htaccess 中为文件夹禁用 gzip 压缩
- ionic-framework - 一代 Apk 离子
- python - 增加集合 pymongo 中所有对象的所有字段
- string - 将 VB.Net CSV 文件读入列表的问题,缺少一半的值
- angular - 在 Ag-Grid 中使用 col-id 删除默认类
- python - 将 JSON 键值导入 pandas 数据框错误
- typescript - 为什么返回类型中的泛型类型参数 T “未知”?如何键入此函数以便正确推断返回类型?
- numpy - 如何在 Python 中从特定轴中选择数组元素
- visual-studio - 可以使用 Visual Studio C++ 头文件/lib 文件在没有安装 Visual Studio 的机器上构建吗?