文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

CSS怎样实现蜂巢/六边形图集

2023-06-08 05:08

关注

这篇文章将为大家详细讲解有关CSS怎样实现蜂巢/六边形图集,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、实现六边形

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

CSS怎样实现蜂巢/六边形图集

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

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

CSS怎样实现蜂巢/六边形图集

矩形的宽高先随便设置,后面组件化的时候再计算其关系,通过 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);}

一个六边形就完成了

CSS怎样实现蜂巢/六边形图集

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

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

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

二、设置尺寸

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

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

CSS怎样实现蜂巢/六边形图集

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

CSS怎样实现蜂巢/六边形图集

对角线 b 为

CSS怎样实现蜂巢/六边形图集

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

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

// 传统方案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,然后排列出一排六边形

CSS怎样实现蜂巢/六边形图集

CSS怎样实现蜂巢/六边形图集

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

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

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

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

CSS怎样实现蜂巢/六边形图集

四、添加内容

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

CSS怎样实现蜂巢/六边形图集

CSS怎样实现蜂巢/六边形图集

关于“CSS怎样实现蜂巢/六边形图集”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