• 技术文章 >web前端 >css教程

    巧用 filter 和 transform-style 属性创建视觉 3D 特效

    青灯夜游青灯夜游2021-11-02 19:21:18转载83
    本文将介绍巧用模糊实现视觉 3D 效果的技巧,看看利用filter 和 transform-style 属性怎么实现视觉 3D 特效,希望对大家有所帮助!

    我们都知道,在正常的视觉效果中,离我们越近的通常我们会看的越清晰,而离我们较远则相对没那么清晰~

    我们可以利用清晰模糊两种状态来构建视差效果。像是这样:

    1-1.gif

    而在 CSS 中,我们可以利用模糊滤镜 filter: blur()transform-style: preserve-3d 来实现它们。

    实现一个文字的 3D 变换

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

    简单的代码如下:

    <p>CSS3DEFFECT</p>
    body {
        perspective: 160vmin;
    }
    
    p {
        font-size: 24vmin;
        transform-style: preserve-3d;
        animation: rotate 10s infinite ease-in-out;
    }
    
    @keyframes rotate {
        0% {
            transform: rotateY(-45deg);
        }
        50% {
            transform: rotateY(45deg);
        }
        100% {
            transform: rotateY(-45deg);
        }
    }

    我们就可以得到这样一个 3D 文字效果:

    2.gif

    实现文字的模糊

    这个效果已经有了初步的 3D 效果,但是仅仅是这样,会觉得少了些什么。接下来我们就需要补充一下模糊的效果,让距离我们近的文字清晰,远离我们的文字模糊。

    但这样就需要对每个文字进行精细化处理,上面的 HTML 结构无法做到对每一个文字的单独处理,我们简单改造一下结构:

    <p>
        <span>C</span>
        <span>S</span>
        <span>S</span>
        <span>3</span>
        <span>D</span>
        <span>E</span>
        <span>F</span>
        <span>F</span>
        <span>E</span>
        <span>C</span>
        <span>T</span>
    </p>

    完整的代码大概是这样:

    @import url('https://fonts.googleapis.com/css2?family=Lobster&display=swap');
    
    $count: 12;
    
    body, html {
        font-family: 'Lobster', cursive;
        perspective: 160vmin;
        overflow: hidden;
    }
    
    p {
        margin: auto;
        font-size: 24vmin;
        transform-style: preserve-3d;
        animation: rotate 10s infinite ease-in-out;
        
        span {
            text-shadow: 
                1px 1px 0 rgba(0, 0, 0, .9),
                2px 2px 0 rgba(0, 0, 0, .7),
                3px 3px 0 rgba(0, 0, 0, .5),
                4px 4px 0 rgba(0, 0, 0, .3),
                5px 5px 0 rgba(0, 0, 0, .1);
            
            &:nth-child(-n+5) { 
                animation-delay: -5s; 
            }
        }
    }
    
    @for $i from 1 to 7 {
        span:nth-child(#{$i}), 
        span:nth-last-child(#{$i}) {
            animation: filterBlur-#{$i} 10s infinite ease-in-out;
        }
    
        @keyframes filterBlur-#{$i} {
            0% {
                filter: blur(0px) contrast(5);
            }
            50% {
                filter: blur(#{7 - $i}px) contrast(1);
            }
            100% {
                filter: blur(0px) contrast(5);
            }
        }
    }
    @keyframes rotate {
        0% {
            transform: rotateY(-45deg);
        }
        50% {
            transform: rotateY(45deg);
        }
        100% {
            transform: rotateY(-45deg);
        }
    }

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

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

    这样,我们可以最终得到如下效果:

    3-1.gif

    完整的代码,你可以戳这里 -- CSS 灵感 -- 利用 filter:blur 增强文字的 3D 效果

    https://csscoco.com/inspiration/#/./filter/use-filter-blur-enhance-text-3d-effect

    使用模糊构建落叶效果

    合理运用模糊,是能在没有 transform-style: preserve-3dperspective 的加持下,也能构建出不错的 3D 效果。

    譬如下面这个落叶效果,就是利用模糊以及简单的层级关系,让整个画面看上去非常的真实:

    <h2>Falling Leaves</h2>
    <section>
      <div class="leaf">
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
        <div><img src="落叶图片.png" /></div>
      </div>
      <div class="leaf leaf2">
        // 重复第二组
      </div>
      <div class="leaf leaf3">
        // 重复第三组
      </div>
    </section>
    .leaf {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
    }
    .leaf img {
      width: 75px;
      height: 75px;
    }
    .leaf div:nth-child(1) {
      left: 20%;
      animation: fall 22s linear infinite;
      animation-delay: -2s;
    }
    .leaf div:nth-child(2) {
      left: 70%;
      animation: fall 18s linear infinite;
      animation-delay: -4s;
    }
    .leaf div:nth-child(3) {
      left: 10%;
      animation: fall 21s linear infinite;
      animation-delay: -7s;
    }
    .leaf div:nth-child(4) {
      left: 50%;
      animation: fall 24s linear infinite;
      animation-delay: -5s;
    }
    .leaf div:nth-child(5) {
      left: 85%;
      animation: fall 19s linear infinite;
      animation-delay: -5s;
    }
    .leaf div:nth-child(6) {
      left: 15%;
      animation: fall 23s linear infinite;
      animation-delay: -10s;
    }
    .leaf div:nth-child(7) {
      left: 90%;
      animation: fall 20s linear infinite;
      animation-delay: -4s;
    }
    .leaf2 {
      transform: scale(1.6) translate(5%, -5%) rotate(15deg);
      filter: blur(1px);
      z-index: 10;
    }
    .leaf3 {
      filter: blur(2px);
      transform: scale(0.8) translate(-5%, 10%) rotate(170deg);
    }
    @keyframes fall {
      0% {
        top: -30%;
        transform: translateX(20px) rotate(0deg);
      }
      20% {
        transform: translateX(-20px) rotate(45deg);
      }
      40% {
        transform: translateX(20px) rotate(90deg);
      }
      60% {
        transform: translateX(-20px) rotate(135deg);
      }
      80% {
        transform: translateX(20px) rotate(180deg);
      }
      100% {
        top: 150%;
        transform: translateX(-20px) rotate(225deg);
      }
    }

    4-1.gif

    主要就是通过清晰模糊两种状态的对比,速度的差异,来构建视差效果。

    CodePen Demo -- Falling leaves

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

    最后

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

    更多编程相关知识,请访问:编程视频!!

    以上就是巧用 filter 和 transform-style 属性创建视觉 3D 特效的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:segmentfault,如有侵犯,请联系admin@php.cn删除
    上一篇:外部css样式表有什么用 下一篇:纯CSS创建各类进度条的 N 种方式(总结分享)
    大前端线上培训班

    相关文章推荐

    • 巧用css filter的drop-shadow()函数创建线条光影效果• 10+个让你的项目大放异彩的CSS loading加载特效,快来收藏吧!!• CSS+JS实现爱心点赞按钮(代码示例)• normalize和css reset分别是什么文件?又有什么区别?• 浅析Scss基础语法和导入SASS文件的方法

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网