CSS实现图片背景填充的六边形的示例代码
前端  /  管理员 发布于 7年前   196
六边形的实现原理其实就是通过旋转三个重叠的矩形得到的,如下图所示:
这里为了得到一个正的六边形,两个矩形旋转的角度必须为-60deg和60deg,以及矩形高宽比必须是Math.sqrt(3) : 1
那么首先我们要创建三个矩形:
<div class="hexagon"> <div class="hexagon__item hexagon__item_left"></div> <div class="hexagon__item hexagon__item_center"></div> <div class="hexagon__item hexagon__item_right"></div> </div>
我们设定三个矩形的宽高分别为60px和104px,背景色为蓝色,.hexagon__item_left旋转-60deg,.hexagon__item_right旋转60deg,.hexagon__item_center不旋转。
.hexagon {width: 60px;height: 104px;position: relative;margin: 200px auto; } .hexagon__item {width: 100%;height: 100%;background: blue;position: absolute;top: 0;left: 0; } .hexagon__item_left {transform: rotate(-60deg); } .hexagon__item_right {transform: rotate(60deg); }
这样就简单的得到了一个正六边形。
那么我们要如何才能使得蓝色背景变成图片呢,其实也很简单,上述的三个矩形其实只是起到了一个塑形的作用,实际上是应该设置为 visibility: hidden 的,我们需要给三个矩形分别添加一个矩形的子元素并且设置为 visibility: visible 。
三个子元素的宽高需要正好能覆盖之前的蓝色六边形。
做好代码如下,大家可以好好研究一下
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> .hexagon {width: 60px;height: 104px;position: relative;margin: 200px auto; } .hexagon__item {width: 100%;height: 100%;background: blue;position: absolute;top: 0;left: 0;visibility: hidden;overflow: hidden; } .hexagon__item_left {transform: rotate(-60deg); } .hexagon__item_right {transform: rotate(60deg); } .hexagon__item:before {position: absolute;top: 0;left: 0;content: "";height: 100%;width: 120px;visibility: visible;background: url('https://ss2.baidu.com/6ONYsjip0QIZ8tyhnq/it/u=13897784,1115290966&fm=58') no-repeat;background-size: cover;transform-origin: 0 0; } .hexagon__item_left:before {transform: rotate(60deg) translateY(-50%); } .hexagon__item_right:before {transform: rotate(-60deg) translateX(-75%); } .hexagon__item_center:before {transform: translateX(-25%); } </style></head><body> <div class="hexagon"> <div class="hexagon__item hexagon__item_left"></div> <div class="hexagon__item hexagon__item_center"></div> <div class="hexagon__item hexagon__item_right"></div> </div></body></html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号