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

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

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


87e3fdf897424ccb85bca6e3171b6745_tplv-k3u1fbpfcp-zoom-1.gif


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


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


7d43984036324796bd403df807431574_tplv-k3u1fbpfcp-zoom-1.gif


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


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



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


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


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

先来看一个简单的例子:

ed258b76c37140578965a2defc9ff8cd_tplv-k3u1fbpfcp-zoom-1.gif

CodePen Demo -- filter mix between blur and contrast


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


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


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


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

22d9ed0567a6409d80c76f20c93f3eaf_tplv-k3u1fbpfcp-zoom-1.png

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



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


6a2b14278eda426c82261e38ec9ed087_tplv-k3u1fbpfcp-zoom-1.gif


CodePen Demo -- word animation | word filter


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


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


核心代码如下:

<div class="g-container">
  <div class="word">iPhone</div>
  <div class="word">13</div>
  <div class="word">Pro</div>
  <div class="word">强得很!</div>
</div>


@import url('https://fonts.googleapis.com/css2?family=Montserrat&display=swap');
$speed: 8s;
$wordCount: 4;
.g-container {
    position: relative;
    width: 100vw;
    height: 100vh;
    background: #000;
    font-family: 'Montserrat', sans-serif;
    color: #fff;
    font-size: 120px;
    filter: contrast(15);
}
.word {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: change $speed infinite ease-in-out;
    @for $i from 0 to $wordCount {
        &:nth-child(#{$i + 1}) {
            animation-delay: ($speed / ($wordCount + 1) * $i) - $speed;
        }
    }
}
@keyframes change {
    0%,
    5%,
    100% {
        filter: blur(0px);
        opacity: 1;
    }
    50%,
    80% {
        filter: blur(80px);
        opacity: 0;
    }
}


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


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

980c795c48d946cc8ec0cf2062b90b3a_tplv-k3u1fbpfcp-watermark.gif

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

da4551dbf7344b0dbaba147562f6734a_tplv-k3u1fbpfcp-watermark.gif


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


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


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


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

目录
相关文章
|
5月前
动态颤抖的眼睛效果404页面源码
动态颤抖的眼睛效果404页面源码, 源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面
35 1
动态颤抖的眼睛效果404页面源码
|
前端开发
前端学习笔记202305学习笔记第二十三天-区域文字和立体设置
前端学习笔记202305学习笔记第二十三天-区域文字和立体设置
48 0
|
7月前
|
索引
在微信小游戏制作工具中实现文字逐个出现的打字机效果
在微信小游戏制作工具中实现文字逐个出现的打字机效果
82 0
|
存储 JSON 前端开发
【红隼书签】自定义光影、自定义背景、亮度和主题功能
【红隼书签】是一款简洁的在线书签导航网站。
109 1
|
Python 容器
tkinter模块高级操作(二)—— 界面切换效果、立体阴影字效果及gif动图的实现
tkinter模块高级操作(二)—— 界面切换效果、立体阴影字效果及gif动图的实现
291 0
|
小程序 索引
如何实现文字逐个出现的打字机效果
今天分享一下如何在微信小游戏制作工具中实现文字逐个出现的打字机效果,这个小功能可以用于游戏中的文字对白的展示,如果你要做的是一个文字类游戏的话,那么肯定用的上。
163 0
|
前端开发 JavaScript
一起看跨年烟花(自定义背景+流行背景音乐+雪花)---- 系列
一起看跨年烟花(自定义背景+流行背景音乐+雪花)---- 系列
235 0
一起看跨年烟花(自定义背景+流行背景音乐+雪花)---- 系列
|
前端开发 JavaScript Serverless
移动端弹出阴影遮罩的几点问题和解决方法
在做移动端的立即购买页面时,点击底部固定栏立即购买按钮需要弹出一个阴影遮罩,在遮罩顶部有一个固定在底部的页面,所以总共是3层页面:最底层浏览页->阴影遮罩页->最上层的立即购买选择规格数量页;效果如下图:
232 0
移动端弹出阴影遮罩的几点问题和解决方法
|
JavaScript 开发者
jQuer y 特效实例_幽灵按钮2|学习笔记
快速学习 jQuery 特效实例_幽灵按钮2
267 0
jQuer y 特效实例_幽灵按钮2|学习笔记