这是我想用CSS制作的动画. 这是一个动画PNG. Firefox是我所知道的唯一可以显示动画的浏览器.请在FireFox中查看此内容,以便您可以看到动画.我想尝试在CSS中使用它,这样我就可以在更多的浏
这是一个动画PNG. Firefox是我所知道的唯一可以显示动画的浏览器.请在FireFox中查看此内容,以便您可以看到动画.我想尝试在CSS中使用它,这样我就可以在更多的浏览器中使用它并仍然获得真正的透明度(GIF动画无法提供)
< - 这是一个点,可以用来制作动画而不必在css中创建点的阴影. 这个小提琴http://jsfiddle.net/jvrvK/显示了我到目前为止所得到的内容.我看看球体的外观,但动画似乎在Chrome中不起作用,我不太了解CSS动画,足以在PNG中创建相同类型的旋转.
非常感谢您的帮助!
小提琴代码如下:
<ul class="busy"> <li class="busy-dot1"><b class="busy-dot-shine"></b></li> <li class="busy-dot2"><b class="busy-dot-shine"></b></li> <li class="busy-dot3"><b class="busy-dot-shine"></b></li> <li class="busy-dot4"><b class="busy-dot-shine"></b></li> <li class="busy-dot5"><b class="busy-dot-shine"></b></li> </ul>
.busy { list-style: none; padding: 0; position: relative; transform-style: preserve-3d; animation: rot 4s linear infinite; width:100px; } .busy-dot1, .busy-dot2, .busy-dot3, .busy-dot4, .busy-dot5 { border-radius: 50%; display: inline-block; transform-style: preserve-3d; margin: 0 4px; } .busy-dot-shine { display: block; border-radius: 50%; background: radial-gradient(circle at 25% 25%, #FFF, rgba(255,255,255,0)); background-color: #193987; animation: rotr 4s linear infinite; height: 20px; width: 20px; }这将是一个近似的解决方案
demo
HTML与您拥有的相同; CSS是
.busy { list-style: none; padding: 0; position: relative; width:100px; } .busy-dot1, .busy-dot2, .busy-dot3, .busy-dot4, .busy-dot5 { border-radius: 50%; display: inline-block; position: absolute; left: 150px; top: 50px; -webkit-animation: rot 4s linear infinite; animation: rot 4s linear infinite; } .busy-dot2 { -webkit-animation-delay: -3.5s; animation-delay: -3.5s; } .busy-dot3 { -webkit-animation-delay: -3s; animation-delay: -3s; } .busy-dot4 { -webkit-animation-delay: -2.7s; animation-delay: -2.7s; } .busy-dot-shine { display: block; border-radius: 50%; background: radial-gradient(circle at 25% 25%, #FFF, rgba(255,255,255,0)); background-color: #193987; height: 20px; width: 20px; } .busy-dot2 .busy-dot-shine { height: 15px; width: 15px; } .busy-dot3 .busy-dot-shine { height: 10px; width: 10px; } .busy-dot4 .busy-dot-shine { height: 6px; width: 6px; } @-webkit-keyframes rot { 0% {-webkit-transform: scaleX(2) rotate(0deg) translateX(50px) scale(1) rotate(0deg) scaleX(0.5); opacity: 0.5;} 25% {-webkit-transform: scaleX(2) rotate(90deg) translateX(50px) scale(1.5) rotate(-90deg) scaleX(0.5); opacity: 0.8;} 50% {-webkit-transform: scaleX(2) rotate(180deg) translateX(50px) scale(1) rotate(-180deg) scaleX(0.5); opacity: 0.5;} 75% {-webkit-transform: scaleX(2) rotate(270deg) translateX(50px) scale(0.8) rotate(-270deg) scaleX(0.5); opacity: 0.2;} 100% {-webkit-transform: scaleX(2) rotate(360deg) translateX(50px) scale(1) rotate(-360deg) scaleX(0.5); opacity: 0.5;} } @keyframes rot { 0% {transform: scaleX(2) rotate(0deg) translateX(50px) scale(1) rotate(0deg) scaleX(0.5); opacity: 0.5;} 25% {transform: scaleX(2) rotate(90deg) translateX(50px) scale(1.5) rotate(-90deg) scaleX(0.5); opacity: 0.8;} 50% {transform: scaleX(2) rotate(180deg) translateX(50px) scale(1) rotate(-180deg) scaleX(0.5); opacity: 0.5;} 75% {transform: scaleX(2) rotate(270deg) translateX(50px) scale(0.8) rotate(-270deg) scaleX(0.5); opacity: 0.2;} 100% {transform: scaleX(2) rotate(360deg) translateX(50px) scale(1) rotate(-360deg) scaleX(0.5); opacity: 0.5;} }
诀窍是设置一个在X中缩放2次的变换(在旋转时生成一个椭圆),然后旋转并平移以形成一个圆.
然后应用刻度使圆圈变大,最后反向旋转以使球体看起来正确
当然,所有的值都是近似的,GIF太小,无法判断这是否准确