dmz社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1252|回复: 0

[Html/Css] CSS 实现蜂巢/六边形图集

[复制链接]
  • TA的每日心情

    2024-11-19 20:46
  • 签到天数: 244 天

    [LV.8]以坛为家I

    4434

    主题

    1459

    帖子

    1万

    积分

    会|员

    Rank: 9Rank: 9Rank: 9

    积分
    10839
    发表于 2020-3-6 16:09:14 | 显示全部楼层 |阅读模式

    本站资源全部免费,回复即可查看下载地址!

    您需要 登录 才可以下载或查看,没有帐号?立即注册

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

    一、实现六边形
    首先用传统的方式来分析一下六边形
    1059788-20200130171549260-242911694.png
    可以拆分成三个矩形,每个矩形旋转正负 60° 得到其它两个矩形
    由此可以设计出基本的 HTML 结构
    1059788-20200130104447364-1260267112.png
    矩形的宽高先随便设置,后面组件化的时候再计算其关系,通过 props 设置
    然后设置 CSS 样式
    [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);
    }


    一个六边形就完成了
    1059788-20200130104929073-882394814.png
    不过这只是传统的方式,如果不考虑兼容性问题,可以直接使用 clip-path 画一个六边形
    [CSS] 纯文本查看 复制代码
    .w-comb {
      clip-path: polygon(
    25%,
        50% 0,
        100% 25%,
        100% 75%,
        50% 100%,
    75%
      );
    }


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


    二、设置尺寸
    实际的应用场景通常都是一堆六边形拼在一起,所以需要将单个六边形处理为组件
    首先的问题就是,如何设置六边形的尺寸,这需要用一下初中学到的数学知识
    1059788-20200130173430121-1760738150.png
    经过计算,当矩形的长为 x 的时候,宽(边长 a )为
    1059788-20200130153036321-2037804069.png
    对角线 b 为
    1059788-20200130153112405-725623156.png
    然后就能规定六边形的尺寸

    如果是三个矩形旋转而成的传统方案:
    [JavaScript] 纯文本查看 复制代码
    // 传统方案
    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 绘制的六边形:
    [JavaScript] 纯文本查看 复制代码
    // 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,然后排列出一排六边形
    1059788-20200130160335010-1173472605.png
    1059788-20200130160057738-530640131.png
    再生成第二排的时候,需要调整一下 top 和 left
    left 为矩形长 ( x ) 的一半(这是基础偏移量,实际需要的距离在这个数字上增加)
    而 top 则为六边形边长 ( a ) 的一半的一半(基础偏移量)
    后面每一行的 top 都会增加,而 left 仅在偶数行生效
    1059788-20200130175008673-236069666.png


    四、添加内容
    在传统方案中,是以横向的矩形为基础,所以六边形的内容可以直接写在矩形里
    1059788-20200130180251853-287833197.png
    1059788-20200130180354514-685811831.png
    copycode.gif
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|小黑屋|本站代理|dmz社区

    GMT+8, 2025-2-2 04:35 , Processed in 0.140891 second(s), 36 queries .

    Powered by Discuz! X3.4 Licensed

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表