如何减慢关键帧动画?

Vir*_*hli 2 css animation keyframe

我有这个代码:

.blur {
  -webkit-animation: blur 5s ;
  -webkit-animation-fill-mode: forwards;
}

@-webkit-keyframes blur {
  0% { -webkit-filter: blur(0px); }
  0% { -webkit-filter: blur(1px); }
  50% { -webkit-filter: blur(5px); }
  60% { -webkit-filter: blur(5px); }
  100% {
    opacity: 0;
  }
}
Run Code Online (Sandbox Code Playgroud)
<img src="http://placehold.it/350x150" class="blur" />
Run Code Online (Sandbox Code Playgroud)

基本上我有一个图像,我想要的效果是慢慢淡入,模糊然后淡出。但是当它模糊时,我希望它在那里停留几秒钟,然后淡出图片。你能帮我一下吗?谢谢

Ale*_*lex 5

从关键帧的角度考虑,您想让动画知道何时开始淡入淡出。否则,它假定您正在努力实现动画持续时间的最终不透明度。

为了防止这种情况,请opacity在开始淡入淡出之前将您的位置固定在 1。你可以尝试这样的事情:

.blur {
  -webkit-animation: blur 5s ;
  -webkit-animation-fill-mode: forwards;
}

@-webkit-keyframes blur {
  0% { -webkit-filter: blur(0px); }
  0% { -webkit-filter: blur(1px); }
  50% { -webkit-filter: blur(5px); }
  60% { -webkit-filter: blur(5px); }
  90% { 
    -webkit-filter: blur(5px);
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
Run Code Online (Sandbox Code Playgroud)
<img src="http://placehold.it/350x150" class="blur" />
Run Code Online (Sandbox Code Playgroud)

上面的代码只在动画的最后 10% 开始淡出 - 否则,模糊的图像会挂起。您可以使用.blur持续时间和关键帧百分比来微调此持续时间(较大的百分比分布 = 淡出前的较长时间)。