Heim  >  Artikel  >  Web-Frontend  >  Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

青灯夜游
青灯夜游nach vorne
2021-04-02 10:20:013250Durchsuche

In diesem Artikel wird ein kleiner Trick vorgestellt, wie Sie mithilfe von SVG-Filtern Rahmen zu verschiedenen unregelmäßigen Grafiken hinzufügen können. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

Hintergrund erforderlich und Ränder zu unregelmäßigen Grafiken hinzufügen


In unserer täglichen Entwicklung werden wir auf einige nicht rechteckige und nicht kreisförmige Muster stoßen. Ähnlich wie folgt:

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

Mit reinem CSS und einigen Techniken können Sie die oben genannten Grafiken erstellen. Dies ist natürlich nur der erste Schritt.

Unmittelbar danach wird möglicherweise eine Aufforderung zum Hinzufügen eines Rahmens zu den obigen Grafiken angezeigt. Zu diesem Zeitpunkt wird es schwierig sein, dies zu tun.

Versuchen Sie, drop-shadow zu verwenden, um Ränder hinzuzufügen. drop-shadow 添加边框


第一种方法,我们可以尝试使用 drop-shadow,给不规则的图形,添加一个外阴影。

我们以一个箭头图形为例使用 CSS 简单实现它的其中一种方式如下:

