Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

polygon()

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨Januar 2020⁩.

Die polygon()-Funktion in CSS gehört zu den <basic-shape> Datentypen. Sie wird verwendet, um ein Polygon zu zeichnen, indem ein oder mehrere Koordinatenpaare angegeben werden, die jeweils einen Scheitelpunkt der Form darstellen.

Probieren Sie es aus

clip-path: polygon(
  0% 20%,
  60% 20%,
  60% 0%,
  100% 50%,
  60% 100%,
  60% 80%,
  0% 80%
);
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
<section class="default-example" id="default-example">
  <div class="transition-all" id="example-element"></div>
</section>
#default-example {
  background: #ffee99;
}

#example-element {
  background: linear-gradient(to bottom right, #ff5522, #0055ff);
  width: 100%;
  height: 100%;
}

Syntax

css
/* Specified as coordinate list */
/* polygon(<length-percentage> <length-percentage>, ... )*/
polygon(50% 2.4%, 34.5% 33.8%, 0% 38.8%, 25% 63.1%, 19.1% 97.6%)
polygon(0px 0px, 200px 100px, 0px 200px)
polygon(0% 0px, 100% 100px, 0px 100%)
polygon(0 0, 50% 1rem, 100% 2vw, calc(100% - 20px) 100%, 0 100%)

/* Specified as coordinate list and fill rule*/
/* polygon(<fill-rule> <length-percentage> <length-percentage>, ... )*/
polygon(nonzero, 0% 0%, 50% 50%, 0% 100%)
polygon(evenodd, 0% 0%, 50% 50%, 0% 100%)

Die Parameter der polygon()-Funktion werden durch Kommas und optionale Leerzeichen getrennt. Der erste Parameter ist ein optionaler Wert für <fill-rule>. Weitere Parameter sind Punkte, die das Polygon definieren. Jeder Punkt ist ein Paar von x/y-Koordinaten <length-percentage>-Werten, die durch ein Leerzeichen getrennt sind, z.B. "0 0" und "100% 100%" für die linke/obere und rechte/untere Ecke.

Hinweis: Das SVG-Element <polygon> hat separate Attribute für fill-rule und points, und points ist flexibel in Bezug auf die Verwendung von Leerzeichen- und Komma-Separatoren. Bei CSS polygon()-Regeln müssen Separatoren strikt beachtet werden.

Parameter

<fill-rule> Optional

Ein optionaler Wert nonzero (der Standardwert, wenn nicht angegeben) oder evenodd, der die Füllregel festlegt.

<length-percentage>

Jeder Scheitelpunkt des Polygons wird durch ein Paar von <length-percentage>-Werten dargestellt, die die x/y-Koordinaten des Scheitelpunkts relativ zur Referenzbox der Form angeben.

Rückgabewert

Gibt einen Wert vom Typ <basic-shape> zurück.

Beschreibung

Mit der Funktion polygon() können Sie nahezu jede Form erstellen, indem Sie die Koordinaten ihrer Punkte angeben. Die Reihenfolge, in der Sie die Punkte definieren, ist wichtig und kann zu unterschiedlichen Formen führen. Die Funktion polygon() erfordert mindestens 3 Punkte, die ein Dreieck bilden, hat jedoch keine obere Begrenzung.

Die Funktion polygon() akzeptiert als Werte durch Kommas getrennte Koordinaten oder Punkte. Jeder Punkt wird durch ein Paar von mit Leerzeichen getrennten x- und y-Werten dargestellt, die die Koordinaten der Punkte innerhalb des Polygons anzeigen.

polygon(x1 y1, x2 y2, x3 y3, x4 y4, xn yn)

Auf dieser Grundlage lässt sich die Zuordnung der Koordinaten des Containers wie folgt visualisieren:

Achse Punkt 1 Punkt 2 Punkt 3 Punkt 4 Punkt n
x 0% 100% 100% 0% xn
y 0% 0% 100% 100% yn

Diese Koordinaten auf die CSS-Eigenschaft clip-path mit der Funktion polygon() anwenden:

css
clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);

Dadurch wird eine Rechteckform in der Größe des übergeordneten Inhalts erstellt, indem die Koordinaten seiner vier Ecken angegeben werden: oben links (0% 0%), oben rechts (100% 0%), unten rechts (100% 100%) und unten links (0% 100%).

Formale Syntax

<polygon()> = 
polygon( <'fill-rule'>? [ round <length> ]? , [ <length-percentage> <length-percentage> ]# )

<fill-rule> =
nonzero |
evenodd

<length-percentage> =
<length> |
<percentage>

Beispiele

Ein Dreieck erstellen

In diesem Beispiel wird ein Dreieck gebildet, indem die Koordinaten seiner drei Punkte definiert werden.

HTML

html
<div class="triangle"></div>

CSS

css
.triangle {
  width: 400px;
  height: 400px;
  background-color: magenta;
  clip-path: polygon(100% 0%, 50% 50%, 100% 100%);
}

Ergebnis

Die Koordinaten für das Dreieck sind die obere rechte Ecke (100% 0%), der Mittelpunkt (50% 50%) und die untere rechte Ecke (100% 100%) des Containers.

Ein Polygon für shape-outside einstellen

In diesem Beispiel wird eine Form erstellt, der der Text folgt, indem die Eigenschaft shape-outside verwendet wird.

html
<div class="box">
  <div class="shape"></div>
  <p>
    One November night in the year 1782, so the story runs, two brothers sat
    over their winter fire in the little French town of Annonay, watching the
    grey smoke-wreaths from the hearth curl up the wide chimney. Their names
    were Stephen and Joseph Montgolfier, they were papermakers by trade, and
    were noted as possessing thoughtful minds and a deep interest in all
    scientific knowledge and new discovery. Before that night—a memorable night,
    as it was to prove—hundreds of millions of people had watched the rising
    smoke-wreaths of their fires without drawing any special inspiration from
    the fact.
  </p>
</div>
css
.box {
  width: 250px;
}

.shape {
  float: left;
  shape-outside: polygon(
    0 5%,
    15% 12%,
    30% 15%,
    40% 26%,
    45% 35%,
    45% 45%,
    40% 55%,
    10% 90%,
    10% 98%,
    8% 100%,
    0 100%
  );
  width: 300px;
  height: 320px;
}

p {
  font-size: 0.9rem;
}

Spezifikationen

Specification
CSS Shapes Module Level 1
# funcdef-basic-shape-polygon

Browser-Kompatibilität

Siehe auch