Maison >interface Web >tutoriel CSS >Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet d'animation de lanterne festive !

Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet d'animation de lanterne festive !

青灯夜游
青灯夜游avant
2022-01-10 19:33:492700parcourir

Il est temps de célébrer la nouvelle année. L'article suivant vous montrera comment dessiner une lanterne avec CSS et ajouter des effets d'animation pour obtenir l'effet de la lanterne se balançant à gauche et à droite.

Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet d'animation de lanterne festive !

C'est le Nouvel An~ C'est le Nouvel An~ C'est le Nouvel An~

Dites au revoir à l'ancien et accueillez la nouvelle année, c'est la Fête du Printemps~

Le coq d'or danse pour envoyer des bénédictions, le nouveau l'année approche~

Les premières paroles de l'article, j'ai immédiatement senti que ça n'a pas l'air festif Nos lanternes ressemblent à ça ?

Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet danimation de lanterne festive !

Attribut d'animation

Dessiner une lanterne Nous ne pouvons certainement pas dessiner une lanterne statique. Examinons d'abord l'attribut animation en CSS. Il s'agit d'un attribut d'abréviation, représenté par animation. -name, animation-durée, animation-timing-function, animation-delay, animation-iteration-count Attributs , animation-direction, animation-fill-mode et animation-play-state. Nous ne l'expliquerons pas ici. Vous pouvez en savoir plus dans MDN. animation属性,该是是一个简写属性,由animation-nameanimation-durationanimation-timing-functionanimation-delayanimation-iteration-countanimation-directionanimation-fill-mode 和 animation-play-state 属性组成。这里我们就不展开讲解了,具体可以到MDN中学习。

我们先来看一下下面这个示例:

animation: swing 3s infinite ease-in-out;

在上面的例子中使用了一个名为swing的动画序列,动画序列通过@keyframes创建,执行时间3s,动画循环执行,最后ease-in-out表示动画执行的节奏。

实现思路

  • 为一个矩形添加border-radius使其,形成一个灯笼的外形。

  • 为矩形添加::before::after来形成灯笼的顶部和头部

  • 画一个灯笼线。

  • 在 矩形内部添加两个比较细的矩形,通过添加 border-radius 来形成灯笼的线条。

  • 设置灯笼的动画效果

  • 添加灯穗的样式

接下来我们就分步骤实现。

绘制灯笼外形

首先我们定义HTML结构,代码如下:

<!-- 灯笼容器 -->
<div class="lantern-con">
  <!-- 提着灯笼的线 -->
  <div class="lantern-line"></div>
  <!-- 灯笼主要区域 -->
  <div class="lantern-light">
  </div>
</div>

然后我们画一个椭圆,然后通过::before::after,绘制上下的两个灯笼盖,CSS如下:

/* 灯笼容器 */
.lantern-con {
  position: fixed;
  left: 160px;
}

/* 灯笼中间红色区域 */
.lantern-light {
  position: relative;
  width: 120px;
  height: 90px;
  background-color: red;
  margin: 30px;
  border-radius: 50%;
  box-shadow: -5px 5px 50px 4px #fa6c00;
  /* 设置旋转点 */
  transform-origin: top center;
  animation: swing 3s infinite ease-in-out;
}

/* 灯笼顶部和底部的样式 */
.lantern-light::before,
.lantern-light::after {
  content: &#39;&#39;;
  position: absolute;
  border: 1px solid #dc8f03;
  width: 60px;
  height: 12px;
  /* 背景渐变 */
  background: linear-gradient(
    to right,
    #dc8f03,
    #ffa500,
    #dc8f03,
    #ffa500,
    #dc8f03
  );
  left: 30px;
}

/* 顶部位置 */
.lantern-light::before {
  top: -7px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}

