CSS 动画延迟和播放状态行为

Posted

技术标签:

【中文标题】CSS 动画延迟和播放状态行为【英文标题】:CSS Animations delay and play-state behavior 【发布时间】:2015-08-31 12:28:12 【问题描述】:

我正在尝试捕捉元素动画中的特定时刻。含义 - 我希望动画在 X 点开始和停止(假设在 100 秒动画的第 5 秒开始和停止)。

这是我的尝试 JSFiddle

@-webkit-keyframes background 
  from  background: yellow; 
  100% 
    background: blue;
  


div 
  -webkit-animation-name: background;
  -webkit-animation-duration: 100s;
  -webkit-animation-fill-mode: forwards;
  -webkit-animation-delay: -40s;
  -webkit-animation-play-state: paused;

这似乎在 Chrome 和 Firefox 中运行良好,但在 Safari 和 IE 中似乎不起作用(不可能,对吧?!) 注意:我保留前缀是为了专门在 Safari 上测试它。

与 Chrome 不同,在 Safari 中动画似乎永远不会开始,而是停留在初始步骤。

这是一个已知问题吗?是否有解决方法或其他方法来实现这一点?

更新/澄清

我需要的是能够捕捉动画的特定帧。在 Chrome 中打开我的小提琴并在我的小提琴中播放动画延迟属性(确保它保持负数)。您将看到的是您能够捕捉到动画的 1 个特定帧。这正是我需要的。我的问题是这在 Safari 中不起作用。

【问题讨论】:

动画延迟应该是大于0的数字 不正确。 developer.mozilla.org/en-US/docs/Web/CSS/animation-delay 为动画延迟指定负值会导致动画立即开始执行。但是,它似乎已经在其周期的中途开始执行。例如,如果您将 -1s 指定为动画延迟时间,则动画将立即开始,但会在动画序列的 1 秒后开始。 在规范中看起来模棱两可。如果动画被暂停,Safari 不会启动动画,即使是负延迟也是如此。如果您允许它启动,然后在延迟之后,以编程方式设置style.webkitAnimationPlayState('paused') 它“有效”,但我得到了奇怪的结果,超时时间很短 - 似乎跳到动画的结尾,这对我来说毫无意义......无论如何,这里有 100 毫秒的延迟 jsfiddle.net/Lb06rh1L 感谢您的回答。我仍然更喜欢仅使用 CSS 的解决方案,因为需要为页面上的多个对象完成此过程。 如果有什么我错过了,我想知道更多关于我的答案。 【参考方案1】:

如何创建一个 5 秒的关键帧动画并确保帧相同的“100 毫秒百分比”。

由于时间的动画比例是百分比,我们可以计算出100ms/5000ms等于2%/100%。

div 
    background:#333;
    padding:10px;
    width:100px;
    height:100px;
    color:#fff;
    animation-name: animateAndPause;
    animation-duration: 5s;
    animation-iteration-count: infinite;

@keyframes animateAndPause 
    0%  
     -ms-transform: rotate(0deg); /* IE 9 */
     -webkit-transform: rotate(0deg); /* Chrome, Safari, Opera */
     transform: rotate(0deg);
    
    98%       
     -ms-transform: rotate(360deg); /* IE 9 */
     -webkit-transform: rotate(360deg); /* Chrome, Safari, Opera */
     transform: rotate(360deg); 
       
   100%  
     -ms-transform: rotate(360deg); /* IE 9 */
     -webkit-transform: rotate(360deg); /* Chrome, Safari, Opera */
     transform: rotate(360deg);    
    

为了演示,jsfiddle的停顿时间更长,500ms。

https://jsfiddle.net/bfu9wvxt/5/

【讨论】:

