stop-opacity
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since April 2017.
Die stop-opacity CSS Eigenschaft definiert die Opazität eines bestimmten Farbverlaufsstopps im SVG-<stop>-Element innerhalb eines SVG-Verlaufs. Falls vorhanden, überschreibt sie das stop-opacity-Attribut des Elements.
Der Werte dieser Eigenschaft hat Einfluss auf den Alpha-Kanal der stop-color; er kann die Transparenz der Farbe eines <stop> erhöhen, aber nicht die durch die stop-color-Eigenschaft definierte Farbe opaker machen.
Syntax
/* numeric and percentage values */
stop-opacity: 0.2;
stop-opacity: 20%;
/* Global values */
stop-opacity: inherit;
stop-opacity: initial;
stop-opacity: revert;
stop-opacity: revert-layer;
stop-opacity: unset;
Werte
Der <opacity-value> ist eine <number> oder <percentage>, die die Opazität des SVG-Verlaufs-<stop>-Elements angibt.
<number>-
Ein numerischer Wert zwischen
0und1, inklusive. <percentage>-
Ein Prozentwert zwischen
0%und100%, inklusive.
Mit 0 oder 0% ist der Stopp vollständig transparent. Mit 1 oder 100% ist das Element in voller Opazität des stop-color-Werts vorhanden, der möglicherweise teilweise undurchsichtig ist.
Formale Definition
| Anfangswert | black |
|---|---|
| Anwendbar auf | <stop> elements in <svg> |
| Vererbt | Nein |
| Berechneter Wert | wie angegeben |
| Animationstyp | diskret |
Formale Syntax
stop-opacity =
<number> |
<percentage>
Beispiele
>Definieren der Opazität eines SVG-Verlaufsfarbstopps
Dieses Beispiel demonstriert den grundlegenden Anwendungsfall von stop-opacity und wie die CSS-stop-opacity-Eigenschaft Vorrang vor dem stop-opacity-Attribut hat.
HTML
Wir haben ein SVG mit einigen <polygon> Sternen und drei <linearGradient> Elementen: Jedes hat drei <stop> Elemente, die drei Farbstopps definieren, um einen Verlauf zu erzeugen, der von Blau zu Weiß zu Pink geht; der einzige Unterschied zwischen ihnen ist der id-Wert.
<svg viewBox="0 0 250 120" xmlns="http://www.w3.org/2000/svg">
<defs>
<linearGradient id="myGradient1">
<stop offset="5%" stop-color="#66ccff" stop-opacity="1" />
<stop offset="50%" stop-color="#fefefe" stop-opacity="1" />
<stop offset="95%" stop-color="#f4aab9" stop-opacity="1" />
</linearGradient>
<linearGradient id="myGradient2">
<stop offset="5%" stop-color="#66ccff" stop-opacity="1" />
<stop offset="50%" stop-color="#fefefe" stop-opacity="1" />
<stop offset="95%" stop-color="#f4aab9" stop-opacity="1" />
</linearGradient>
<linearGradient id="myGradient3">
<stop offset="5%" stop-color="#66ccff" stop-opacity="1" />
<stop offset="50%" stop-color="#fefefe" stop-opacity="1" />
<stop offset="95%" stop-color="#f4aab9" stop-opacity="1" />
</linearGradient>
</defs>
<polygon points="40,10 10,100 80,40 0,40 70,100" />
<polygon points="125,10 95,100 165,40 85,40 155,100" />
<polygon points="210,10 180,100 250,40 170,40 240,100" />
</svg>
CSS
Wir fügen stroke und stroke-width hinzu, um die Polygonpfadlinie sichtbar zu machen.
Jedes polygon hat einen Verlaufshintergrund, der mit der fill Eigenschaft festgelegt wird; die id des Verlaufs ist der url()-Parameter. Wir setzen magenta als Fallback-Farbe.
Wir definieren die Opazität der Stopps jedes Verlaufs mit der stop-opacity Eigenschaft.
Das SVG hat einen gestreiften Hintergrund, um die Transparenzeinstellungen deutlicher zu machen.
polygon {
stroke: #333333;
stroke-width: 1px;
}
polygon:nth-of-type(1) {
fill: url("#myGradient1") magenta;
}
polygon:nth-of-type(2) {
fill: url("#myGradient2") magenta;
}
polygon:nth-of-type(3) {
fill: url("#myGradient3") magenta;
}
#myGradient1 stop {
stop-opacity: 1;
}
#myGradient2 stop {
stop-opacity: 0.8;
}
#myGradient3 stop {
stop-opacity: 25%;
}
Ergebnisse
Der erste Stern ist vollständig opak. Die Füllung des zweiten Sterns ist zu 80% opak, weil die Farbstopps leicht durchscheinend sind; stop-opacity: 0.8; überschreibt den stop-opacity="1" Attribute-Wert des Elements. Die Füllung des letzten Sterns ist kaum bemerkbar mit Farbstopps, die zu 25% opak sind. Beachten Sie, dass der Strich in allen Fällen das gleiche durchgehend opake Dunkelgrau ist.
Hinweis:
Da wir denselben stop-opacity Wert für alle Geschwister-<stop> Elemente im linearen Verlauf verwendet haben, hätten wir stattdessen einen einzigen <linearGradient> mit vollständig opaken Stopps verwenden können und einen Wert für die fill-opacity Eigenschaft jedes <polygon> setzen.
Spezifikationen
| Specification |
|---|
| Scalable Vector Graphics (SVG) 2> # StopOpacityProperty> |
Browser-Kompatibilität
Loading…
Siehe auch
- SVG
stop-opacityAttribut - Präsentationseigenschaften:
stop-opacity,clip-rule,color-interpolation-filters,fill-opacity,fill-rule,fill,marker-end,marker-mid,marker-start,shape-rendering,stop-color,stroke,stroke-dasharray,stroke-dashoffset,stroke-linecap,stroke-linejoin,stroke-miterlimit,stroke-opacity,stroke-width,text-anchor, undvector-effect opacitybackground-color<color><basic-shape>Datentyp