/* 底部位置 */
.lantern-light::after {
  bottom: -7px;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

/* 提着灯笼的线的样式 */
.lantern-line {
  width: 2px;
  height: 50px;
  background-color: #dc8f03;
  position: absolute;
  left: 88px;
}
/* 灯笼的动画效果 */
@keyframes swing {
  0% {
    transform: rotate(-6deg);
  }

  50% {
    transform: rotate(6deg);
  }

  100% {
    transform: rotate(-6deg);
  }
}

现在就实现了一个比较基础灯笼外形,效果如下:

Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet danimation de lanterne festive !

灯笼内部线条

灯笼的内部线条是通过两个矩形实现了,通过border-radius

Jetons d'abord un coup d'œil à l'exemple suivant :

<div class="lantern-light">
  <!-- 灯笼中间的线条 -->
  <div class="lantern-circle">
    <div class="lantern-rect">
      <!-- 灯笼中间的文字内容 -->
      <div class="lantern-text">灯笼</div>
    </div>
  </div>
</div>

Dans l'exemple ci-dessus, une séquence d'animation nommée swing est utilisée. La séquence d'animation est créée via @keyframes. . Le temps d'exécution est de 3s, l'animation est exécutée en boucle, et le dernier ease-in-out indique le rythme d'exécution de l'animation.

Idée d'implémentation
  • Ajoutez border-radius à un rectangle pour former une forme de lanterne. Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet danimation de lanterne festive !

  • Ajoutez ::before et ::after au rectangle pour former le haut et la tête de la lanterne

Tracez une ligne de lanterne.

  • Ajoutez deux rectangles plus fins à l'intérieur du rectangle et formez les lignes de la lanterne en ajoutant un rayon de bordure.

  • Définissez l'effet d'animation de la lanterne

  • Ajoutez le style du piquet de la lampe

  • Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet danimation de lanterne festive !Ensuite, nous le mettrons en œuvre étape par étape .

    Dessinez la forme de la lanterne

    Nous définissons d'abord la structure HTML, le code est le suivant :

    /* 灯笼中间的线条 */
    .lantern-circle,
    .lantern-rect {
      height: 90px;
      border-radius: 50%;
      border: 2px solid #dc8f03;
      background-color: rgba(216, 0, 15, 0.1);
    }
    
    /* 外层 */
    .lantern-circle {
      width: 100px;
      margin: 12px 8px 8px 10px;
    }
    
    /* 内层 */
    .lantern-rect {
      margin: -2px 8px 8px 26px;
      width: 45px;
    }
    
    /* 文字样式 */
    .lantern-text {
      font-size: 28px;
      font-weight: bold;
      text-align: center;
      color: #dc8f03;
      margin-top: 4px;
    }

    Ensuite, nous dessinons une ellipse, puis passons ::before et ::after, dessinez les couvercles supérieur et inférieur de la lanterne, le CSS est le suivant : 🎜
    <!-- 灯笼主要区域 -->
    <div class="lantern-light">
      <!-- more code -->
      <!-- 灯笼穗 -->
      <div class="lantern-tassel-top">
        <div class="lantern-tassel-middle"></div>
        <div class="lantern-tassel-bottom"></div>
      </div>
    </div>
    🎜 Maintenant, une forme de lanterne relativement basique a été implémentée, l'effet est le suivant : 🎜 🎜Il est temps de célébrer la nouvelle année, utilisez CSS pour obtenir un effet danimation de lanterne festive !🎜

    Lignes internes de la lanterne 🎜🎜Les lignes internes de la lanterne sont réalisées à travers deux rectangles. Définissez-les en ellipses via l'attribut border-radius, puis dessinez les côtés selon. présenter les lignes de lanternes. Le CSS correspondant de 🎜
    /* 灯穗 */
    .lantern-tassel-top {
      width: 5px;
      height: 20px;
      background-color: #ffa500;
      border-radius: 0 0 5px 5px;
      position: relative;
      margin: -5px 0 0 59px;
      /* 让灯穗也有一个动画效果 */
      animation: swing 3s infinite ease-in-out;
    }
    
    .lantern-tassel-middle,
    .lantern-tassel-bottom {
      position: absolute;
      width: 10px;
      left: -2px;
    }
    
    .lantern-tassel-middle {
      border-radius: 50%;
      top: 14px;
      height: 10px;
      background-color: #dc8f03;
      z-index: 2;
    }
    
    .lantern-tassel-bottom {
      background-color: #ffa500;
      border-bottom-left-radius: 5px;
      height: 35px;
      top: 18px;
      z-index: 1;
    }
    🎜 est le suivant : 🎜rrreee🎜L'effet est le suivant : 🎜🎜🎜🎜🎜Lantern Spike🎜🎜Maintenant, dessinons la pointe de la lanterne. Cette chose est relativement simple. La chose la plus importante est d'ajouter un. effet d'animation. Sa structure HTML est la suivante : 🎜rrreee🎜Le CSS est la suivante : 🎜rrreee🎜À ce stade, nous avons fini de dessiner cette lanterne. 🎜🎜🎜🎜🎜 (Partage de vidéos d'apprentissage : 🎜Tutoriel vidéo CSS🎜)🎜

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Déclaration:
    Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer