css实现交融文字效果的项目实践

CSS是有魔法的,我们今天来实现一个CSS的动画效果,只需要几行代码就可以搞定。

第一步、我们要将一行文字从中间展开

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<title>Document</title>
    body{
        background: #000;
    }
    .container{
        margin-top: 50px;
        text-align: center;
        background-color: #000;
        filter: contrast(30);
    }
    .text{
        font-size: 100px;
        color: #fff;
        /* 第一步、如何从中间展开 */
        letter-spacing: 0px;
    }
<div class="container">
    <span class="text">hello world</span>
</div>

以上是基础代码结构,通过调整letter-spacing的值,我们可以控制他的展开与收起。值越小为负数时文字就可以挤在一起,越大文字间距就越大。

默认值为0时正常显示的效果

小于正常值的效果

我们可以为节点加上keyframes动画,此时letter-spacing属性转由keyframes控制可以达到自动展开文字的效果

1
2
3
4
5
6
7
8
9
10
11
12
13
.text{
  font-size: 100px;
  color: #fff;
  animation: showup 3s forwards;
}
@keyframes showup {
  from{
    letter-spacing: -50px;
  }
  to{
    letter-spacing: 10px;
  }
}

第二步、我们需要设置文字融合在一起的效果

先给文本节点设置filter blur文字变得模糊

学过ps的就会知道,当给图片加上较高的对比度的时候,就会导致黑的部分越黑,白的部分越白。我们给父节点加上filter,设置contrast(30),可以获得如下效果

这样就有了一些圆润的边缘,最后我们将对应的css属性交给keyframes控制,就可以达到最终的效果

1
2
3
4
5
6
7
8
9
10
11
12
@keyframes showup {
    from{
        letter-spacing: -50px;
                /* 新增 */
        filter: blur(10px);
    }
    to{
        letter-spacing: 10px;
        /* 新增 */
        filter: blur(2px);
    }
}

完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<title>Document</title>
    body{
        background: #000;
    }
    .container{
        margin-top: 50px;
        text-align: center;
        background-color: #000;
        filter: contrast(30);
    }
    .text{
        font-size: 100px;
        color: #fff;
        /* 第一步、如何从中间展开 */
        /* letter-spacing: 0px; */
        animation: showup 3s forwards;
    }
    @keyframes showup {
        from{
            letter-spacing: -50px;
            filter: blur(10px);
        }
        to{
            letter-spacing: 10px;
            filter: blur(2px);
        }
    }
<div class="container">
    <span class="text">hello world</span>
</div>

到此这篇关于css实现交融文字效果的项目实践的文章就介绍到这了,更多相关css交融文字效果内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章,希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/navsub/css/13937.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部