这仍然不允许我捕捉动画的特定帧。在我的小提琴中使用 -webkit-animation-delay 值来看看我的意思(确保它仍然是负数)。您将看到,您正在捕捉动画的特定帧。这就是我需要的。 我玩过动画延迟,虽然我看不到你想去哪里,你能把它放在上下文中吗?负值看起来很像正等值。 w3schools.com/cs-s-ref/… 它是这样的:(没关系),但我需要获得具有一定不透明度的颜色,而我不能使用 rgba() 函数。例如,给定黑色,我想在不使用 RGBA 的情况下获取 rgba(#000, .5)。我想的方法是创建一个动画长度为 100 毫秒。然后在某个点开始和结束动画(因此使用负延迟)。这基本上允许我从动画中捕捉 1 帧,捕捉特定不透明状态下的颜色。希望它清楚。 @Frankey 我认为纯粹的 css 很难做到这一点,一些 javascript 总是有帮助的,只需向元素添加一个类,其超时时间与您的不透明度级别相匹配。或者在此示例中,您可以单击 div 并暂停。 jsfiddle.net/bfu9wvxt/12 这是我正在研究的一个例子。适用于除 safari 以外的所有浏览器。 codepen.io/anon/pen/qZvjVw【参考方案2】:

试试这个代码: 兼容所有浏览器,尤其是 safari。

div 
  width: 100%;
  background-color: #fff;
  position: relative;
  -webkit-animation-name: example;
  /* Chrome, Safari, Opera */
  -webkit-animation-duration: 5s;
  /* Chrome, Safari, Opera */
  -webkit-animation-delay: 5s;
  /* Chrome, Safari, Opera */
  animation-name: example;
  animation-duration: 5s;
  animation-delay: 5s;
  -webkit-animation-iteration-count: 100;
  /* Chrome, Safari, Opera */
  animation-iteration-count: 100;
  

/* Chrome, Safari, Opera */

@-webkit-keyframes example 
  25% 
    background-color: blue;
  
  50% 
    background-color:yellow ;
  
  25% 
    background-color: yellow;
  
  50% 
    background-color: blue;
  

/* Standard syntax */

@keyframes example 
  25% 
    background-color: blue;
  
  50% 
    background-color:yellow ;
  
  25% 
    background-color: yellow;
  
  50% 
    background-color: blue;
  
<div>Color bar</div>

如果你想要它不是100次,你可以把它拿出来加100s到 持续时间,因为我不确定你想要什么

如果您有任何问题,请告诉我。

【讨论】:

感谢您的回答,但这不是我所要求的。我的问题是我需要动画在某个点停止而不是一直走。例如,如果动画从蓝色背景变为黄色,我希望动画在中途某个地方开始和停止。【参考方案3】:

如果您希望动画在特定点停止和开始,则需要更多关键帧:

@-webkit-keyframes background 
    0%  background: yellow; 
    /* When You Want */%  background: /* A different color in-between yellow and blue! */; 
    /* When You Want */%  background: /* A different color in-between yellow and blue! */; 
    100%  background: blue; 

div 
    -webkit-animation-name: background;
    -webkit-animation-duration: 100s;
    -webkit-animation-timing-function: ease;

将第一个 /* When You Want */% 替换为您希望它停止的动画持续时间的百分比。

将第二个/* When You Want */% 替换为您希望它重新开始的动画持续时间的百分比。

将出现的/* A different color in-between yellow and blue! */ 替换为相同的颜色,黄色和蓝色之间的颜色。

【讨论】:

【参考方案4】:

这应该可以在 Safari 中使用:Fiddle

    @-webkit-keyframes change 
      0%  background-color: yellow; 
      100%  background-color: blue; 
    

    div 
        -webkit-animation-name: change;
        -webkit-animation-delay: 0s;
        -webkit-animation-duration: 5s;
        -webkit-animation-play-state: running;
        -webkit-animation-timing-function: cubic-bezier(0.29, 0.3, 0.86, 0.99);
    

使用三次贝塞尔曲线可以复制停止然后从 5 秒开始(每 100 秒)的动画,但如果没有 javascript,将很难启动和停止动画。

【讨论】:

以上是关于CSS 动画延迟和播放状态行为的主要内容,如果未能解决你的问题,请参考以下文章

你如何在反应中取消和重置css动画?

css 您可以通过更改其动画播放状态属性来“暂停”和“播放”CSS动画。将其设置为“暂停”会停止播放动画

unity 有了行为树还用状态机吗

如何停止css animation动画

UML中状态机图概念

具有淡入下拉效果的 Angular 和 CSS 动画