我有一个旋转动画,我象征着正在加载的东西。这很好用(除了它不会连续旋转,它有点在360度左右时停止一些),但在某些手机上(我有一个Android注释4)它根本不旋转。然后在其他人(iphone)上,我的圆圈实际上会像摆动一样旋转,或者固定在圆圈的一个角落,然后从那个轴旋转。
我的代码中有webkits,我将img设置为:
#spinning-circle img {
width: 100%;
height: auto;
}
为什么我的形象会做这些事情。如果你想在移动环境中看到它,我可以给网址直播。
#spinning-circle-container {
float: left;
width: 40%;
background: red;
padding: 140px 0 0 10%;
}
#spinning-circle {
animation-name: spinning-circle;
animation-duration: 4s;
animation-iteration-count: infinite;
width: 100px;
height: 100px;
}
#spinning-circle img {
width: 100%;
height: auto;
}
@-webkit-keyframes spinning-circle {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}
#spinning-circle-title {
padding-top: 35px;
color: #000;
font-size: 2.8em;
}
@media screen and (max-width:640px) {
#spinning-circle-container {
width: 80%;
padding: 40px 0 0 6%;
}
#spinning-circle {
animation-name: spinning-circle;
animation-duration: 4s;
animation-iteration-count: infinite;
width: 50px;
height: 50px;
}
#spinning-circle img {
width: 100%;
height: auto;
}
@-webkit-keyframes spinning-circle {
0% {
-webkit-transform: rotate(0deg);
-webkit-transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(360deg);
-webkit-transform: rotate(360deg);
}
}
#spinning-circle-title {
padding-top: 35px;
color: blue;
font-size: 1.5em;
}
}
<div id="spinning-circle-container">
<div id="spinning-circle">
<img src="http://optimumwebdesigns.com/images/spinning-circle.png">
</div>
<div id="spinning-circle-title">LOADING...</div>
</div>
答案 0 :(得分:2)
-webkit-transform
中使用带前缀的@webkit-keyframes
,而不带前缀transform
的前缀@keyframes
。此外,您还需要添加前缀-webkit-animation
。animation-timing-function: linear
,但动画会保持恒定速度。@keyframes
内复制@media screen {}
和其他属性。
#spinning-circle-container {
float: left;
width: 40%;
background: red;
padding: 140px 0 0 10%;
}
#spinning-circle {
-webkit-animation: spinning-circle linear 2s infinite;
animation: spinning-circle linear 2s infinite;
width: 100px;
height: 100px;
}
#spinning-circle img {
width: 100%;
height: auto;
}
#spinning-circle-title {
padding-top: 35px;
color: #000;
font-size: 2.8em;
}
@media screen and (max-width: 640px) {
#spinning-circle-container {
width: 80%;
padding: 40px 0 0 6%;
}
#spinning-circle {
width: 50px;
height: 50px;
}
#spinning-circle-title {
color: blue;
font-size: 1.5em;
}
}
@-webkit-keyframes spinning-circle {
0% {
-webkit-transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(360deg);
}
}
@keyframes spinning-circle {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
&#13;
<div id="spinning-circle-container">
<div id="spinning-circle">
<img src="http://optimumwebdesigns.com/images/spinning-circle.png">
</div>
<div id="spinning-circle-title">LOADING...</div>
</div>
&#13;
答案 1 :(得分:1)
您必须在动画定义中添加animation-timing-function: linear;
。
这里有代码https://jsfiddle.net/xhurpqLd/
- 编辑 -
你也有
@-webkit-keyframes spinning-circle {
0% {
-webkit-transform: rotate(0deg) ;
-webkit-transform: rotate(0deg) ;
}
100% {
-webkit-transform: rotate(360deg) ;
-webkit-transform: rotate(360deg) ;
}
}
您只定义了webkit的转换。改为
@-webkit-keyframes spinning-circle {
0% {
-webkit-transform: rotate(0deg) ;
transform: rotate(0deg) ;
}
100% {
-webkit-transform: rotate(360deg) ;
transform: rotate(360deg) ;
}
}
您可以在此处获得更新后的代码https://jsfiddle.net/xhurpqLd/3/。它适用于我的Android。
您还可以为IE支持添加-ms-transform
。
答案 2 :(得分:0)
main-style.css
的第731-733行和第1391-1393行似乎导致摆动问题。
*::after, *::before {
content: '';
}
应该是
*::after, *::before {
content: '';
display: table;
}
假设您尝试使用this clearfix方法