LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

[点晴永久免费OA]原生手写一镜到底特效《龙年大吉》。

freeflydom
2024年1月27日 17:38 本文热度 682

上源码:

<div class="perspective-box">
      <div class="cover"></div>
      <div class="perspective-content pc1">
        <div class="sence-box sence-box1">
          <div class="sence-in">
            <div class="text-left text-box">掘金多多</div>
            <div class="text-right text-box">大展鸿图</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
          </div>
        </div>
        <div class="sence-box sence-box2">
          <div class="sence-in">
            <div class="text-left text-box">步步高升</div>
            <div class="text-right text-box">年年有鱼</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box3">
          <div class="sence-in">
            <div class="text-left text-box">心想事成</div>
            <div class="text-right text-box">万事如意</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box4">
          <div class="sence-in">
            <div class="text-left text-box">蒸蒸日上</div>
            <div class="text-right text-box">一帆风顺</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box5">
          <div class="sence-in">
            <div class="text-left text-box">自强不息</div>
            <div class="text-right text-box">恭喜发财</div>
            <div class="sence-block">龙年大吉</div>
            <div class="denglong-box"></div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
      </div>

      <div class="perspective-content pc2">
        <div class="sence-box sence-box1">
          <div class="sence-in">
            <div class="text-left text-box">掘金多多</div>
            <div class="text-right text-box">大展鸿图</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
          </div>
        </div>
        <div class="sence-box sence-box2">
          <div class="sence-in">
            <div class="text-left text-box">步步高升</div>
            <div class="text-right text-box">年年有鱼</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box3">
          <div class="sence-in">
            <div class="text-left text-box">心想事成</div>
            <div class="text-right text-box">万事如意</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box4">
          <div class="sence-in">
            <div class="text-left text-box">蒸蒸日上</div>
            <div class="text-right text-box">一帆风顺</div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="denglong-box"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
        <div class="sence-box sence-box5">
          <div class="sence-in">
            <div class="text-left text-box">自强不息</div>
            <div class="text-right text-box">恭喜发财</div>
            <div class="sence-block">龙年大吉</div>
            <div class="denglong-box"></div>
            <div class="long long-left"></div>
            <div class="long long-right"></div>
            <div class="long2 long2-left"></div>
            <div class="long2 long2-right"></div>
            <div class="xiangyun"></div>
          </div>
        </div>
      </div>
    </div>


     @font-face {
        font-family: "albb";
        font-weight: 400;
        src: url("http://at.alicdn.com/wf/webfont/UtqyOOTInYwh/j66d3Uavi7Io.woff2")
            format("woff2"),
          url("http://at.alicdn.com/wf/webfont/UtqyOOTInYwh/ElZddLrzcmO1.woff")
            format("woff");
        font-display: swap;
      }
      * {
        box-sizing: border-box;
        font-family: albb;
        border: none!important;
      }
      html,
      body {
        display: flex;
        justify-content: center;
        align-items: center;
        margin: 0;
        padding: 0;
        height: 100%;
        /* background: url('https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/4a8a979202e043c480960b25d385e7a5~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=798&h=998&s=33164&e=webp&b=9a010b') no-repeat center; */
        /* background: url('https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a6bdca2510534ecab6101a930f4f4d7c~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=437&h=800&s=426980&e=webp&f=125&b=c81212') no-repeat center; */
        background-size: cover;
        font-family: albb;
        background: linear-gradient(45deg, rgb(77, 3, 3), rgb(157, 1, 1));
      }

      .cover {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: url("https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f515124157f748968b3dcc84a38ad067~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=364&h=575&s=1117790&e=webp&f=100&b=e6e2bd")
          no-repeat;
        background-size: 100%;
      }
      .perspective-box {
        perspective: 800px;
        perspective-origin: center center;
        transform-style: preserve-3d;
        /* border: 4px solid green; */
        /* background: url("https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/4a8a979202e043c480960b25d385e7a5~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=798&h=998&s=33164&e=webp&b=9a010b") */
          /* no-repeat center; */
          /* background: url('./bg22.jpg') no-repeat; */
          background: linear-gradient(45deg, rgb(77, 3, 3), rgb(157, 1, 1));
        background-size: cover;
         border: 1px dashed yellow!important;
        /*
          position: absolute;
          left: 0;
          top:0;
          border: 1px solid red;
        */
        width: 1000px;
        height: 600px;
        overflow: hidden;
      }

      .perspective-content {
        /* perspective: 2000px; */
        transform-style: preserve-3d;
        position: absolute;
        left: 0;
        top: 0;
        /* border: 1px solid red; */
        width: 100%;
        height: 100%;
        /* animation: upup 5s linear infinite; */
      }

      .pc2 {
        transform: translateZ(-3000px) rotate(0deg);
      }

      .sence-box {
        position: absolute;
        left: 0;
        top: 0;
        /* margin-left: -100vw; */
        /* border: 1px solid green; */
        width: 100%;
        height: 100%;
        transform-style: preserve-3d;
      }

      .sence-in {
        transform-style: preserve-3d;
        border: 1px solid #fff;
        height: 500px;
      }

      .sence-in .text-box {
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        flex-direction: column;
        position: absolute;
        left: 0;
        top: 100px;
        /* border: 1px solid red; */
        width: 200px;
        height: 400px;
        background: url("https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/31b3bc1063274e28ba90adf7cb7edce8~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=386&h=901&s=7074&e=webp&a=1&b=db2721")
          no-repeat;
        background-size: 100% 100%;
        padding: 0 60px;
        font-size: 50px;
        color: #dbbb78;
      }

      .sence-in .text-right {
        left: auto;
        right: 0;
      }

      .pc1 {
        animation: pc1 20s linear infinite;
      }
      .pc2 {
        animation: pc2 20s linear infinite;
      }

      .pc2 .sence-box img {
        /* border-color: red; */
      }
      .sence-block {
        position: absolute;
        width: 200px;
        height: 200px;
        top: 200px;
        left: 400px;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 40px;
        background: url("https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/6b265e7d23f34e769ec9a5f952fee069~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1176&h=1176&s=49626&e=webp&a=1&b=d5502f")
          no-repeat;
        background-size: cover;
        font-size: 30px;
        color: #c4af47;
      }

      .long {
        position: absolute;
        left: -400px;
        bottom: 0;
        border: 1px solid #fff;
        width: 400px;
        height: 300px;
        background: url('https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/9705e283dc414d6484cf1c467a859ed4~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1200&h=570&s=115094&e=png&a=1&b=d90e00') no-repeat right bottom;
        background-size: contain;
        /* transform:translateZ(300px); */
      }

      .long-right{
        left: auto;
        right: -400px;
        transform: rotateY(180deg);
      }

      .long2 {
        position: absolute;
        left: 200px;
        bottom: 0;
        width: 150px;
        height: 150px;
        border: 1px solid yellow;
        background: url('https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/06b7e8f187a34109a134aa24b66f1d78~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=954&h=647&s=792959&e=png&a=1&b=e04736')no-repeat center;
        background-size: contain;
        transform: translateZ(600px);
      }

      .long2-right {
        left: auto;
        right: 200px;
      }

      .xiangyun{
        position: absolute;
        left: -400px;
        bottom: 0;
        width: 1600px;
        height: 600px;
        background: url('https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/aa5a2687d1244108afefd86b4ef5729a~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1157&h=369&s=62644&e=png&a=1&b=d60101') no-repeat center;
        background-size: contain;
        border: 1px solid yellow;
        transform: translateZ(-200px);
      }

      .hua {
        position: absolute;
        left: 120px;
        top: 130px;
        height: 50px;
        border: 1px solid #fff;
        width: 50px;
        background: url('./hua.png') no-repeat center;
        background-size: contain;
        /* animation: rot 5s infinite linear; */
      }

      .sence-box1 {
        transform: translateZ(-500px);
      }

      .sence-box2 {
        transform: translateZ(-1500px);
      }

      .sence-box3 {
        transform: translateZ(-2500px);
      }
      .sence-box4 {
        transform: translateZ(-3500px);
      }
      .sence-box5 {
        transform: translateZ(-4500px);
      }

      .denglong-box {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 300px;
        background: url("https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f4b556643a2e48289af3dad79ad29033~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=802&h=1373&s=57508&e=webp&a=1&b=d6502f")
            no-repeat 50px,
          url("https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/c2a79cfefa0d43d8b550f3675753b94c~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=809&h=1528&s=43006&e=webp&a=1&b=d14a30")
            no-repeat 150px,
          url("https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f4b556643a2e48289af3dad79ad29033~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=802&h=1373&s=57508&e=webp&a=1&b=d6502f")
            no-repeat 800px,
          url("https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/c2a79cfefa0d43d8b550f3675753b94c~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=809&h=1528&s=43006&e=webp&a=1&b=d14a30")
            no-repeat 720px;
        background-size: 120px, 100px;
        transform: translateZ(400px);
      }

      @keyframes pc1 {
        0% {
          transform: translateZ(0px);
          z-index: 99;
        }

        50% {
          transform: translateZ(6000px);
          z-index: 99;
        }
        50.1% {
          transform: translateZ(-6000px);
          /* opacity: 0.5; */
          z-index: 1;
        }
        60% {
          /* opacity: 1; */
        }
        100% {
          transform: translateZ(0px);
          z-index: 1;
        }
      }
      @keyframes pc2 {
        0% {
          transform: translateZ(-6000px);
          z-index: 1;
          /* opacity: 0.5; */
        }
        10% {
          /* opacity: 1; */
        }
        50% {
          z-index: 1;
        }
        50.1% {
          z-index: 99;
        }
        100% {
          transform: translateZ(6000px);
          z-index: 99;
        }
      }

      @keyframes rot {
        0% {
          transform: rotate(0deg);
        }
        100% {
          transform: rotate(360deg);
        }
      }

