CSS 实现航班起飞、飞行和降落动画

CSS 实现航班起飞、飞行和降落动画

效果展示

  • 航班起飞阶段
    在这里插入图片描述

  • 航班飞行阶段
    在这里插入图片描述

  • 航班降落
    在这里插入图片描述

CSS 知识点

  • animation 属性的综合运用
  • :active 属性的运营

动画分解

航班滑行阶段动画

实现航班的滑行阶段动画,需要使用两个核心物件,一个是跑动动画,另外一个是固定在跑道上的航班。实现跑道可以使用background属性的repeating-linear-gradient来实现,然后结合使用animation属性实现跑道动画,这样就可以实现航班滑行阶段的动画。

航班起飞阶段动画

起飞阶段主要使用:active实现鼠标按下激活航班放大和跑道消失和变小的动画。

航班飞行阶段动画

航班飞行动画核心就是云层的动画。

航班降落阶段动画

航班降落阶段的动画其实就是鼠标放开后,云层消失、航班变小和跑道还原的动画过程。

整体页面布局

<section>
  <!-- 左侧云层 -->
  <div class="clounds">
    <img src="cloud1.png" style="--i:1" />
    <img src="cloud2.png" style="--i:2" />
    <img src="cloud3.png" style="--i:3" />
  </div>
  <!-- 右侧云层 -->
  <div class="clounds clounds2">
    <img src="cloud1.png" style="--i:1" />
    <img src="cloud2.png" style="--i:2" />
    <img src="cloud3.png" style="--i:3" />
  </div>
  <!-- 滑行跑道 -->
  <div class="runway"></div>
  <!-- 飞机 -->
  <img src="plane.png" class="plane" />
</section>

实现跑道和飞机样式

section {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  height: 100vh;
  background: #034071;
}

section .runway {
  position: relative;
  width: 400px;
  height: 100vh;
  background: #1379bc;
  border-left: 20px solid rgba(0, 0, 0, 0.25);
  border-right: 20px solid rgba(0, 0, 0, 0.25);
  transition: transform 1s;
  /* 延迟动画,主要是用于降落使用 */
  transition-delay: 1s;
  transform-origin: top;
}

section .runway::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 15px;
  height: 100%;
  background: repeating-linear-gradient(
    transparent 0%,
    transparent 50%,
    #fff 50%,
    #fff 100%
  );
  background-size: 20px 320px;
}

.plane {
  position: absolute;
  bottom: 100px;
  max-width: 250px;
  pointer-events: none;
  /* 航班影子 */
  filter: drop-shadow(10px 10px 0 rgba(0, 0, 0, 0.5));
  /* 控制5庙后 :active 属性激活后触发对应的样式 */
  transition: 5s;
}

实现上述代码后效果如下:

在这里插入图片描述

实现航班滑行动画

航班的滑行的动画可以使用:active和动画结合实现。具体代码如下:

section:active .runway {
  transform: scaleX(0.7) scaleY(0);
  transition-delay: 0s;
  transform-origin: bottom;
}

@keyframes anumateRunWay {
  0% {
    background-position-y: 0px;
  }
  100% {
    background-position-y: 320px;
  }
}

实现航班起飞动画

航班的起飞主要是通过鼠标点击section元素后触发,所以可以使用:active属性来实现动画。具体的代码如下:

section:active .runway {
  transform: scaleX(0.7) scaleY(0);
  transition-delay: 0s;
  transform-origin: bottom;
}

section:active .runway::before {
  animation: anumateRunWay 0.25s linear infinite;
}

section:active .plane {
  max-width: 500px;
  filter: drop-shadow(200px 200px 0 rgba(0, 0, 0, 0));
}

实现上述代码后,鼠标左键点击下去一直按住不动,就会可以看到飞起起飞的效果。

实现航班飞行动画

通过上述的代码实现,现在航班可以从滑行到起飞有了动画,现在就是实现云层的动画,从而结合飞机实现航班飞行的动画。具体代码如下:

.clounds {
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  /* 控制几秒后显示云层 */
  transition: opacity 2s;
  transition-delay: 0s;
}

/* 当 :active 属性激活后显示云层 */
section:active .clounds {
  opacity: 1;
  transition-delay: 1s;
}

.clounds img {
  position: absolute;
  left: 0;
  width: 800px;
  animation: animateClouds 4s linear infinite;
  /* 控制多个云层做延迟动画,形成动画运动差 */
  animation-delay: calc(-1.5s * var(--i));
}

.clounds2 {
  right: 0;
  transform: rotate(180deg);
}

.clounds2 img {
  animation: animateClouds2 4s linear infinite;
  /* 控制多个云层做延迟动画,形成动画运动差 */
  animation-delay: calc(-1.5s * var(--i));
}

@keyframes animateClouds {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}

@keyframes animateClouds2 {
  0% {
    transform: translateY(100%);
  }
  100% {
    transform: translateY(-100%);
  }
}

实现航班降落动画

因为使用:active属性实现动画,所以当鼠标左键释放的时候,动画属性就会还原从而执行降落的动画,所以不用编写降落的动画。

完整代码下载

完整代码下载

  • 18
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue提供了过渡动画的内置支持,可以通过Vue的transition组件来实现过渡动画。在transition组件中,可以定义进入动画、离开动画和过渡模式等。同时,CSS也提供了丰富的动画效果,可以通过CSS的transition属性来实现过渡动画。 下面是一个使用Vue和CSS实现过渡动画的示例: ```html <template> <div> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello, World!</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> <script> export default { data() { return { show: false }; } }; </script> ``` 在上面的示例中,我们定义了一个按钮和一个包裹着文本的transition组件。文本的显示与隐藏通过控制show属性来实现。同时,我们也定义了一个名为"fade"的transition,它定义了进入和离开动画的方式。 在CSS中,我们定义了两个类名为"fade-enter-active"和"fade-leave-active",它们分别表示进入和离开动画的状态。这里我们使用了CSS的transition属性,它指定了过渡的属性和时长。在这个例子中,我们使用opacity属性和0.5秒的时长来实现淡入淡出的效果。 同时,我们也定义了类名为"fade-enter"和"fade-leave-to",它们分别表示进入和离开动画的初始和结束状态。在这个例子中,我们将opacity属性的值设置为0,表示文本初始时是透明的,离开时也是透明的。 通过这样的方式,我们就可以使用Vue和CSS实现过渡动画了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值