我试图创建一个无限动画,其中围绕圆圈的新笔划围绕圆周运行。最初笔划是蓝色,然后当它达到360度时,它似乎在同一方向上消失。但实质上,类似的动画正在另一组元素中运行,其中颜色反转。
我希望将此循环无限地作为加载状态。现在我可以让所描述的行为运行一次。我坚持让它循环,这意味着蓝色边框在消失后再次返回,依此类推。小片包含在演示中 -
body {
padding: 0;
margin: 0;
}
.outer, .inner, .cover {
border-radius: 50%;
height: 200px;
width: 200px;
box-sizing: border-box;
}
.outer {
background: linear-gradient(to right, transparent 0%, transparent 50%, #7db9e8 50%, #7db9e8 100%);
position: absolute;
top: 0;
}
.outer.opp {
background: linear-gradient(to right, #7db9e8 0%, #7db9e8 50%, transparent 50%, transparent 100%);
}
.inner {
background: linear-gradient(to right, transparent 0%, transparent 50%, #ccc 50%, #ccc 100%);
padding: 5px;
-webkit-animation: spin 5s 2s linear forwards;
}
.inner.opp {
background: linear-gradient(to right, #ccc 0%, #ccc 50%, transparent 50%, transparent 100%);
-webkit-animation: spin2 5s 7s linear forwards;
}
.cover {
background: #ccc;
height: 190px;
width: 190px;
position: absolute;
top: 5px;
left: 5px;
z-index: 5;
}
img {
margin-left: 35px;
margin-top: 45px;
}
@-webkit-keyframes spin {
0% {
-webkit-transform: rotate(0);
}
99.99% {
background: linear-gradient(to right, transparent 0%, transparent 50%, #ccc 50%, #ccc 100%);
}
100% {
-webkit-transform: rotate(-180deg);
background: linear-gradient(to right, transparent 0%, transparent 50%, transparent 50%, transparent 100%);
}
}
@-webkit-keyframes spin2 {
0% {
-webkit-transform: rotate(0);
}
99.99% {
background: linear-gradient(to right, #ccc 0%, #ccc 50%, transparent 50%, transparent 100%);
}
100% {
background: linear-gradient(to right, transparent 0%, transparent 50%, transparent 50%, transparent 100%);
-webkit-transform: rotate(-180deg);
}
}
/****** Start css for gray border animation *******/
.gray {
opacity: 0;
-webkit-animation: appear 0s 12s forwards;
position: absolute;
top: 0px;
}
.gray .outer {
background: linear-gradient(to right, transparent 0%, transparent 50%, #ccc 50%, #ccc 100%);
}
.gray .outer.opp {
background: linear-gradient(to right, #ccc 0%, #ccc 50%, transparent 50, transparent 100%);
}
.gray .inner {
background: linear-gradient(to right, transparent 0%, transparent 50%, #7db9e8 50%, #7db9e8 100%);
-webkit-animation: spin-gray 5s 12s linear forwards;
}
.gray .inner.opp {
background: linear-gradient(to right, #7db9e8 0%, #7db9e8 50%, #ccc 50%, #ccc 100%);
-webkit-animation: spin-gray2 5s 17s linear forwards;
}
@-webkit-keyframes appear {
0% {
opacity: 0;
}
100% {
opacity: 1;
}
}
@-webkit-keyframes spin-gray {
0% {
-webkit-transform: rotate(0);
}
99.99% {
background: linear-gradient(to right, transparent 0%, transparent 50%, #7db9e8 50%, #7db9e8 100%);
}
100% {
-webkit-transform: rotate(-180deg);
background: linear-gradient(to right, transparent 0%, transparent 50%, transparent 50%, transparent 100%);
}
}
@-webkit-keyframes spin-gray2 {
0% {
-webkit-transform: rotate(0);
}
100% {
-webkit-transform: rotate(-180deg);
}
}

<div class="opp outer">
<div class="opp inner">
</div>
</div>
<div class="outer">
<div class="inner">
</div>
</div>
<div class="gray">
<div class="opp outer">
<div class="opp inner">
</div>
</div>
<div class="outer">
<div class="inner">
</div>
</div>
</div>
<div class="cover">
<img src="http://media.giphy.com/media/aHKpXstxvNf56/giphy.gif" height="90"></div>
&#13;
答案 0 :(得分:1)
想出来。使用两个裁剪的div覆盖div显示。在剪切的div中是一个带圆角的div。每个都与循环动画相关联。一个被推迟以模拟单个无缝效果。不是一个完美的解决方案,因为蓝色在灰色圆圈之外有点偷看,但并不坏。
但是,IE,FF和某些版本的Android 4不支持此剪辑属性。叹息
.blue-circle {
background: blue;
border-radius: 50%;
height: 150px;
position: relative;
width: 150px;
}
.cover {
background: lightgray;
border-radius: 50%;
height: 130px;
left: 0;
margin: auto;
position: absolute;
right: 0;
top: 10px;
width: 130px;
}
.left-half, .right-half {
height: 100%;
display: inline-block;
overflow: hidden;
width: 50%;
}
.left-half {
left: 0;
}
.left-half-circle {
background: lightgray;
border-radius: 50%;
height: 100%;
width: 200%;
-webkit-clip-path: polygon(50% 0, 0 0, 0 100%, 50% 100%);
clip-path: polygon(50% 0, 0 0, 0 100%, 50% 100%);
-webkit-animation: rotate-half-circle 16s 4s linear infinite;
-webkit-transform: translatez(0);
}
.right-half {
position: relative;
}
.right-half-circle {
background: lightgray;
border-radius: 50%;
height: 100%;
position: absolute;
right: 0;
width: 200%;
-webkit-clip-path: polygon(100% 0, 50% 0, 50% 100%, 100% 100%);
clip-path: polygon(100% 0, 50% 0, 50% 100%, 100% 100%);
-webkit-animation: rotate-half-circle 16s 0s linear infinite forwards;
-webkit-transform: translatez(0);
}
@-webkit-keyframes rotate-half-circle {
0% {
-webkit-transform: rotate(0deg);
}
25% {
-webkit-transform: rotate(180deg);
}
50% {
-webkit-transform: rotate(180deg);
}
75% {
-webkit-transform: rotate(360deg);
}
100% {
-webkit-transform: rotate(360deg);
}
}
&#13;
<div class="blue-circle">
<div class="left-half">
<div class="left-half-circle">
</div>
</div><!--
--><div class="right-half">
<div class="right-half-circle">
</div>
</div>
<div class="cover-wrapper">
<div class="cover">
<img src="http://media.giphy.com/media/aHKpXstxvNf56/giphy.gif" height="90" style="margin-top:15px;">
</div>
</div>
</div>
&#13;