CSS 如何进行单一div的正多边形变换

本文是纯粹利用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的正多边形变换的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2888066.html

(0)
上一篇 2025年3月10日 21:07:56
下一篇 2025年2月25日 17:23:36

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 浅谈CSS的background背景属性

    文档树中的每个元素只是一个矩形盒子,这些盒子都有一个背景层,背景层可以是完全透明或者其它颜色,也可以是一张图片。此背景层由8个css属性(加上1个简写的属性)控制。 background-color background-color属性设置…

    2025年3月10日 编程技术
    200
  • 怎么用div布局?

    div是层叠样式表中的定位技术,全称division,即为划分。有时可以称其为图层。div在编程中又叫做整除,即只得商的整数。 div元素是用来为html(标准通用标记语言下的一个应用)文档内大块(block-level)的内容提供结构和背…

    2025年3月10日
    200
  • aspx怎么引入css?

    aspx引入css的方法: 1、可以直接写在需要样式控制的控件里 例如: 是该div 的边框 颜色,粗细为1像素, solid 视线  。 例如: 2、 写在该页面内 立即学习“前端免费学习笔记(深入)”; 可以是赋给多个控件 控件的 na…

    2025年3月10日
    200
  • css reset是什么意思?

    html标签在浏览器中都有默认的样式,例如p标签有上下边距,strong标签有字体加粗样式等。不同浏览器的默认样式之间存在差别,例如ul默认带有缩进样式,在ie下,它的缩进是由margin实现的,而在firefox下却是由padding实现…

    2025年3月10日
    200
  • css是什么含义

    css指的是层叠样式表,是一种用来表现HTML或XML等文件样式的计算机语言,是描述标记语言页面格式的标准。CSS使开发人员能够分离内容和可视元素,以实现更好的页面控制和灵活性。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网…

    2025年3月10日
    200
  • css中的url是什么意思

    css中的url是指网页背景图片的位置,即指定的某一个图片的绝对存放地址。CSS是层叠样式表,它是一种用来表现HTML或XML等文件样式的计算机语言。 CSS中的url属性:定义的是网页背景图片位置,即指定的某一个图片的绝对存放地址。这么做…

    2025年3月10日
    200
  • css是做什么的

    css(英文全称:cascading style sheets)中文名叫层叠样式表是一种用来表现html或xml等文件样式的计算机语言。css不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。 CSS 能够对网页中…

    2025年3月10日
    200
  • css怎么设置字体为楷体?

    本篇文章小编将和大家讲讲如何在css里设置字体为楷体,还有五类通用字体说明以及其他的字体样式表示,感兴趣的朋友可以看看,希望对你有所帮助。 CSS使用font-family属性来定义字体类型。css设置字体为楷体的语句为: font-fam…

    2025年3月10日
    200
  • 简述什么是css?

    CSS是英语Cascading Style Sheets(层叠样式表单)的缩写,它是一种用来表现HTML或 XML 等文件式样的计算机语言。 样式表有三种类型: 1、外部链接的样式表。指使用CSS文件链接到HTML文件。 2、内部样式表。是…

    2025年3月10日
    200
  • 什么是css(层叠样式表)?

    css是 cascading style sheets(层叠样式表)的缩写,是一种用来表现html(标准通用标记语言的一个应用)或xml(标准通用标记语言的一个子集)等文件样式的计算机语言。 CSS主要用于设置网站外观,让我们的网站更加绚丽…

    2025年3月10日
    200

发表回复

登录后才能评论