只需纯 CSS 实现的简单圆形倒计时动画。

4

有许多scss样例,但是只有很少的CSS样例。有人知道用纯CSS制作圆形倒计时动画的简单方法。


是的,我认为有人知道......但这不是一个适合在SO上提问的问题。请阅读[ask]和[mcve]。 - Sfili_81
1个回答

16

这是一个简单而短小的纯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>

如上所示,您可以使用变量来控制大小和持续时间。

编辑:

回答@COil的评论,要求进行文本倒计时:多亏了这些问题的答案:https://dev59.com/Q1gQ5IYBdhLWcg3wym0Y#53602554https://dev59.com/EFkS5IYBdhLWcg3wQEYU#40179718,我能够拼凑出一个解决方案,但它非常静态,因为它需要最少X个动画步骤(X是持续时间的秒数)才能以1的步长显示数字:

.countdown:after {
    counter-reset: duration calc(var(--duration) * 1.0);
    content: counter(duration); 
    animation: spin calc(var(--duration) * 1s) infinite;
}

@keyframes spin {
    1% {
        counter-reset: duration calc(var(--duration) * 1.0);
        content: counter(duration); 
    }
    11% {
        counter-reset: duration calc(var(--duration) * 0.9);
        content: counter(duration); 
    }
    21% {
        counter-reset: duration calc(var(--duration) * 0.8);
        content: counter(duration); 
    }
    31% {
        counter-reset: duration calc(var(--duration) * 0.7);
        content: counter(duration); 
    }
    41% {
        counter-reset: duration calc(var(--duration) * 0.6);
        content: counter(duration); 
    }
    51% {
        counter-reset: duration calc(var(--duration) * 0.5);
        content: counter(duration); 
    }
    61% {
        counter-reset: duration calc(var(--duration) * 0.4);
        content: counter(duration); 
    }
    71% {
        counter-reset: duration calc(var(--duration) * 0.3);
        content: counter(duration); 
    }
    81% {
        counter-reset: duration calc(var(--duration) * 0.2);
        content: counter(duration); 
    }
    91% {
        counter-reset: duration calc(var(--duration) * 0.1);
        content: counter(duration); 
    }
    100% {
        counter-reset: duration calc(var(--duration) * 0);
        content: counter(duration); 
    }
}
<p class="countdown" style="--duration: 10;">
</p>


非常好,谢谢!最好的方法是在圆圈内显示剩余时间。没有JavaScript是否可能实现? - COil
干得好,@simon-tribus。 - Szilard Mihocsa
@COil 我不认为如此。如果你能够使用 duration 变量的值来设置容器的内容,那么可能可以,但我尝试过无法正常工作。 - Simon Tribus
1
@Coil 我找到了一个可能的解决方案,已经作为编辑添加了进去。 - Simon Tribus
太棒了!实至名归的赏金。 - COil

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接