整体实现思路介绍

整个案例使用到CSS3 和 HTML技术, 案例的核心知识点 使用到了 CSS3 中的透视 、3D变换、 动画 、无缝滚动等技术要点, 下面我会逐一进行介绍

  • 知识点1: 一镜到底特效的 案例的整体布局、设计、及动画思路

  • 知识点2:CSS3中的3D坐标系

  • 知识点3:CSS3中的3D变换及案例应用

  • 知识点4:CSS3中的3D透视及案例应用

  • 知识点5:CSS3中的 透视及3d变换的异同点

  • 知识点6:CSS3中的 动画及案例应用

1、一镜到底特效 的整体布局、设计、及动画思路

如下图所示,一镜到底的案例特效 最核心的就是要 构成一套 在3D 空间中, 有多个平行的场景, 然后以摄像机的视角  从前往后 移动,在场景中穿梭, 依次穿过每一个场景的页面即可,自己闭上眼睛来体会一下吧。

对应到本案例中效果就是这样啦:

当然有朋友会说看上图,感觉不到明显的3D 立体效果, 那再来看看下面这个图吧;

上面这张图就是 基于人眼 看不同距离的物体呈现出的结果, 也就是透视效果, 透视效果最核心的特点就是近大远小;而影响看到透视物体大小的一个参数就是消失点距离, 比如消失点越近,最远处的物体会越小, 近大远小的效果越明显, 自己闭上眼睛来体会一下吧。

