巧用滤镜实现高级感拉满的文字快闪切换效果

开发 前端
今天并非是想用 CSS 实现上述的的效果。在尝试的过程中,我发现了另外一类能够使用 CSS 非常轻松实现文字快闪动画,运用了blur() 滤镜和 contrast() 滤镜产生的融合效果。

[[434029]]

今天偶然看到这样一类很有意思的文字快闪动画:

图片

这类文字快闪切换效果运用得当的话,能比较好的吸引用户的眼球。

当然,今天并非是想用 CSS 实现上述的的效果。在尝试的过程中,我发现了另外一类能够使用 CSS 非常轻松实现文字快闪动画,运用了blur() 滤镜和 contrast() 滤镜产生的融合效果,类似于这样:

图片

这个技巧也在多篇文章就提及,本文再简述下。

blur 滤镜混合 contrast 滤镜产生融合效果

本文的重点,模糊滤镜叠加对比度滤镜产生的融合效果。单独将两个滤镜拿出来,它们的作用分别是:

  1. filter: blur():给图像设置高斯模糊效果。
  2. filter: contrast():调整图像的对比度。

但是,当他们“合体”的时候,产生了奇妙的融合现象。

先来看一个简单的例子:

图片

CodePen Demo -- filter mix between blur and contrast[1]

仔细看两圆相交的过程,在边与边接触的时候,会产生一种边界融合的效果,通过对比度滤镜把高斯模糊的模糊边缘给干掉,利用高斯模糊实现融合效果。

上述效果的实现基于两点:

  1. 图形是在被设置了 filter: contrast() 的画布背景上进行动画的
  2. 进行动画的图形被设置了 filter: blur()( 进行动画的图形的父元素需要是被设置了 filter: contrast() 的画布)

当然,背景色不一定是白色,我们稍稍修改上面的Demo,简单的示意图如下:

使用 blur/contrast 滤镜实现文字的切换

利用上述的技巧,我们可以实现文字的融合效果,像是这样:

这样,利用这个技巧,我们可以巧妙构思一下动画:

  1. 多个文字按顺序依次出现(利用 animation-delay 进行控制处理)
  2. 做到上一个文字消失的同时,下一个文字出现
  3. 叠加上上述的滤镜即可

核心代码如下:

  1. <div class="g-container"
  2.   <div class="word">iPhone</div> 
  3.   <div class="word">13</div> 
  4.   <div class="word">Pro</div> 
  5.   <div class="word">强得很!</div> 
  6. </div> 
  1. @import url('https://fonts.googleapis.com/css2?family=Montserrat&display=swap'); 
  2.  
  3. $speed: 8s; 
  4. $wordCount: 4; 
  5.  
  6. .g-container { 
  7.     position: relative
  8.     width: 100vw; 
  9.     height: 100vh; 
  10.     background: #000; 
  11.     font-family: 'Montserrat', sans-serif; 
  12.     color: #fff; 
  13.     font-size: 120px; 
  14.     filter: contrast(15); 
  15. .word { 
  16.     position: absolute
  17.     top: 50%; 
  18.     left: 50%; 
  19.     transform: translate(-50%, -50%); 
  20.     animation: change $speed infinite ease-in-out
  21.  
  22.     @for $i from 0 to $wordCount { 
  23.         &:nth-child(#{$i + 1}) { 
  24.             animation-delay: ($speed / ($wordCount + 1) * $i) - $speed; 
  25.         } 
  26.     } 
  27.  
  28. @keyframes change { 
  29.     0%, 
  30.     5%, 
  31.     100% { 
  32.         filter: blur(0px); 
  33.         opacity: 1; 
  34.     } 
  35.     50%, 
  36.     80% { 
  37.         filter: blur(80px); 
  38.         opacity: 0; 
  39.     } 

整段代码,核心需要关注 @keyframes change 这个动画,我们通过顺序给文字添加上这个动画(也就是利用 animation-delay 顺序添加了延时)实现了上一个文字消失的过程下一个文字显示的效果。

上述的 .g-container 添加了这样一句代码 -- filter: contrast(15),去掉这句的话,效果是这样的:

加上这句关键的代码 -- filter: contrast(15),整个效果就如一开始的题图所示:

CodePen Demo -- 纯 CSS 实现文字融合快闪切换效果[2]

整个动画的两个核心关键点:

  1. 利用了 blur 滤镜混合 contrast 滤镜产生融合效果
  2. 在上一个文字消失的过程中,显示下一个文字,以此产生当前展示文字是由上个文字演变而来的效果

由此,你可以通过 HTML 控制文字的条数、改变 SASS 变量中表示动画时长的 $speed 和文字条数的 $wordCount 以及最终 @keyframes change 里面的参数,不断去调整优化你要的效果。演变出各种文字快闪效果。

最后

好了,本文到此结束,希望本文对你有所帮助 :)

参考资料

[1]CodePen Demo -- filter mix between blur and contrast:

https://codepen.io/Chokcoco/pen/QqWBqV

[2]CodePen Demo -- 纯 CSS 实现文字融合快闪切换效果:

https://codepen.io/Chokcoco/pen/xxLjdmz

 

责任编辑:姜华 来源: iCSS前端趣闻
相关推荐

2021-11-15 07:45:06

CSS 技巧背景光动画

2023-05-26 07:08:05

CSS模糊实现文字

2021-08-30 06:20:39

CSS 技巧3D 效果

2022-01-07 07:35:28

CSS 技巧磨砂玻璃

2010-09-07 14:53:45

Chroma属性CSS

2022-03-31 07:46:17

CSS动画技巧

2010-09-13 14:09:35

CSS文字

2023-01-29 08:00:00

Instagram滤镜图片编辑

2018-04-16 14:39:10

Vue轮播切换

2021-09-28 06:00:01

BackgroundCSS技巧

2023-05-18 09:25:20

background花式文字效果

2024-01-12 17:06:50

字节面试题目

2011-05-31 09:23:58

Android Activity

2021-12-06 15:10:01

鸿蒙HarmonyOS应用

2021-09-28 08:26:06

CSS 技巧文字镂空波浪

2024-03-12 09:21:04

WindowsAI

2009-07-31 17:21:28

linux cd命令linux cd命令详Pushd

2009-04-03 13:22:44

2018-08-03 10:39:13

快闪
点赞
收藏

51CTO技术栈公众号