superellipse()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.
Die superellipse() CSS Funktion definiert die Krümmung einer Ellipse und wird verwendet, um Eckformen entweder direkt oder über <corner-shape-value> Schlüsselwörter anzugeben.
Syntax
superellipse(infinity)
superellipse(4)
superellipse(1.7)
superellipse(0)
superellipse(-2.8)
superellipse(-3)
superellipse(-infinity)
Parameter
<number>-
Eine Zahl im Bereich von
-unendlichbisunendlich, einschließlich.
Rückgabewert
Eine Superellipse-Form.
Beschreibung
Die Funktion superellipse() gibt eine Superellipse-Form zurück, die verwendet wird, um corner-shape Werte anzugeben. Eine Superellipse ist eine geschlossene, symmetrische Kurvenform zwischen einem Rechteck und einer Ellipse. Sie ähnelt einer Ellipse, die die geometrischen Merkmale ihrer beiden Achsen beibehält.
Die Superellipse-Form wird mit einer modifizierten Version einer Ellipse berechnet. Die folgende Gleichung definiert eine Ellipse, die im Ursprung zentriert ist:
Die Variablen a und b beziehen sich auf die Radien der Ellipse, während die x und y Koordinaten Punkte auf dem Umfang der Ellipse sind.
Ein Kreis ist eine Ellipse, bei der die Radien, das a und b in der vorherigen Gleichung, die gleiche Länge haben. Mit a und b gleich r kann die Gleichung für einen Kreis wie folgt geschrieben werden:
In dieser Gleichung sind x und y Koordinaten von Punkten auf dem Umfang des Kreises, und r ist der Radius des Kreises, wobei der Mittelpunkt des Kreises (0, 0) ist. Die Ellipse entsteht durch das Skalieren einer Kreisform entlang der x- und/oder y-Achse.
Eine Superellipse-Form entsteht, indem der 2 Exponent in jedem Fall durch 2K ersetzt wird, wobei K das Argument ist, das an die superellipse() Funktion übergeben wird, die die Krümmung der Ellipse ändert:
Das folgende Diagramm zeigt verschiedene superellipse() Werte für die obere rechte Ecke eines Containers: unendlich, 1, 0, -1 und -unendlich:
- Ein
KWert von0erzeugt eine gerade Linie. Dieser Wert kann verwendet werden, um abgeschrägte Ecken zu erstellen und entspricht dem<corner-shape-value>bevelSchlüsselwort. - Ein
KWert von1erzeugt eine gewöhnliche Ellipse, entsprechend dem Schlüsselwortround. - Ein
KWert von>1lässt die Ellipsenform quadratischer erscheinen;2entspricht dem Schlüsselwortsquircle. - Ein
KWert vonunendlicherzeugt ein perfektes Quadrat (entspricht demsquareSchlüsselwort), obwohlKWerte von10oder mehr praktisch nicht von einem Quadrat zu unterscheiden sind. - Negative
KWerte führen zu einer konkaven Kurve, wodurch Eckformen entstehen, die nach innen gekrümmt oder „ausgehöhlt“ sind. EinKWert von-1entspricht dem Schlüsselwortscoopund-unendlichentspricht dem Schlüsselwortnotch.
Eine negative oder positive Superellipse würde symmetrisch zu einer Superellipse mit ihrem inversen Wert erscheinen.
Hinweis:
Für jeden übergebenen K Parameterwert wird der Rückgabewert der superellipse() Funktion immer derselbe für diesen K Wert sein. Wenn dieser Wert auf zwei Elemente angewendet wird, kann das Erscheinungsbild der Eckform abweichen, wenn die Boxgrößen oder border-radius Werte unterschiedlich sind.
Formale Syntax
<superellipse()> =
superellipse( <number [-∞,∞]> |
infinity |
-infinity )
Beispiele
>superellipse() Wertvergleich
In diesem Beispiel ermöglichen zwei <input type="range"> Regler Ihnen, durch viele verschiedene corner-shape superellipse() und border-radius Werte zu blättern und die Auswirkungen auf einen Container zu vergleichen. Der Code ist aus Gründen der Kürze ausgeblendet, aber die vollständige Erklärung des Superellipse-Wertvergleichs finden Sie auf der corner-shape Referenzseite.
Hinweis:
Sehen Sie sich auch das Beispiel zum <corner-shape-value> Wertvergleich an.
Spezifikationen
| Specification |
|---|
| CSS Borders and Box Decorations Module Level 4> # funcdef-superellipse> |