Maison > interface Web > tutoriel CSS > Comment créer une forme de cercle inversé en utilisant CSS3 ?

Comment créer une forme de cercle inversé en utilisant CSS3 ?

Mary-Kate Olsen
Libérer: 2024-12-04 05:05:11
original
605 Les gens l'ont consulté

How to Create an Inverse Circle Shape Using CSS3?

Forme CSS 3 : Cercle inversé ou cercle découpé

Question :

Comment puis-je créer un "cercle inversé" ", où le bord extérieur du récipient est découpé de manière circulaire, laissant un cercle plein dans le centre ?

Réponse :

Option de dégradé d'arrière-plan radial CSS3

(Pour les navigateurs modernes comme Firefox, Chrome, Safari, et IE10)

Cette solution améliorée permet un "espace" transparent entre le cercle et son inverse découpe :

CSS :

.inversePair {
  border: 1px solid black;
  display: inline-block;
  position: relative;
  height: 100px;
  text-align: center;
  line-height: 100px;
  vertical-align: middle;
}

#a {
  width: 100px;
  border-radius: 50px;
  background: grey;
  z-index: 1;
}

#b {
  width: 200px;
  padding-left: 30px;
  margin-left: -30px;
  border-left: none;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  background-image: -moz-radial-gradient(-23px 50%, circle closest-corner, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0) 55px, black 56px, grey 57px);
  background-image: -webkit-radial-gradient(-23px 50%, circle closest-corner, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0) 55px, black 56px, grey 57px);
}
Copier après la connexion

Réponse originale :

<div>
Copier après la connexion
.inversePair {
  border: 1px solid black;
  background: grey;
  display: inline-block;
  position: relative;
  height: 100px;
  text-align: center;
  line-height: 100px;
  vertical-align: middle;
}

#a {
  width: 100px;
  border-radius: 50px;
}

#a:before {
  content: ' ';
  left: -6px;
  top: -6px;
  position: absolute;
  z-index: -1;
  width: 112px;
  height: 112px;
  border-radius: 56px;
  background-color: white;
}

#b {
  width: 200px;
  z-index: -2;
  padding-left: 50px;
  margin-left: -55px;
  overflow: hidden;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
}

#b:before {
  content: ' ';
  left: -58px;
  top: -7px;
  position: absolute;
  width: 114px;
  height: 114px;
  border-radius: 57px;
  background-color: black;
}
Copier après la connexion

Les deux solutions aboutissent à un effet de « cercle inversé » visuellement agréable, permettant d'obtenir la forme souhaitée sans avoir besoin d'images.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal