简单的倒计时圆圈动画与纯CSS

643ylb08  于 2023-02-01  发布在  其他
关注(0)|答案(1)|浏览(110)

bounty将在4天后过期。此问题的答案可获得+100声望奖励。COil希望奖励现有答案:您好,我添加了一条评论,请随时完成您的回答(如果可能的话)。

有很多scss的例子,但只有少数与CSS。有人知道一个简单的方法来动画一个圆圈倒计时与纯CSS。

olhwl3o2

olhwl3o21#

下面是一个简短的仅使用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>

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

相关问题