将动画SVG停止在屏幕上的某个位置

时间:2019-09-17 14:02:31

标签: css css-animations svg-animate

使用此示例,是否可以将CSS动画停止在屏幕上的固定点?因此,举例来说,它正在移动,我决定让它从屏幕右上方停止,例如20px。仅CSS就能做到吗?

.bird {
  background-image: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/174479/bird-cells.svg);
  background-size: auto 100%;
  width: 88px;
  height: 125px;
  will-change: background-position;
  animation-name: fly-cycle;
  animation-timing-function: steps(10);
  animation-iteration-count: infinite;
}
.bird--one {
  animation-duration: 1s;
  animation-delay: -0.5s;
}

.bird-container {
  position: absolute;
  top: 20%;
  left: -10%;
  transform: scale(0) translateX(-10vw);
  will-change: transform;
  animation-name: fly-right-one;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}
.bird-container--one {
  animation-duration: 15s;
  animation-delay: 0;
}

@keyframes fly-cycle {
100% {
	background-position: -900px 0;
}
}

@keyframes fly-right-one {

0% {
	transform: scale(0.3) translateX(-10vw);
}

10% {
	transform: translateY(2vh) translateX(10vw) scale(0.4);
}

20% {
	transform: translateY(0vh) translateX(30vw) scale(0.5);
}

30% {
	transform: translateY(4vh) translateX(50vw) scale(0.6);
}

40% {
	transform: translateY(2vh) translateX(70vw) scale(0.6);
}

50% {
	transform: translateY(0vh) translateX(90vw) scale(0.6);
}

60% {
	transform: translateY(0vh) translateX(110vw) scale(0.6);
}

100% {
	transform: translateY(0vh) translateX(110vw) scale(0.6);
}
}
<div style="width:100%;">
 <div class="bird-container bird-container--one">
  <div class="bird bird--one"></div>
  </div>
</div>

https://jsfiddle.net/14ndk5xg/

1 个答案:

答案 0 :(得分:2)

通过将VW更改为较小的数字,您可以使它在距屏幕右侧一定距离处停止。如果您始终希望小鸟在屏幕移动大约90%的宽度时停下来,则可以将VW更改为90。 使用当前设置的方式,要使其停止在一定数量的像素上并不容易。

通过将下面的代码设置为50%并删除较高的百分比,您可以使鸟儿向右飞90%,然后飞到右上角。

50% {
        transform: translateY(-20vh) translateX(90vw) scale(0.6);
    }