如何使用纯CSS完成一个可爱炫酷的动画效果

简介: 本文利用CCS相关代码,完成了小狗滑梯动画效果。并详细了讲解如何实现

本文利用CCS相关代码,完成了小狗滑梯动画效果。并详细了讲解如何实现

效果图

y38tx-72rcv.gif

第一部分

首先,先来解释CSS的变量定义部分。
在这部分代码中,使用了:root选择器来定义全局的CSS变量,它将用于控制小狗和滑梯的样式。

:root {
   
  --dog-color: #f9c197;
  --background-color: #e9f7f6;
  --slide-color: #fdbf88;
}

在上面的代码中,定义了三个变量:--dog-color表示小狗的颜色,--background-color表示背景色,--slide-color表示滑梯的颜色。这样,我们可以通过修改这些变量的值,来改变小狗和滑梯的外观颜色。

接下来,继续设置body元素的样式定义。

body {
   
  background-color: var(--background-color);
}

代码将页面的背景颜色设置为之前定义的变量--background-color的值。这样,页面的整体背景色将与该变量的值保持一致。

然后找到.box-canvas类的样式定义部分。这部分代码将负责定义一个容器,用于包裹小狗和滑梯的元素。

.box-canvas {
   
  position: relative;
  width: 600px;
  height: 600px;
  margin: 0 auto;
}

在上面的代码里,使用了类选择器.box-canvas来选中这个容器元素。通过设置position属性为relative,使得这个容器内部的元素可以使用相对于该容器的位置进行定位。同时,设置了容器的宽度和高度为600像素,并使用margin: 0 auto;将容器水平居中显示。

来看一下.dog类的样式定义部分。这部分代码负责定义小狗元素的样式。

.dog {
   
  position: absolute;
  right: 50px;
  top: 100px;
  width: 120px;
  height: 150px;
  animation: dogSlide 5s infinite linear;
}

上面代码里,使用了类选择器.dog来选择小狗元素。通过设置position属性为absolute,使得小狗元素可以相对于其父元素进行定位。使用righttop属性来将小狗定位在容器的指定位置。然后,还定义了小狗元素的宽度和高度为120像素150像素。最后,应用了一个名为dogSlide的动画效果,并设置其持续时间为5秒,循环播放并且采用线性的时间函数。

第二部分

来看一下关键帧动画dogSlide的定义部分。这个动画控制小狗元素在不同关键帧位置之间的变化。

@keyframes dogSlide {
   
  0% {
   
    transform: translate(0, 0) rotate(0);
  }
  50% {
   
    transform: translate(200px, 0) rotate(30deg);
  }
  100% {
   
    transform: translate(400px, 0) rotate(0);
  }
}

在上代码里,使用了@keyframes关键字来定义了一个名为dogSlide的关键帧动画。该动画包含三个关键帧:0%、50%和100%。在每个关键帧中使用transform属性来定义小狗元素的位移和旋转效果。

在动画的开始(0%关键帧)时,小狗元素的偏移量为(0, 0),不进行旋转。在动画进行到一半(50%关键帧)时,小狗元素的偏移量变为(200px, 0),并向顺时针方向旋转30度。最后,在动画结束时(100%关键帧),小狗元素的偏移量恢复到(400px, 0),并且不再旋转。

再看看.heart类的样式定义部分。该部分代码负责定义心形图案元素的样式。

.heart {
   
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30px;
  height: 30px;
  background-color: red;
  transform: translate(-50%, -50%);
  animation: heartAppear 1s infinite ease-in-out;
}

在上面代码里,使用.heart选择器来选中心形图案元素。通过设置position属性为absolute,使心形图案元素可以相对于其父元素进行定位。接着,使用topleft属性将心形图案元素定位在其父元素的正中心。然后还定义了心形图案元素的宽度和高度为30像素,并设置背景色为红色。

通过使用transform属性和translate函数,将心形图案元素在其父元素内部进行居中定位。应用了一个名为heartAppear的动画效果,该动画持续时间为1秒,采用缓入缓出的时间函数,并且无限循环播放。

第三部分

.slide类的样式定义部分,该部分代码负责定义滑梯元素的样式。

.slide {
   
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 240px;
  height: 300px;
  background-color: var(--slide-color);
}

上面代码我们使用.slide选择器来选中滑梯元素。通过设置position属性为absolute,使得滑梯元素可以相对于其父元素进行定位。然后使用bottom属性将滑梯元素定位在其父元素的底部。通过left: 50%transform: translateX(-50%)来将滑梯元素在水平方向上居中定位。

同时定义了滑梯元素的宽度和高度分别为240像素和300像素。使用变量--slide-color指定了滑梯的背景颜色,这样可以通过修改变量的值来改变滑梯的外观。

继续看看.slide::before伪元素的样式定义部分。该部分代码用于创建滑梯的左侧把手。

.slide::before {
   
  content: '';
  position: absolute;
  top: 50%;
  left: -20px;
  transform: translateY(-50%);
  width: 20px;
  height: 60px;
  background-color: var(--slide-color);
}

上面代码里使用.slide::before选择器来选中滑梯的伪元素。通过设置content属性为空字符串,创建了一个空的伪元素。使用position属性将伪元素相对于滑梯元素进行定位。

通过top: 50%left: -20px将伪元素定位在滑梯元素的左侧并垂直居中。然后,使用transform: translateY(-50%)将伪元素在垂直方向上进行偏移,使其保持垂直居中。

最后定义了伪元素的宽度和高度分别为20像素和60像素,并且使用变量--slide-color指定了把手的背景颜色。

全部代码

下面就是整合了我们此次教程的全部代码:

HTML

<body>
  <div class="box-canvas">
    <div class="dog">
      <div class="heart"></div>
      <div class="body"></div>
      <div class="nose"></div>
      <div class="ear"></div>
      <div class="eye"></div>
      <div class="tail"></div>
    </div>
    <div class="slide">
      <div class="slide-end"></div>
      <div class="slide-main"></div>
      <div class="slide-start"></div>

    </div>
  </div>
</body>

CSS

:root {
   
  --dog-color: white;
  --dog-accent-color: #333642;
  --background-color: #25A9FC;
  --slide-color: #FEDF01;
  --ladder-color: #0185B5;
  --heart-color: #E81C23;
}

body{
   
  background: var(--background-color);
}

.box-canvas{
   
  position: relative;
  margin: auto;
  display: block;
  margin-top: 8%;
  margin-bottom: 8%;
  width: 600px;
  height:600px;
}

/* Convenience wrapper for easy positioning */
.dog {
   
  position: absolute;
  right: 170px;
  top: 70px;
  width: 58px;
  height: 75px;
  animation: dogSlide 2s infinite ease-in-out;
}

@keyframes dogSlide {
   
  10% {
   
    transform: translateX(-25px);
  }

  70% {
   
    transform: rotate(-20deg) translate(-185px, 50px);
  }

  90% {
   
     transform: translate(-205px, 125px);
  }

  100% {
   
     transform: translate(-205px, 125px);
  }
}

.heart {
   
  opacity: 0;
  position: absolute;
  background: var(--heart-color);
  width: 15px;
  height: 15px;
  border-radius: 50%;
  top: -50px;
  left: 60%;
  transform: translateX(-60%);
  animation: heartAppear 2s infinite ease-in-out;
}

.heart::before {
   
  content: '';
  position: absolute;
  left: 10px;
  background: var(--heart-color);
  width: 15px;
  height: 15px;
  border-radius: 50%;
}

.heart::after {
   
  content: '';
  position: absolute;
  top: 10px;
  left: 0;
  background: var(--heart-color);
  width: 25px;
  height: 10px;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}

@keyframes heartAppear {
   
  0% {
   
     opacity: 0;
  }

  50% {
   
    opacity: 0;
  }

  70% {
   
    opacity: 1;
  }

  90% {
   
    opacity: 1;
  }

  100% {
   
    opacity: 0;
  }
}

.body {
   
  position: absolute;
  left: 13px;
  width: 44px;
  height: 75px;
  border-radius: 25% 10% 20% 20%;
  background: var(--dog-color);
}

.body::before{
   
  content: '';
  position: absolute;
  top: 5px;
  left: -3px;
  background: var(--dog-color);
  border-radius: 20%;
  width: 20px;
  height: 30px;
  transform: rotate(45deg);
}

/* Snout section */
.body::after {
   
  content: '';
  position: absolute;
  background: var(--dog-color);
  width: 25px;
  height: 15px;
  top: 20px;
  left: -12px;
  border-radius: 20% 20% 50% 20%;
  border-bottom: 2px solid var(--dog-accent-color);
  animation: dogSmile 2s infinite ease-in-out;
}

@keyframes dogSmile {
   
  0% {
   
    border-radius: 20% 20% 20% 20%;
    border-bottom: none;
  }

  70% {
   
    border-radius: 20% 20% 50% 20%;
    border-bottom: 2px solid var(--dog-accent-color);
  }
}

.nose {
   
  position: absolute;
  background-color: var(--dog-accent-color);
  width: 8px;
  height: 5px;
  border-radius: 30%;
  top: 20px;
}

.ear {
   
  position: absolute;
  left: 35px;
  width: 20px;
  height: 30px;
  background: var(--dog-accent-color);
  border-radius: 0 0 30% 30%;
}

.eye {
   
  position: absolute;
  left: 22px;
  top: 10px;
  background: var(--dog-accent-color);
  width: 5px;
  height: 5px;
  border-radius: 50%;
}

.tail {
   
  position: absolute;
  bottom: 0;
  right: -8px;
  width: 10px;
  height: 55px;
  background: var(--dog-color);
  transform: rotate(25deg);

}

.tail::before {
   
  content: '';
  position: absolute;
  top: -15px;
  width: 15px;
  height: 25px;
  background: var(--dog-color);
  clip-path: polygon(12% 0, 0% 100%, 100% 100%);
}

.tail::after {
   
  content: '';
  position: absolute;
  top: 5px;
  left: 5px;
  width: 12px;
  height: 25px;
  background: var(--dog-color);
  clip-path: polygon(12% 0, 0% 100%, 100% 100%);
}

/* Convenience wrapper for positioning */
.slide {
   
  position: absolute;
  width: 270px;
  height: 200px;
  left: 50%;
  transform: translateX(-50%);
  top: 100px;
}

.slide-main {
   
  position: absolute;
  bottom: 64px;
  left: 53px;
  width: 200px;
  height: 50px;
  background: var(--slide-color);
  transform: rotate(-45deg);
}

.slide-end {
   
  position: absolute;
  height: 50px;
  width: 100px;
  background: var(--slide-color);
  bottom: 0;
  border-radius: 50% 0 0 0;
}

.slide-start {
   
  position: absolute;
  height: 50px;
  top: 23px;
  width: 63px;
  background: var(--slide-color);
  right: 0px;
}

/* Ladder */
.slide-start::after {
   
  content: '';
  position: absolute;
  height: 177px;
  width: 10px;
  background: var(--ladder-color);
  right: 0;
}

本文同步我的技术文档

相关文章
|
3月前
|
机器学习/深度学习 前端开发 JavaScript
|
6天前
jQuery+CSS3实现404背景游戏动画源码
jQuery+CSS3实现404背景游戏动画源码
42 22
|
2月前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
62 31
|
3月前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
121 58
|
1月前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
44 6
|
2月前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
77 7
|
2月前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
35 6
|
2月前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
76 5
|
2月前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
28 2
|
2月前
|
Web App开发 前端开发 iOS开发
CSS加载动画大全 126种
CSS加载动画大全是一个css Loaders加载动画特效汇总,一共包含126种加载动画效果,不同样式不同图案,简单实用,一览包含所有,会让你在等待的过程中,体验视觉盛宴,给用户不一般的加载体验,欢迎下载试试!代码适用浏览器:搜狗、360、FireFox(建议)、Chrome、Safari、Opera、傲游、世界之窗,是一款不错的的特效插件,希望大家喜欢!
33 2