CSS 3D
在正常的视觉效果中,离的越近的通常会看的越清晰,而离的较远则相对没那么清晰~
可以利用清晰与模糊两种状态来构建视差效果。像是这样:
2021-08-30-07-14-00-281741.gif
而在 CSS 中,可以利用模糊滤镜 filter: blur()transform-style: preserve-3d 来实现它们。

实现一个文字的 3D 变换

首先,需要实现一个文字的 3D 变换,这个比较简单。主要是借助 transform-style: preserve-3dperspective,以及让文字绕 Y 轴进行旋转即可。
简单的代码如下:

  1. <p>CSS3DEFFECT</p>
  1. body {
  2. perspective: 160vmin;
  3. }
  4. p {
  5. font-size: 24vmin;
  6. transform-style: preserve-3d;
  7. animation: rotate 10s infinite ease-in-out;
  8. }
  9. @keyframes rotate {
  10. 0% {
  11. transform: rotateY(-45deg);
  12. }
  13. 50% {
  14. transform: rotateY(45deg);
  15. }
  16. 100% {
  17. transform: rotateY(-45deg);
  18. }
  19. }

就可以得到这样一个 3D 文字效果:
2021-08-30-07-14-00-834744.gif

实现文字的模糊

这个效果已经有了初步的 3D 效果,但是仅仅是这样,会觉得少了些什么。接下来就需要补充一下模糊的效果,让距离近的文字清晰,远离的文字模糊。
但这样就需要对每个文字进行精细化处理,上面的 HTML 结构无法做到对每一个文字的单独处理,简单改造一下结构:

  1. <p>
  2. <span>C</span>
  3. <span>S</span>
  4. <span>S</span>
  5. <span>3</span>
  6. <span>D</span>
  7. <span>E</span>
  8. <span>F</span>
  9. <span>F</span>
  10. <span>E</span>
  11. <span>C</span>
  12. <span>T</span>
  13. </p>

完整的代码大概是这样:

  1. @import url('https://fonts.googleapis.com/css2?family=Lobster&display=swap');
  2. $count: 12;
  3. body, html {
  4. font-family: 'Lobster', cursive;
  5. perspective: 160vmin;
  6. overflow: hidden;
  7. }
  8. p {
  9. margin: auto;
  10. font-size: 24vmin;
  11. transform-style: preserve-3d;
  12. animation: rotate 10s infinite ease-in-out;
  13. span {
  14. text-shadow:
  15. 1px 1px 0 rgba(0, 0, 0, .9),
  16. 2px 2px 0 rgba(0, 0, 0, .7),
  17. 3px 3px 0 rgba(0, 0, 0, .5),
  18. 4px 4px 0 rgba(0, 0, 0, .3),
  19. 5px 5px 0 rgba(0, 0, 0, .1);
  20. &:nth-child(-n+5) {
  21. animation-delay: -5s;
  22. }
  23. }
  24. }
  25. @for $i from 1 to 7 {
  26. span:nth-child(#{$i}),
  27. span:nth-last-child(#{$i}) {
  28. animation: filterBlur-#{$i} 10s infinite ease-in-out;
  29. }
  30. @keyframes filterBlur-#{$i} {
  31. 0% {
  32. filter: blur(0px) contrast(5);
  33. }
  34. 50% {
  35. filter: blur(#{7 - $i}px) contrast(1);
  36. }
  37. 100% {
  38. filter: blur(0px) contrast(5);
  39. }
  40. }
  41. }
  42. @keyframes rotate {
  43. 0% {
  44. transform: rotateY(-45deg);
  45. }
  46. 50% {
  47. transform: rotateY(45deg);
  48. }
  49. 100% {
  50. transform: rotateY(-45deg);
  51. }
  52. }

简单解析下,这里有几个小技巧,仔细观察需要的效果:

  1. 第一个字符和最后一个字符在旋转的最左效果和最右效果下分别会离最近和最远,它们的效果其实应该是一致的,所以第一个字符和最后一个字符应该统一处理,依次类推,第二个字符和倒数第二字符统一处理,这里可以借助 SASS 利用 :nth-child:nth-last-child 高效编写 CSS 代码
  2. 每次有一半是清晰的,一半的是模糊的,需要区分对待,利用 animation-delay 让一半的动画延迟一半进行
  3. 可以再配合 text-shadow 让文字更立体点

这样,可以最终得到如下效果:
2021-08-30-07-14-02-962707.gif