Heim  >  Artikel  >  Web-Frontend  >  Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

青灯夜游
青灯夜游nach vorne
2021-11-02 19:21:182124Durchsuche

In diesem Artikel werden die Techniken zur Verwendung von Unschärfe zum Erzielen visueller 3D-Effekte vorgestellt und erläutert, wie Filter- und Transformationsstilattribute verwendet werden, um visuelle 3D-Effekte zu erzielen.

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

Wir alle wissen, dass wir bei normalen visuellen Effekten normalerweise umso klarer sehen, je näher wir uns sind, während es relativ weniger klar ist, je weiter wir von uns entfernt sind ~

Wir können Klar und Unschärfe verwenden zwei Zustände, um einen Parallaxeneffekt zu erzeugen. So:

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

Und in CSS können wir die Unschärfefilter filter: Blur() und transform-style: Preserve-3d verwenden, um sie zu implementieren. 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 文字效果:

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

实现文字的模糊

这个效果已经有了初步的 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(&#39;https://fonts.googleapis.com/css2?family=Lobster&display=swap&#39;);

$count: 12;

body, html {
    font-family: &#39;Lobster&#39;, 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 让文字更立体点

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

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen

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

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

使用模糊构建落叶效果

合理运用模糊,是能在没有 transform-style: preserve-3dperspective

Implementieren Sie die 3D-Transformation eines Textes

Zuerst müssen wir die 3D-Transformation eines Textes implementieren, was relativ einfach ist. Hauptsächlich durch die Verwendung von transform-style: preserve-3d und perspective und durch Drehen des Textes um die Y-Achse.

Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugenDer einfache Code lautet wie folgt:

<h2>Falling Leaves</h2>
<section>
  <div class="leaf">
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></div>
    <div><img  src="落叶图片.png" / alt="Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen" ></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);
  }
}

Wir können einen solchen 3D-Texteffekt erzielen: Nutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugenText unscharf machen

Dieser Effekt hat bereits einen vorläufigen 3D-Effekt, aber schon auf diese Weise werden Sie das Gefühl haben, dass etwas fehlt. Als nächstes müssen wir einen Unschärfeeffekt hinzufügen, um den Text, der näher an uns liegt, deutlich zu machen und den Text, der weiter von uns entfernt ist, unscharf zu machen.

Aber dies erfordert eine detaillierte Verarbeitung jedes Textes. Die obige HTML-Struktur kann nicht jeden Text einzeln verarbeiten:

rrreee

Der vollständige Code sieht wahrscheinlich so aus:
rrreee

Einfach Unter der Analyse sind hier einige Tipps, um den Effekt, den wir benötigen, sorgfältig zu beobachten:

  1. Das erste Zeichen und das letzte Zeichen sind unter dem Effekt ganz links bzw. am weitesten rechts von uns, ihre Effekte sollten eigentlich gleich sein , also sollten das erste Zeichen und das letzte Zeichen einheitlich verarbeitet werden, und so weiter, das zweite Zeichen und das vorletzte Zeichen sollten einheitlich verarbeitet werden, hier können Sie SASS verwenden, um :nth-child und :nth-last-child CSS-Code effizient schreiben
  2. Jedes Mal ist die Hälfte klar und die andere Hälfte verschwommen, was unterschiedlich behandelt werden muss, indem animation-delayverwendet wird > verzögert die Hälfte der Animation
  3. Es kann mit text-shadow kombiniert werden, um den Text dreidimensionaler zu machen

Auf diese Weise haben wir kann endlich den folgenden Effekt erzielen:

 3- 1.gif

Für den vollständigen Code können Sie hier klicken – CSS-Inspiration – Verwenden Sie filter:blur, um den 3D-Effekt von Text zu verstärken🎜🎜https://csscoco.com/inspiration/#/. / filter/use-filter-blur-enhance-text-3d-effect🎜🎜🎜Verwenden Sie Unschärfe, um einen fallenden Blatteffekt zu erzeugen.🎜🎜Verwenden Sie Unschärfe richtig, um ohne transform-style: Preserve-3d und zu arbeiten Perspektive lassen sich auch gute 3D-Effekte erzeugen. 🎜🎜Zum Beispiel verwendet der Falling-Blatt-Effekt unten Unschärfe und einfache hierarchische Beziehungen, um das gesamte Bild sehr real aussehen zu lassen: 🎜rrreeerrreee🎜🎜🎜🎜 Hauptsächlich durch den Vergleich der beiden Zustände 🎜klar🎜 und 🎜verschwommen🎜, der Geschwindigkeit Unterschied, um einen Parallaxeneffekt zu erzeugen. 🎜🎜🎜CodePen-Demo – Fallende Blätter🎜🎜https://codepen.io/Chokcoco/pen/vYyGVZZ🎜🎜🎜Endlich🎜🎜Okay, das ist das Ende dieses Artikels, ich hoffe, er wird Ihnen hilfreich sein :) 🎜🎜Weitere Programmierkenntnisse finden Sie unter: 🎜Programmiervideo🎜! ! 🎜

Das obige ist der detaillierte Inhalt vonNutzen Sie geschickt Filter- und Transformationsstileigenschaften, um visuelle 3D-Effekte zu erzeugen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen