--- title: shape-outside slug: Web/CSS/shape-outside tags: - CSS - Propriété - Reference translation_of: Web/CSS/shape-outside ---
La propriété shape-outside
définit une forme (qui peut ne pas être un rectangle) autour de laquelle le contenu en ligne devra « s'écouler ». Par défaut, le contenu en ligne évolue autour de la boîte de marge de l'élément flottant. La propriété shape-outside
permet de personnaliser ce contour et d'obtenir un texte qui s'écoule autour d'objets plus complexes que des rectangles.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
/* Valeurs avec un mot-clé */ shape-outside: none; shape-outside: margin-box; shape-outside: content-box; shape-outside: border-box; shape-outside: padding-box; /* Valeurs utilisant une fonction */ shape-outside: circle(); shape-outside: ellipse(); shape-outside: inset(10px 10px 10px 10px); shape-outside: polygon(10px 10px, 20px 20px, 30px 30px); shape-outside: linear-gradient(45deg, rgba(255,255,255,0) 150px, red 150px); /* Valeur de type <url> */ shape-outside: url(image.png); /* Valeur de type <gradient> */ shape-outside: linear-gradient(45deg, rgba(255, 255, 255, 0) 150px, red 150px); /* Valeurs globales */ shape-outside: initial; shape-outside: inherit; shape-outside: unset;
none
<shape-box>
margin-box
', 'border-box
', 'padding-box
' or 'content-box
' qui correspondent chacune aux boîtes de marge, bordure, remplissage et de contenu. La boîte ainsi définie inclue les courbures induites par {{cssxref("border-radius")}}. On a un effet semblable à {{cssxref("background-clip")}}.<basic-shape>
inset()
, circle()
, ellipse()
, ou polygon()
. Si une valeur <shape-box>
est fournie, cela définira la boîte de référence dans laquelle appliquée la forme définie avec la fonction <basic-shape>
. Si <shape-box>
n'est pas fournie, la valeur par défaut sera 'margin-box
'.<image>
fetch
, éventuellement avec CORS pour les URL utilisées dans shape-outside
. Lors de l'accès à la ressource, les agents utilisateurs doivent utiliser le mode Anonymous et définir la source du referrer comme l'URL de la feuille de style, l'origine de l'URL doit être celle du document. S'il y a des erreurs réseau empêchant de récupérer l'image, l'effet sera le même que celui obtenu avec la valeur none
.Afin de pouvoir interpoler entre deux formes, on appliquera les règles suivantes. Les valeurs avec des fonctions sont interpolées comme une liste simple. Les valeurs d'une liste sont interpolées comme des longueurs, des pourcentages ou des valeurs calculées lorsque c'est possible. Si les valeurs de la liste n'ont pas ces types mais sont identiques (par exemple, on trouve nonzero
à la même position dans les deux listes), les valeurs pourront interopérer.
ellipse()
ou circle()
et qu'aucun des rayons n'utilise les mots-clés closest-side
ou farthest-side
, on aura une interpolation entre chaque valeur.inset()
, on aura une interpolation entre chaque valeur.polygon()
, que les deux polygones ont le même nombre de côtés et utilisent la même règle <fill-rule>
, on aura une interpolation entre chaque valeur.<div class="main"> <div class="left"></div> <div class="right"></div> <p> Sometimes a web page's text content appears to be funneling your attention towards a spot on the page to drive you to follow a particular link. Sometimes you don't notice. </p> </div>
.main { width: 530px; } .left, .right { width: 40%; height: 12ex; background-color: lightgray; } .left { -webkit-shape-outside: polygon(0 0, 100% 100%, 0 100%); shape-outside: polygon(0 0, 100% 100%, 0 100%); float: left; -webkit-clip-path: polygon(0 0, 100% 100%, 0 100%); clip-path: polygon(0 0, 100% 100%, 0 100%); } .right { -webkit-shape-outside: polygon(100% 0, 100% 100%, 0 100%); shape-outside: polygon(100% 0, 100% 100%, 0 100%); float: right; -webkit-clip-path: polygon(100% 0, 100% 100%, 0 100%); clip-path: polygon(100% 0, 100% 100%, 0 100%); } p { text-align: center; }
{{EmbedLiveSample('Exemples', "100%", 130)}}
Spécification | État | Commentaires |
---|---|---|
{{SpecName('CSS Shapes', '#shape-outside-property', 'shape-outside')}} | {{Spec2('CSS Shapes')}} | Définition initiale. |
{{cssinfo}}
{{Compat("css.properties.shape-outside")}}
<basic-shape>