系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网页制作 > CSS > 详细页面

CSS 实现蜂巢/六边形图集

时间:2020-03-04来源:电脑系统城作者:电脑系统城

不知道为什么,UI 很喜欢设计蜂巢效果(摊手) 

 

一、实现六边形

首先用传统的方式来分析一下六边形

可以拆分成三个矩形,每个矩形旋转正负 60° 得到其它两个矩形

由此可以设计出基本的 HTML 结构

矩形的宽高先随便设置,后面组件化的时候再计算其关系,通过 props 设置

然后设置 CSS 样式

复制代码
.w-comb {
  background-color: #e4e4e4;
  display: inline-block;
  position: relative;
}

.w-comb-sub1,
.w-comb-sub2 {
  background-color: #e4e4e4;
  position: absolute;
  width: inherit;
  height: inherit;
}

.w-comb-sub1 {
  transform: rotate(-60deg);
}

.w-comb-sub2 {
  transform: rotate(60deg);
}
复制代码

一个六边形就完成了

不过这只是传统的方式,如果不考虑兼容性问题,可以直接使用 clip-path 画一个六边形

复制代码
.w-comb {
  clip-path: polygon(
    0 25%,
    50% 0,
    100% 25%,
    100% 75%,
    50% 100%,
    0 75%
  );
}
复制代码

非常简单粗暴!不需要子节点不需要旋转,只要一行代码,六边形带回家!

 

 

二、设置尺寸

实际的应用场景通常都是一堆六边形拼在一起,所以需要将单个六边形处理为组件

首先的问题就是,如何设置六边形的尺寸,这需要用一下初中学到的数学知识

经过计算,当矩形的长为 x 的时候,宽(边长 a )为

对角线 b 为

 

然后就能规定六边形的尺寸

 

如果是三个矩形旋转而成的传统方案:

复制代码
// 传统方案
const RADICAL_3 = 1.7320508;
const Comb = (props) => {
  const { className } = props;
  const width = props.size || 80;
  const height = Math.ceil(width / RADICAL_3);

  return (
    <div className={`w-comb ${className}`} style={{
      width,
      height,
    }}>
      <div className={'w-comb-sub1'}></div>
      <div className={'w-comb-sub2'}></div>
    </div>
  )
}
复制代码

 

如果是直接使用 clip-path 绘制的六边形:

复制代码
// clip-path
const RADICAL_3 = 1.7320508;
const Comb = (props) => {
  const { className } = props;
  const width = props.size || 80;
  const height = 2 * Math.ceil(width / RADICAL_3);

  return (
    <div className={`w-comb-test ${className}`} style={{
      width,
      height,
    }}></div>
  )
}
复制代码

 

 

三、排列蜂巢

定义一个 spacing 字段,用来设置 margin-right,然后排列出一排六边形

再生成第二排的时候,需要调整一下 top 和 left

left 为矩形长 ( x ) 的一半(这是基础偏移量,实际需要的距离在这个数字上增加)

而 top 则为六边形边长 ( a ) 的一半的一半(基础偏移量)

后面每一行的 top 都会增加,而 left 仅在偶数行生效

 

 

 

四、添加内容 

在传统方案中,是以横向的矩形为基础,所以六边形的内容可以直接写在矩形里

分享到:

相关信息

  • 纯CSS实现具有渐变和圆角的彩色边框

    传统的灰色纯色边框你是不是觉得太难看了?你是否想设计一些精美的边框,例如渐变、圆角、彩色的边框?那你来对地方了,本文将介绍如何用纯CSS就能实现具有渐变和圆角的彩色边框...

    2023-03-06

  • css圆角三角形的实现代码

    今天给大家带来一个如何实现圆角三角形的方案,这个方案虽然可以实现,但是也是借助拼凑等方式来实现的,假如想一个div来实现圆角三角形,还是比较困难的。之前文章讲了如何实现对话框,里面介绍了三角形的实现方式。今天讲讲...

    2023-03-06

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载