<div class="arrow-button"></div>
.arrow-button {
    position: relative;
    width: 180px;
    height: 64px;
    background: #f49714;

    &::after {
        content: "";
        position: absolute;
        width: 32px;
        height: 64px;
        top: 0;
        right: -32px;
        background: 
            linear-gradient(-45deg, transparent 0, transparent 22px, #f49714 22px, #f49714 100%),
            linear-gradient(-135deg, transparent 0, transparent 22px, #f49714 22px, #f49714 100%);
        background-size: 32px 32px;
        background-repeat: no-repeat;
        background-position: 0 bottom, 0 top;
    }
}

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

我们通过给 .arrow-button 添加一个 drop-shadow,可以实现给不规则图形添加一个阴影,效果如下:

.arrow-button {
    ...
    filter: drop-shadow(0px 0px 2px #000);
    ...
}

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

drop-shadow  方案的局限性

使用 drop-shadow  方案的局限性在于,drop-shadow 只能对不规则图形生成阴影,无法生成不带模糊的边框效果。

上述图形添加 drop-shadow 的效果如下,与我们想要的实体不带模糊的边框还是差了一点:

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

使用 SVG feMorphology 滤镜添加边框


我们还可以换个思路,复制一个原图形,再将其稍微放大一点点改变为边框的颜色,然后两个图形叠加在一起,就能够生成一个带边框的不规则图形了。

CSS 中也有能够放大元素的能力 transform: scale(),但是本身实现一个原图形的代码可能已经非常复杂了,再叠加一个可能会显得不太优雅,我们得另辟蹊径,寻找其他类似的实现方案。

这里,我们尝试使用 SVG的 feMorphology 滤镜来实现给不规则图形添加边框。

简单介绍下 feMorphology 滤镜

feMorphology 滤镜

feMorphology 为形态滤镜,它的输入源通常是图形的 alpha 通道,用来它的两个操作可以使源图形腐蚀(变薄)或扩张(加粗)。

使用属性 operator 确定是要腐蚀效果还是扩张效果。使用属性 radius 表示效果的程度,可以理解为笔触的大小。

  • operator:erode 腐蚀模式,dilate 为扩张模式,默认为 erode
  • radius:笔触的大小,接受一个数字,表示该模式下的效果程度,默认为 0

我们将这个滤镜简单的应用到文字上看看效果:

<div>
    <p>Normal Text</p>
    <p>Normal Text</p>
    <p>Normal Text</p>
</div>

<svg>
    <filter>
        <femorphology></femorphology>
    </filter>
    <filter>
        <femorphology></femorphology>
    </filter>
</svg>
p {
    font-size: 64px;
}
.dilate {
    filter: url(#dilate);
}
.erode {
    filter: url(#erode);
}

效果如下:最左边的是正常文字,中间的是扩张的模式,右边的是腐蚀模式,看看效果,非常好理解:

Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

借用 feMorphology 的扩张能力给不规则图形添加边框

利用 feMorphology 的扩张能力,我们可以提前准备好一个 SVG feMorphology 滤镜,其作用就是上述所说的:

复制一个原图形,再将其稍微放大一点点改变为边框的颜色,然后两个图形叠加在一起,就能够生成一个带边框的不规则图形了

并且 SVG 滤镜可以非常简单的通过 CSS Filter 的 url 模式引入到各个不同的图形当中去,复用性非常的高。

该滤镜的简单代码如下:

<svg>
    <filter>
        <femorphology></femorphology>
        <femerge>
            <femergenode></femergenode>
            <femergenode></femergenode>
        </femerge>
    </filter>
</svg>

简单浅析一下这段 SVG 滤镜代码:

  • <femorphology in="SourceAlpha" result="DILATED" operator="dilate" radius="1"></femorphology> 将原图的不透明部分作为输入,采用了 dilate 扩张模式且程度为 radius="1",生成了一个比原图大 1px 的黑色图块

  • 使用 feMerge

    🎜🎜Bei der ersten Methode können wir versuchen, drop-shadow zu verwenden, um unregelmäßigen Grafikschatten einen Umriss hinzuzufügen . 🎜🎜🎜Wir nehmen eine Pfeilgrafik als Beispiel und verwenden CSS, um sie einfach umzusetzen. Eine Möglichkeit, sie einfach umzusetzen, ist wie folgt: 🎜
    .arrow-button {
        ...
        filter: url(#outline);
        ...
    }
    <svg>
        <filter>
            <femorphology></femorphology>
    
            <feflood></feflood>
            <fecomposite></fecomposite>
    
            <femerge>
                <femergenode></femergenode>
                <femergenode></femergenode>
            </femerge>
        </filter>
    </svg>
    🎜Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden🎜🎜Wir können einen <code>Schlagschatten hinzufügen. Pfeiltaste Um unregelmäßigen Grafiken einen Schatten hinzuzufügen, ist der Effekt wie folgt: 🎜rrreee🎜Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden🎜

    🎜drop-shadow Die Einschränkungen der Lösung🎜

    🎜Die Einschränkungen der Verwendung von drop-shadow Das Problem besteht darin, dass drop-shadow nur Schatten für unregelmäßige Grafiken erzeugen kann, aber keine Randeffekte ohne Unschärfe erzeugen kann. 🎜🎜Der Effekt des Hinzufügens von drop-shadow zu den obigen Grafiken ist wie folgt, was immer noch ein wenig hinter der gewünschten Entität ohne unscharfen Rand zurückbleibt: 🎜🎜Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden🎜🎜🎜Verwenden Sie den SVG feMorphology Filter zum Hinzufügen eines Rahmens🎜 🎜🎜🎜Wir können auch die Idee ändern und eine Originalgrafik kopieren, sie dann leicht vergrößern und in die Farbe des Rahmens ändern und dann die beiden Grafiken überlagern, um eine unregelmäßige Grafik mit einem zu erzeugen Grenze. 🎜🎜🎜CSS hat auch die Möglichkeit, Elemente zu vergrößern transform: scale(), aber der Code selbst zum Implementieren einer Originalgrafik kann sehr kompliziert sein und das Überlagern einer anderen Grafik muss möglicherweise nicht elegant aussehen Suchen Sie nach anderen ähnlichen Implementierungen. 🎜🎜Hier versuchen wir, den feMorphology-Filter von SVG zu verwenden, um unregelmäßigen Grafiken Ränder hinzuzufügen. 🎜🎜Eine kurze Einführung in den feMorphology-Filter🎜

    🎜feMorphology-Filter🎜

    🎜feMorphology ist normalerweise der Alphakanal der Grafik Denn seine beiden Vorgänge können die Quellgrafik erodieren (verdünnen) oder erweitern (verdicken). 🎜🎜Verwenden Sie das Attribut Operator, um zu bestimmen, ob Sie einen Korrosionseffekt oder einen Expansionseffekt wünschen. Verwenden Sie das Attribut radius, um den Grad der Wirkung anzugeben, der als Größe des Strichs verstanden werden kann. 🎜
    • Operator: erode Korrosionsmodus, dilate ist der Erweiterungsmodus, die Standardeinstellung ist erode
    • Radius: Die Größe des Strichs, akzeptiert eine Zahl, die den Grad des Effekts in diesem Modus angibt, der Standardwert ist 0
    🎜Wir wenden diesen Filter einfach auf den Text an, um den Effekt zu sehen: 🎜rrreeerrreee🎜 Der Effekt ist wie folgt: Der ganz linke ist normaler Text, der in der Mitte ist der Erweiterungsmodus und der rechte ist der Korrosionsmodus. Schauen Sie sich den Effekt an, er ist sehr leicht zu verstehen: 🎜🎜🎜

    🎜Verwenden die Erweiterungsfähigkeit von feMorphology zum Hinzufügen von Rändern zu unregelmäßigen Grafiken🎜🎜Mit der Erweiterungsfähigkeit von feMorphology können wir einen SVG-feMorphologyvorbereiten > Vorher filtern. Seine Funktion ist wie oben erwähnt: 🎜🎜🎜Kopieren Sie eine Originalgrafik, vergrößern Sie sie dann leicht und ändern Sie sie in die Farbe des Randes, und legen Sie dann die beiden Grafiken übereinander, um eine unregelmäßige Grafik mit einem Rand zu erzeugen🎜 . 🎜🎜Und SVG-Filter können über den URL-Modus des CSS-Filters problemlos in verschiedene Grafiken eingeführt werden, und die Wiederverwendbarkeit ist sehr hoch. 🎜🎜Der einfache Code dieses Filters lautet wie folgt: 🎜rrreee🎜Eine kurze Analyse dieses SVG-Filtercodes: 🎜
    • 🎜<femorphology in="SourceAlpha" result="DILATED" operator="dilate" radius="1"></femorphology> nimmt den undurchsichtigen Teil des Originalbilds als Eingabe und verwendet dilate Erweiterungsmodus und der Grad ist radius="1", wodurch eine schwarze Kachel erzeugt wird, die 1 Pixel größer als das Originalbild ist🎜
    • 🎜Verwenden Sie dazu feMerge Konvertieren Sie das Schwarz. Die Kacheln und das Originalbild werden überlagert🎜

    我们还是给上述的 .arrow-button 添加一个 CSS filter filter: url(#outline),引入我们创建的 SVG 滤镜:

    .arrow-button {
        ...
        filter: url(#outline);
        ...
    }
    url 是 CSS 滤镜属性的关键字之一,url 模式是 CSS 滤镜提供的能力之一,允许我们引入特定的 SVG 过滤器,这极大的增强 CSS 中滤镜的能力。【推荐教程:CSS视频教程

    看看效果:

    Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

    Wow,这下成功了,通过 feMorphology 滤镜,我们成功的实现了给不规则的图形添加了边框效果,我能可以通过控制滤镜中的 radius="1" 来控制边框的大小。

    再将上述滤镜运用在各种不规则图形下看看效果:

    Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

    效果还算可以,就是颜色是黑色的。如果我们希望边框的颜色是其他颜色,有没有办法呢?

    辅以 feFloodfeComposite 改变边框颜色

    通过 feFloodfeComposite 两个 SVG 滤镜,可以给生成的图块上不同的颜色,代码如下:

    <svg>
        <filter>
            <femorphology></femorphology>
    
            <feflood></feflood>
            <fecomposite></fecomposite>
    
            <femerge>
                <femergenode></femergenode>
                <femergenode></femergenode>
            </femerge>
        </filter>
    </svg>

    通过 feFlood 中的 flood-color="green",即可控制生成的边框(图块)的颜色,这里设置为了绿色。应用到各个图形上的效果如下:

    Ausführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden

    至此,我们实现了通过 SVG 滤镜实现对不规则图形添加不同颜色的边框。

    完整的 DEMO,你可以戳这里:transparent 配合 SVG feMorphology 滤镜生成不规则边框

    总结一下


    简单的总结一下:

    • 使用 drop-shadow 可以实现给不规则图形添加阴影,但是无法实现给不规则图形添加实体不带模糊的边框
    • 使用 feMorphology SVG 滤镜可以实现给给不规则图形添加边框效果,通过控制 radius="1" 可以调节边框的大小
    • 使用 feMorphology 辅以 feFloodfeComposite 滤镜改变边框颜色
    • 通过 CSS Filter 的 url 模式,可以快速的将 SVG 滤镜引入 HTML 元素,例如 filter: url(#outline)

    值得注意的是,由于图形高宽不是 1:1 的,并且 feMorphologydilate 模式也不会根据元素的高宽等比例的扩张,所以生成的边框是不一定在各处的均匀相等的,而 feMorphologyradius 属性可以传入两个值,使用空格分离,分别表示横向与纵向的扩张大小,实际使用的时候可以微调一下。

    最后


    本文更多的是提供一种不规则边框的生成方案思路,当然,具体遇到这种情况大部分还是会以切图为主,不过多了解掌握一种可行方法也不是坏事。

    好了,本文到此结束,一个简单的小技巧,希望对你有帮助 :)

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

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung, wie unregelmäßige Ränder mithilfe von CSS3+SVG-Filtern implementiert werden. 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