当前位置:   article > 正文

CSS @keyframes 动画:颜色变化、背景旋转与放大缩小_css 颜色变化动态

css 颜色变化动态

在CSS中,@keyframes 是一个强大的工具,它允许我们创建复杂的动画效果。今天,我们将一起探索如何使用 @keyframes 来实现颜色变化、背景旋转以及放大缩小的动画效果。

动画会在 2 秒内循环播放,并在不同的时间点改变盒子的背景颜色和变换(旋转和缩放)。

  • 在 0% 的时间点,盒子的背景颜色是绿色(#4CAF50),没有进行旋转和缩放。
  • 在 25% 的时间点,盒子的背景颜色变为红色(#F44336),同时旋转了 90 度并放大了 10%。
  • 在 50% 的时间点,盒子的背景颜色变为绿色(#0F9D58),旋转了 180 度并回到了初始大小。
  • 在 75% 的时间点,盒子的背景颜色变为蓝色(#00BCD4),旋转了 270 度并再次放大了 10%。
  • 在 100% 的时间点(也就是动画结束时),盒子的背景颜色回到了初始的绿色(#4CAF50),旋转了 360 度(即回到初始位置)并回到了初始大小。

 

一、HTML 结构

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>使用 @keyframes 创建动画</title>
  7. <style>
  8. /* CSS 样式和关键帧定义将放在这里 */
  9. </style>
  10. </head>
  11. <body>
  12. <div class="animated-box"></div>
  13. </body>
  14. </html>

二、CSS 样式与 @keyframes 动画

  1. <style>
  2. .animated-box {
  3. width: 100px;
  4. height: 100px;
  5. background-color: #4CAF50;
  6. border-radius: 50%; /* 圆形盒子 */
  7. margin: 50px auto; /* 居中显示 */
  8. animation: colorRotateScale 2s infinite linear; /* 应用动画 */
  9. }
  10. /* 定义关键帧动画 */
  11. @keyframes colorRotateScale {
  12. 0% {
  13. background-color: #4CAF50; /* 初始颜色 */
  14. transform: rotate(0deg) scale(1); /* 初始旋转角度和大小 */
  15. }
  16. 25% {
  17. background-color: #F44336; /* 颜色变化 */
  18. transform: rotate(90deg) scale(1.1); /* 旋转90度并放大 */
  19. }
  20. 50% {
  21. background-color: #0F9D58; /* 颜色变化 */
  22. transform: rotate(180deg) scale(1); /* 旋转180度并回到初始大小 */
  23. }
  24. 75% {
  25. background-color: #00BCD4; /* 颜色变化 */
  26. transform: rotate(270deg) scale(1.1); /* 旋转270度并放大 */
  27. }
  28. 100% {
  29. background-color: #4CAF50; /* 回到初始颜色 */
  30. transform: rotate(360deg) scale(1); /* 旋转360度并回到初始大小 */
  31. }
  32. }
  33. </style>

在这个CSS样式中,我们定义了一个名为 colorRotateScale 的 @keyframes 动画。这个动画会在 2 秒内完成一个循环,并且会无限次地重复(infinite)。我们使用 linear 动画缓动函数,确保动画在整个周期内的速度是均匀的。

动画的效果包括:

  • 颜色变化:从绿色(#4CAF50)到红色(#F44336),再到绿色(#0F9D58),最后到蓝色(#00BCD4),并最终回到绿色(#4CAF50)。
  • 背景旋转:从 0 度开始,每过 25% 的时间,就旋转 90 度,直到完成 360 度的旋转。
  • 放大缩小:在动画过程中,盒子会在旋转 90 度和 270 度时稍微放大(1.1 倍),而在其他时间点则保持原始大小。

完整例程

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>Keyframe Animation Example</title>
  7. <style>
  8. .animated-box {
  9. width: 100px;
  10. height: 100px;
  11. background-color: #4CAF50;
  12. border-radius: 50%; /* 圆形盒子 */
  13. margin: 50px auto; /* 居中显示 */
  14. animation: colorRotateScale 2s infinite; /* 应用动画 */
  15. }
  16. /* 定义关键帧动画 */
  17. @keyframes colorRotateScale {
  18. 0% {
  19. background-color: #4CAF50; /* 初始颜色 */
  20. transform: rotate(0deg) scale(1); /* 初始旋转角度和大小 */
  21. }
  22. 25% {
  23. background-color: #F44336; /* 颜色变化 */
  24. transform: rotate(90deg) scale(1.1); /* 旋转90度并放大 */
  25. }
  26. 50% {
  27. background-color: #0F9D58; /* 颜色变化 */
  28. transform: rotate(180deg) scale(1); /* 旋转180度并回到初始大小 */
  29. }
  30. 75% {
  31. background-color: #00BCD4; /* 颜色变化 */
  32. transform: rotate(270deg) scale(1.1); /* 旋转270度并放大 */
  33. }
  34. 100% {
  35. background-color: #4CAF50; /* 回到初始颜色 */
  36. transform: rotate(360deg) scale(1); /* 旋转360度并回到初始大小 */
  37. }
  38. }
  39. </style>
  40. </head>
  41. <body>
  42. <div class="animated-box"></div>
  43. </body>
  44. </html>

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号