时间:2021-05-08
不知道为什么,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-pathconst 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六边形图集内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文主要介绍了css实现六边形图片的示例代码,分享给大家,具体如下:不说别的,先上效果:用简单的div配合伪元素,即可‘画出’这幅六边形
说下两种css制作正六边形的方法。先看一下结果:在之前要先了解一下正六边形内角和边的关系,正六边形的每个内角是60deg,如图(√3其实是根号3):
纯CSS绘制的六边形复制代码代码如下:DrawHive.hexagon{display:inline;float:left;}#second{margin-le
一、前言六边形能力图如下,由6个六边形组成,每一个顶点代表其在某一方面的能力。这篇文章我们就来看看如何基于canvas去绘制这么一个六边形能力图。当然,你也可以
blender在创建模型的时候,用到了蜂巢网格效果的模型,制作这个蜂巢网格我们需要创建一个六边形,然后使用到array修改器等工具与操作。软件名称:Blende