对应到本案例中效果就是这样啦:

注意:本案例中 的主要功能是动效, 所以在页面框架布局上,大多使用的都是定位布局, 布局中的基础概念 ‘子绝父相’ 就不用我多说了吧

上述框架对应的HTML源码如下, 其中.sence-in 内部的子元素是素材,可以先忽略:

<div class="sence-box sence-box1">

  <div class="sence-in">

    <div class="text-left text-box">掘金多多</div>

    <div class="text-right text-box">大展鸿图</div>

    <div class="long long-left"></div>

    <div class="long long-right"></div>

    <div class="denglong-box"></div>

    <div class="long2 long2-left"></div>

    <div class="long2 long2-right"></div>

  </div>

</div>

<div class="sence-box sence-box2">

  <div class="sence-in">

    <div class="text-left text-box">步步高升</div>

    <div class="text-right text-box">年年有鱼</div>

    <div class="long long-left"></div>

    <div class="long long-right"></div>

    <div class="denglong-box"></div>

    <div class="long2 long2-left"></div>

    <div class="long2 long2-right"></div>

    <div class="xiangyun"></div>

  </div>

</div>

<div class="sence-box sence-box3">

  <div class="sence-in">

    <div class="text-left text-box">心想事成</div>

    <div class="text-right text-box">万事如意</div>

    <div class="long long-left"></div>

    <div class="long long-right"></div>

    <div class="denglong-box"></div>

    <div class="long2 long2-left"></div>

    <div class="long2 long2-right"></div>

    <div class="xiangyun"></div>

  </div>

</div>

<div class="sence-box sence-box4">

  <div class="sence-in">

    <div class="text-left text-box">蒸蒸日上</div>

    <div class="text-right text-box">一帆风顺</div>

    <div class="long long-left"></div>

    <div class="long long-right"></div>

    <div class="denglong-box"></div>

    <div class="long2 long2-left"></div>

    <div class="long2 long2-right"></div>

    <div class="xiangyun"></div>

  </div>

</div>

<div class="sence-box sence-box5">

  <div class="sence-in">

    <div class="text-left text-box">自强不息</div>

    <div class="text-right text-box">恭喜发财</div>

    <div class="sence-block">龙年大吉</div>

    <div class="denglong-box"></div>

    <div class="long long-left"></div>

    <div class="long long-right"></div>

    <div class="long2 long2-left"></div>

    <div class="long2 long2-right"></div>

    <div class="xiangyun"></div>

  </div>

</div>

知识点一: CSS3中的坐标系

CSS3中的坐标系,是一切3D 效果的基石, 务必熟练掌握 , 如下图所示:

  • x轴坐标:左边负,右边正

  • y轴坐标:上边负,下边正

  • z轴坐标:里面负,外面正

  • 注意: 坐标系的原点在 浏览器的左上角

知识点二: 透视(perspective)

perspective属性定义了观察者和Z=0平面之间的距离,从而为3D转换元素创建透视效果。上面也说了, 透视的效果就是 近大远小, 上面的截图中也能看到 。这个属性是用来创建3D转换效果的必要属性,因为当我们进行旋转或其他3D转换时,如果透视效果设置得不正确,元素可能会显得很奇怪或不正常。 透视的语法如下:

在CSS中,我们可以通过在父元素上设置perspective属性来控制子元素的3D效果。例如:

.container {  

  perspective: 1000px;  

}


在这个例子中,我们为.container元素设置了perspective属性,值为1000px。这意味着任何在这个元素内部的3D转换都会基于这个视距进行透视。

知识点三:3D 变换的核心属性: transform-style

transform-style属性决定了是否保留元素的三维空间布局。当设置为preserve-3d时,它会保留元素内部的三维空间,即使这个元素本身没有进行任何3D转换。这使得子元素可以相对于父元素进行旋转或其他3D转换,而不会影响其他元素。在我们的案例截图中 也能看出在父元素设置了 transform-style: preserve-3d;属性后, 各个场景在 Z轴方向上,已经有了前后距离上的差异了。  需要注意的点就是, transform-style属性一定要设置给发生3D变换元素的父元素

例如:

 /* 透视属性加给了 最外层的元素, 保证所有子元素的透视效果是一致的,协调的*/

.perspective-box {  

  transform-style: preserve-3d;  

}


在这个例子中,我们为.perspective-box元素设置了transform-style属性为preserve-3d,这意味着任何在这个元素内部的3D转换都会保留其三维空间布局。

  • 小技巧:如果你希望自己做的3D场景,立体效果很真实的话, 可以尽量多的给不同的元素,设置在Z轴方向上 设置不同的偏移量, 这样的效果是 摄像机在穿梭的过程中,每一段距离都能看到不同的风景, 层次感会很强, 当然也不要太疯狂, 不然场景会变得混乱哦

知识点四、perspective和transform-style的差异和注意点(炒鸡重要!)

  • perspective属性定义了观察者和Z=0平面之间的距离,通俗的说 就是屏幕 到消失点的距离,从而影响3D元素的透视效果, 而transform-style属性决定了是否保留元素的三维空间布局

  • 当我们只使用perspective属性时,只有被明确设置为3D转换的元素才会显示透视效果。而当我们使用transform-style: preserve-3d时,即使元素本身没有进行任何3D转换,其子元素也可以进行3D转换并保留三维空间布局。

注意:perspective属性,只能带来近大远小的透视视觉效果,并不能构成真正的3D空间布局。真正的3D布局必须依赖于transform-style: preserve-3d属性来实现

知识点五、animation动画的定义和使用

CSS动画是一种使元素从一种样式逐渐改变为另一种样式的方法。这个过程是通过关键帧(keyframes)来定义的,关键帧定义了动画过程中的不同状态。 在一镜到底的案例中, 整个场景的前后移动,用的就是动画属性。

动画的使用分为两步, 具体使用方式如下:

  • 1.使用@keyframes 来定义动画

  • 2.使用animation属性来调用动画,


@keyframes rotate {  

  from { transform: rotateX(0deg); }  

  to { transform: rotateX(360deg); }  

}


在这个例子中,我们定义了一个名为“rotate”的关键帧动画,使元素从X轴的0度旋转到360度。然后,我们可以通过将这个动画应用到HTML元素上来使用它:

.perspective-content {  

  animation: rotate 5s infinite linear;  

}


在这个例子中,我们将“rotate”动画应用到.cube元素上,设置动画时间为5秒,无限循环,并且线性过渡;

在一镜到底的案例中, 我们定义的动画如下:


      @keyframes perspective-content {

      

        0% {

          transform: translateZ(0px);

        }


        50% {

          transform: translateZ(6000px);

        }

        

        50.1% {

          transform: translateZ(-6000px);

        }

        

        100% {

          transform: translateZ(0px);

        }

      }


上午动画 其实做了一个无线循环轮播的逻辑, 就是当 在Z轴方向上 从 0 移动到 6000距离以后, 在重置到-6000px, 这样就可以在从-6000继续向前移动, 移动到 0 ,达到一个循环, 再开始下一次的循环;

  • 小技巧: 你可以把动画 单独加给每个场景(可能有10多个子元素, 你的重复写10多遍,会很麻烦的),也可以把动画加给公共的父元素,父元素会带着里面的子元素一起动, 这样只用写一次就行哦。


作者:IT大春哥
链接:https://juejin.cn/post/7325739662033879090
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。




该文章在 2024/1/27 17:39:58 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved