今天偶然看到这样一类很有意思的巧用切换文字快闪动画: 这类文字快闪切换效果运用得当的话,能比较好的滤镜吸引用户的眼球。 当然,实现今天并非是高级感拉想用 CSS 实现上述的的效果。在尝试的文字过程中,我发现了另外一类能够使用 CSS 非常轻松实现文字快闪动画,快闪运用了blur() 滤镜和 contrast() 滤镜产生的效果融合效果,类似于这样: 这个技巧也在多篇文章就提及,巧用切换本文再简述下。滤镜 本文的实现重点,模糊滤镜叠加对比度滤镜产生的高级感拉融合效果。单独将两个滤镜拿出来,文字它们的快闪作用分别是: 但是巧用切换,当他们“合体”的时候,产生了奇妙的融合现象。站群服务器 先来看一个简单的例子: CodePen Demo -- filter mix between blur and contrast[1] 仔细看两圆相交的过程,在边与边接触的时候,会产生一种边界融合的效果,通过对比度滤镜把高斯模糊的模糊边缘给干掉,利用高斯模糊实现融合效果。 上述效果的实现基于两点: 当然,背景色不一定是白色,我们稍稍修改上面的Demo,简单的示意图如下: 使用 blur/contrast 滤镜实现文字的切换 利用上述的技巧,我们可以实现文字的融合效果,像是这样: 这样,利用这个技巧,高防服务器我们可以巧妙构思一下动画: 核心代码如下: 整段代码,核心需要关注 @keyframes change 这个动画,我们通过顺序给文字添加上这个动画(也就是利用 animation-delay 顺序添加了延时)实现了上一个文字消失的过程下一个文字显示的效果。 上述的 .g-container 添加了这样一句代码 -- filter: contrast(15),去掉这句的话,效果是这样的: 加上这句关键的代码 -- filter: contrast(15),整个效果就如一开始的题图所示: CodePen Demo -- 纯 CSS 实现文字融合快闪切换效果[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/xxLjdmzblur 滤镜混合 contrast 滤镜产生融合效果
最后
参考资料
上一篇
下一篇