Maison > interface Web > tutoriel CSS > le corps du texte

Comment implémenter des hexagones en CSS

藏色散人
Libérer: 2023-01-07 11:41:53
original
8722 Les gens l'ont consulté

Comment implémenter des hexagones en CSS : 1. Combinez 3 p ensemble, dont 2 triangles isocèles et un rectangle 2. Obtenez un hexagone régulier en faisant pivoter 3 rectangles sous des angles différents.

Comment implémenter des hexagones en CSS

L'environnement d'exploitation de cet article : système Windows7, version HTML5&&CSS3, ordinateur Dell G3.

Comment implémenter des hexagones en CSS ?

J'écrivais récemment une mise en page en nid d'abeille, j'ai donc étudié le principe d'implémentation des hexagones
Deux façons d'implémenter des hexagones :
Méthode 1 : Un rectangle + deux triangles
Nous devons d'abord comprendre la bordure
Comment implémenter des hexagones en CSS
Chaque bordure mesure 45 degrés d'écart. Nous pouvons utiliser cela pour créer un triangle

<p class="triangle"></p>/*css片段*/.triangle{
    width: 0;
    height: 0;
    border-bottom: 50px solid red;
    border-left: 86px solid transparent;
    border-right: 86px solid transparent;
}
Copier après la connexion

Le code ci-dessus peut créer un triangle isocèle avec un angle au sommet de 120 degrés
Comment implémenter des hexagones en CSS
La façon dont nous créons un hexagone est de combiner 3 p ensemble, le haut et le bas sont 120. -des triangles isocèles de degrés, et le milieu est un rectangle (note : border-top/border-bottom détermine la hauteur du triangle)
Réalisons l'hexagone

<p class="top-triangle"></p>
<p class="center"></p>
<p class="bottom-triangle"></p>
/*css片段*/
.top-triangle{
    width: 0;
    height: 0;
    border-bottom: 50px solid red;
    border-left: 86px solid transparent;
    border-right: 86px solid transparent;
}
.center{
    width: 172px;
    height: 100px;
    background: red;
}
.bottom-triangle{
    width: 0;
    height: 0;
    border-top: 50px solid red;
    border-left: 86px solid transparent;
    border-right: 86px solid transparent;
}
Copier après la connexion

Comment implémenter des hexagones en CSS
A partir du code ci-dessus, on peut obtenir une déformation hexagonale régulière
Méthode 2 : Faites pivoter trois rectangles sous des angles différents pour obtenir un hexagone régulier
Points clés : overflow : caché ;
L'utilisation de transform: rotate()

<p class="six">
    <p class="child">
        <p class="child_child"></p>
    </p></p>/*css片段*/.six,.child,.child_child{
    width: 100px;
    height: 150px;
    overflow: hidden;
}.six{    -webkit-transform: rotate(120deg);    -o-transform: rotate(120deg);    -ms-transform: rotate(120deg);    -moz-transform: rotate(120deg);
    transform: rotate(120deg);
}.child{    -webkit-transform: rotate(-60deg);    -o-transform: rotate(-60deg);    -ms-transform: rotate(-60deg);    -moz-transform: rotate(-60deg);
    transform: rotate(-60deg);
}.child_child{
    background: red;    -webkit-transform: rotate(-60deg);    -o-transform: rotate(-60deg);    -ms-transform: rotate(-60deg);    -moz-transform: rotate(-60deg);
    transform: rotate(-60deg);
}
Copier après la connexion

peut ajouter le p le plus intérieur. Pour les arrière-plans ou les images, n'ajoutez pas de couleur à les deux p à l'extérieur. Cependant, il n'y a aucun moyen d'ajouter du texte à l'hexagone créé de cette manière. Exécutez le code ci-dessus pour obtenir l'image suivante :
Comment implémenter des hexagones en CSS

【Apprentissage recommandé : "tutoriel vidéo CSS" 】

.

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!

Étiquettes associées:
css
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal