百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>CSS教程> CSS 怎样进行单一div的正多边形变换
分享文章到:

CSS 怎样进行单一div的正多边形变换

发布时间:09/01 来源:未知 浏览: 关键词:
本文是纯洁利用CSS,让“简单个”div,从正三角形变换为正八边形(简单div最多只能做到正八边形),最后再搭配动画的结果,变成正多边形的变换动画,也由于正多边形需要用到不少的三角函数运算,为了利便起见,这里将正多边形的边统一都设为100px。

正三角形

正三角形不需要用到伪元素,只需要设定p本身的边框宽度即可发生,先来看一下正三角形的边长与中线,若边长为100px,则中线四舍五入就是87px(100 x sin(60)= 87)。

1.jpg

因此我们要将p的长宽都设为0,接着把底部border的宽度设为87px,摆布的border宽度设为50px(色彩设为透亮transparent),就可以做出一个美丽的三角形。

width:0;
height:0;
border-width:0 50px 87px ;
border-style:solid;
border-color:transparent transparent #095;

2.jpg

正方形

正方形应当是最简便的,只要设定长宽设定为一样数值就可以了,不外其实还有别的两种办法,第一种你可以把长宽设为0,把上下摆布的border设为50px也可以,第二种则是高度设为0,宽度设为100px,然后某个边宽也设为100,都是可以的。

.a{
width:100px;
height:100px;
background:#c00;
}
.b{
width:0;
height:0;
border-width:50px;
border-style:solid;
border-color:#095;
}
.c{
width:100px;
height:0;
border-width:0 0 100px;
border-style:solid;
border-color:#069;
}

3.jpg

正五边形

正五边形就需要进入根本的三角函数领域了,让我们先把正五边形分解,用本来的p作为上方的三角形,然后用一个伪元素制作下方的梯形,由于正五边形每边的夹角为108度,所以可以藉由三角函数运算出上方三角形的高度为59px(100 x cos(54)),宽度为192px(100x sin(54)x 2),下方梯形的高度为95px(100 x sin(72)),长边的宽度跟上面的三角形一样都是192px。

4.jpg

理解道理之后,就可以利用伪元从来搭配制作啰!

.a{
      position:relative;
  width:0;
  height:0;
  border-width:0 81px 59px;
      border-style:solid;
  border-color:transparent transparent #069;
}
.a:before{
  position:absolute;
  content:"";
  top:59px;
  left:-81px;
  width:100px;
  height:0;
  background:none;
  border-width:95px 31px 0;
  border-style:solid;    
  border-color:#069 transparent transparent;
    }

5.jpg

正六边形

正六边形的每个夹角是120度,假如以纯CSS的标的目的来看的话,就是把正五边形上面的三角形改动一下,就可以做出正六边形,也就是变成上下两个梯形的组合罢了,梯形的长边为200px(100 x cos(60)x 2 + 100),梯形的高度为87px(100 x sin(60))。

6.jpg

所以只要把正五边形的CSS稍作修改就可以做出正六边形了。

.a{
      position:relative;
    width:100px;
    height:0;
    border-width:0 50px 87px;
      border-style:solid;
    border-color:transparent transparent #f80;
}
.a:before{
  position:absolute;
  content:"";
    top:87px;
    left:-50px;
    width:100px;
    height:0;
  background:none;
    border-width:87px 50px 0;
  border-style:solid;    
    border-color:#f80 transparent transparent;
    }

7.jpg

正七边形

正七边形开端就必需再使用after这个伪元素了,由于正七边形必需要拆解为三个内存块,离别是用本来的p作为上面的三角形,一个伪元素作为中心的梯形,然后另一个伪元素作为底部的梯形,正七边形的夹角比力特殊不是整数,而是128又4/7度,大约取到小数第二位是128.57,所以运算起来结果就如下图所示,重点就是必需要分明地知道长宽是多少。

8.jpg

有了长宽之后,就开端用CSS来写啰!

.a{
      position:relative;
    width:0;
    height:0;
    border-width:0 90px 43px;
      border-style:solid;
    border-color:transparent transparent #09c;
}
.a:before{
  position:absolute;
  content:"";
    top:140px;
    left:-112px;
    width:100px;
    height:0;
    border-width:78px 62px 0;
  border-style:solid;    
    border-color:#09c transparent transparent;
    }
  .a:after{
    position:absolute;
    content:"";
    top:43px;
    left:-112px;
    width:180px;
    height:0;
    border-width:0 22px 97px;
    background:none;
    border-style:solid;
    border-color:transparent transparent #09c;
  }

9.jpg

正八边形

正八边形其实就是把正七边形上面的三角形变成梯形,然后中心的梯形变成矩形就搞定了,正八边形的夹角为135度,运算出来的各个区域长宽如下图。

10.jpg

一样的理解道理,CSS做起来就简便多啰!

.a{
      position:relative;
    width:100px;
      height:0;
      border-width:0 71px 71px;
      border-style:solid;
    border-color:transparent transparent  #f69;
}
.a:before{
  position:absolute;
  content:"";
    top:171px;
      left:-71px;
      width:100px;
      height:0;
      border-width:71px 71px 0;
  border-style:solid;    
      border-color: #f69 transparent transparent;
    }
  .a:after{
      position:absolute;
      content:"";
      top:71px;
      left:-71px;
      width:242px;
      height:0;
      border-width:0 0 100px;
      background:none;
      border-style:solid;
      border-color:transparent transparent #f69;
  }

11.jpg

小结

以上就是纯洁利用CSS做出来的简单div的正多边形变换,假如熟练的话,其实加上动画结果,就可以做出像下面示例这个模样的变换动画啰!

12.gif

相关教程:css视频教程

以上就是CSS 怎样停止简单div的正多边形变换的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板