纯CSS实现单一div的正多边形变换_第1页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、纯css实现单一div的正多边形变换纯粹利用css,让单一个div,从正三角形变换为正八边形(单一div最多只能做到正八边形),最后再搭配动画的效果,变成正多边形的变换动画,也因为正多边形需要用到不少的三角函数计算,为了便利起见,这里将正多边形的边统一都设为100px。正三角形正三角形不需要用到伪元素,只需要设定div本身的边框宽度即可产生,先来看一下正三角形的边长与中线,若边长为100px,则中线四舍五入就是87px(100 x sin(60)= 87)。因此我们要将div的长宽都设为0,接着把底部border的宽度设为87px,左右的border宽度设为50px(色彩设为透亮transpa

2、rent),就可以做出一个美丽的三角形。width:0;height:0;border-width:0 50px 87px ;border-style:solid;border-color:transparent transparent 095;正方形正方形应当是最容易的,只要设定长宽设定为同样数值就可以了,不过其实还有另外两种办法,第一种你可以把长宽设为0,把上下左右的border设为50px也可以,其次种则是高度设为0,宽度设为100px,然后某个边宽也设为100,都是可以的。.awidth:100px;height:100px;background:c00;.bwidth:0;heigh

3、t:0;border-width:50px;border-style:solid;border-color:095;.cwidth:100px;height:0;border-width:0 0 100px;border-style:solid;border-color:069;正五边形正五边形就需要进入基本的三角函数领域了,让我们先把正五边形分解,用原本的div作为上方的三角形,然后用一个伪元素制作下方的梯形,由于正五边形每边的夹角为108度,所以可以藉由三角函数计算出上方三角形的高度为59px(100 x cos(54),宽度为192px(100x sin(54)x 2),下方梯形的高度为

4、95px(100 x sin(72),长边的宽度跟上面的三角形一样都是192px。了解原理之后,就可以利用伪元素来搭配制作啰!.aposition:relative;width:0;height:0;border-width:0 81px 59px;border-style:solid;border-color:transparent transparent 069;.a:beforeposition:absolute;content:""top:59px;left:-81px;width:100px;height:0;background:none;bor

5、der-width:95px 31px 0;border-style:solid;border-color:069 transparent transparent;正六边形正六边形的每个夹角是120度,假如以纯css的方一直看的话,就是把正五边形上面的三角形转变一下,就可以做出正六边形,也就是变成上下两个梯形的组合而已,梯形的长边为200px(100 x cos(60)x 2 + 100),梯形的高度为87px(100 x sin(60)。所以只要把正五边形的css稍作修改就可以做出正六边形了。.aposition:relative;width:100px;height:0;border-wi

6、dth:0 50px 87px;border-style:solid;border-color:transparent transparent f80;.a:beforeposition: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;正七边形正七边形开头就必需再用法after这个伪元素了

7、,由于正七边形必需要拆解为三个内存块,分离是用原本的div作为上面的三角形,一个伪元素作为中间的梯形,然后另一个伪元素作为底部的梯形,正七边形的夹角比较特殊不是整数,而是128又4/7度,也许取到小数其次位是128.57,所以计算起来结果就如下图所示,重点就是必需要清晰地知道长宽是多少。有了长宽之后,就开头用css来写啰!.aposition:relative;width:0;height:0;border-width:0 90px 43px;border-style:solid;border-color:transparent transparent 09c;.a:beforepositio

8、n:absolute;content:""top:140px;left:-112px;width:100px;height:0;border-width:78px 62px 0;border-style:solid;border-color:09c transparent transparent;.a:afterposition:absolute;content:""top:43px;left:-112px;width:180px;height:0;border-width:0 22px 97px;background:n

9、one;border-style:solid;border-color:transparent transparent 09c;正八边形正八边形其实就是把正七边形上面的三角形变成梯形,然后中间的梯形变成矩形就搞定了,正八边形的夹角为135度,计算出来的各个区域长宽如下图。同样的了解原理,css做起来就容易多啰!.aposition:relative;width:100px;height:0;border-width:0 71px 71px;border-style:solid;border-color:transparent transparent f69;.a:beforeposition:

10、absolute;content:""top:171px;left:-71px;width:100px;height:0;border-width:71px 71px 0;border-style:solid;border-color: f69 transparent transparent;.a:afterposition:absolute;content:""top:71px;left:-71px;width:242px;height:0;border-width:0 0 100px;background:none;border-style:solid;border-color:transpare

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论