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 Eckenformen 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 Kurve zwischen einem Rechteck und einer Ellipse. Sie ähnelt einer Ellipse, die die geometrischen Merkmale ihrer beiden Achsen beibehält.
Die Superellipse-Form wird unter Verwendung einer modifizierten Version einer Ellipse berechnet. Die folgende Gleichung definiert eine Ellipse, die am 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 beide gleich r kann die Gleichung für einen Kreis geschrieben werden als:
In dieser Gleichung sind die x und y die Koordinaten der Punkte auf dem Umfang des Kreises, und das r ist der Radius des Kreises, wobei der Mittelpunkt des Kreises bei (0, 0) liegt. Die Ellipse entsteht durch Skalierung der Form eines Kreises 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 modifiziert:
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 normale Ellipse entsprechend demroundSchlüsselwort. - Ein
KWert von>1macht die Ellipse Form eckiger;2entspricht demsquircleSchlüsselwort. - Ein
KWert vonunendlicherzeugt ein perfektes Quadrat (entsprechend demsquareSchlüsselwort), obwohlKWerte von10oder mehr praktisch nicht von einem Quadrat zu unterscheiden sind. - Negative
KWerte führen zu einer konkaven Kurve, was zu Eckenformen führt, die nach innen gekrümmt sind oder „ausgehöhlt“ erscheinen. EinKWert von-1entspricht demscoopSchlüsselwort und-unendlichentspricht demnotchSchlüsselwort.
Eine negative oder positive Superellipse würde symmetrisch zu einer Superellipse mit ihrem inversen Wert erscheinen.
Hinweis:
Für jeden K Parameterwert, der übergeben wird, wird der Rückgabewert der superellipse() Funktion immer gleich für diesen K Wert sein. Wenn dieser Wert auf zwei Elemente angewendet wird, kann das Erscheinungsbild der Eckenform unterschiedlich sein, wenn die Boxgröße oder border-radius Werte unterschiedlich sind.
Formale Syntax
<superellipse()> =
superellipse( <number [-∞,∞]> |
infinity |
-infinity )
Beispiele
>superellipse() Wertvergleiche
In diesem Beispiel ermöglichen zwei <input type="range"> Schieberegler Ihnen, viele verschiedene corner-shape superellipse() Werte und border-radius Werte durchzugehen, was Ihnen ermöglicht, die Auswirkungen jedes einzelnen auf einen Container zu vergleichen. Der Code ist der Kürze halber versteckt, aber die vollständige Erklärung des Superellipse Wertvergleichs wird auf der corner-shape Referenzseite bereitgestellt.
Hinweis:
Siehe auch das <corner-shape-value> Wertvergleichs Beispiel.
Spezifikationen
| Specification |
|---|
| CSS Borders and Box Decorations Module Level 4> # funcdef-superellipse> |
Browser-Kompatibilität
Loading…