9

尝试使用 css3 动画连续闪烁三个元素。我已经让它运行了,但是每一帧都有一个淡入淡出,我想删除它。理想情况下,每个元素保持可见 1 秒,然后立即隐藏。

我已经尝试设置动画与帧在0%99%foropacity:1100%foropacity: 0但仍然没有运气。

我希望有办法消除褪色!

webkit js小提琴

CSS:

.motion.play .frame {
    -webkit-animation-name: flash;
    -webkit-animation-duration: 3s;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-direction: linear;
}
    .frame:nth-of-type(2) {
        -webkit-animation-delay: 1s;
    }
    .frame:nth-of-type(3) {
        -webkit-animation-delay: 2s;
    }

    @-webkit-keyframes flash {
        0% {
            opacity: 1;
        }
        100% {
            opacity: 0;
        }
    }
4

3 回答 3

17

只需定义您的动画,使其尽可能长时间地保持一种状态,然后尽快切换到另一种状态。像这样:

@-webkit-keyframes flash {
      0% { opacity: 1; }
     49% { opacity: 1; }
     50% { opacity: 0; }
    100% { opacity: 0; }
}
于 2015-01-27T13:18:20.257 回答
6

正确使用animation-timing-function

http://jsfiddle.net/rfGDD/1/(仅限 WebKit)

.motion.play .frame {
    -webkit-animation-name: flash;
    -webkit-animation-duration: 3s;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-direction: normal; /* not "linear" */
    -webkit-animation-fill-mode:forwards;
    -webkit-animation-timing-function:steps(3, end);
}

MDN 文档fill-mode

MDN 文档direction

steps()关于计时功能的 MDN 文档

编辑

糟糕,刚刚意识到逻辑缺陷。

修订: http: //jsfiddle.net/rfGDD/3/(仅限 WebKit)

除了上述更改,将flash动画更改为以下内容:

@-webkit-keyframes flash {
    0% {
        opacity: 1;
    }
    33% {
        opacity: 0;
    }
    100% {
        opacity: 0;
    }
}

问题是,动画播放了 3 秒,但是每个元素都需要保持在opacity:0第 1 秒之后的状态,所以我需要将动画分成 2 个阶段(时间长度比为 1:2),所以元素看起来像他们在最后阶段停留 2 秒。

于 2013-03-18T03:40:01.790 回答
3

您可以将不透明度保持最长时间并快速更改它。

尝试这个:

.blinkMe {
  animation: blink 1s linear infinite;
}

@keyframes blink {
  0%,50% {
    opacity: 0;
  }
  51%,100% {
    opacity: 1;
  }
}
于 2016-06-18T04:05:09.217 回答