可以用css3制作不规则多边形吗

html-css014

可以用css3制作不规则多边形吗,第1张

1、圆形

#circle {    width: 100px    height: 100px    background: red    -moz-border-radius: 50px    -webkit-border-radius: 50px    border-radius: 50px

}

2、椭圆

#oval {    width: 200px    height: 100px    background: red    -moz-border-radius: 100px / 50px    -webkit-border-radius: 100px / 50px    border-radius: 100px / 50px

}

3、等边三角

#triangle-up {    width: 0    height: 0    border-left: 50px solid transparent    border-right: 50px solid transparent    border-bottom: 100px solid red

}

4、直角三角

#triangle-topleft {    width: 0    height: 0    border-top: 100px solid red 

    border-right: 100px solid transparent          

}

5、平行四边形

#parallelogram {    width: 150px    height: 100px    margin-left:20px    -webkit-transform: skew(20deg)       -moz-transform: skew(20deg)         -o-transform: skew(20deg)    background: red

}

培训视频、在线学习、学习视频网站、网络学习平台

技术文章 >web前端 >css教程

css常见问题:如何画多边形(三角形~六边形)

青灯夜游青灯夜游2021-09-16 10:57:38转载

利用纯CSS如何画多边形?本篇文章就来给大家介绍一下从纯CSS画三角形开始,介绍一下画四边形、五边形、六边形的方法,更高的实现方式也可以此类推画出来,希望对大家有所帮助!

今天要学习一下面试中常考的一个css题目,用css画多边形。 这一次以三角形、四边形、五边形、六边形为例,首先开始之前需要了解一些必要的知识。

一、基础知识储备

本次将利用纯CSS知识来绘制一些形状,为了绘制这些形状,首先补习一下所需的CSS基础知识点——css盒模型。【相关推荐:《css视频教程》】

1.png

由上图可以看出标准的盒模型是由content,padding,border,margin组成的,我们用代码看一下具体情况吧。

<!--HTML部分,此部分代码若是不变,后面将复用不在赘述-->

<div id="main"></div>

/*css部分*/

#main {

width: 100px

height: 100px

border: 200px solid red

}

效果图如下:

2.png

二、实战

光说不练假把式,现在就由利用这些基本的CSS属性来绘制常见的三角形、四边形、五边形……

2.1 四边形

若是不能用直接使用background-color属性来画一个四边形,由上图我们可以看出若是让content的宽高全部设为0,并设置border的宽高,那么我们就可以得到一个仅由border构成的四边形了,四边形又分为正方形、平行四边形、矩形等等,这里就让我们使用border来实现上述中的三种图形吧。

2.1.1 正方形

首先让我们来实现一下最简单的正方形吧。

#main {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid black

border-right: 200px solid blue

border-top: 200px solid pink

}

效果如下图所示:

3.png

2.1.2 矩形

在2.1.1中我们已经实现了通过使用border来实现正方形,那么我们接下来实现一下矩形吧,根据所学过的数学知识我们只需用将正方形的调整正方形的长宽使其长≠宽即可,接下来让我们来实现一下吧。

#main {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 100px solid red

border-right: 100px solid red

border-top: 200px solid red

}

效果如下图所示:

4.png

2.1.3 平行四边形

PS:平行四边形的实现需要使用两个三角形来实现,故此这里建议先跳过,请先前往阅读2.2中查看三角形的实现,再折返查看此处的平行四边行的方法。

此处便默认您已阅读完了2.2的内容了,接下来实现一下平行四边形。

<div id="wrapper">

<div class="public"></div>

<div class="public move"></div>

</div>

*{

margin: 0

}

#wrapper {

position: relative

}

.public {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid transparent

border-right: 200px solid transparent

border-top: 200px solid transparent

position: absolute

}

.move {

transform: rotate(180deg)

top: 200px

left: 200px

}

效果如下图所示:

5.png

2.2 三角形

目前为止,最为简单的四边形已完成,那么此时是不是已经有感觉了呢!我们接着往下走,既然border可以实现四边形,那么三角形按道理应该也不在话下,当然三角形里面也有很多很多种类,按照角划分,可分为锐角三角形、直角三角形、钝角三角形;下面分别来实现一下。

2.2.1 锐角三角形

首先我们来看看在content的宽高都是0的情况下,border的left,right,top,bottom四个所占据的情况吧。

#main {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid black

border-right: 200px solid blue

border-top: 200px solid pink

}

效果图如下:

6.png

从图可以看出left,right,top,bottom都是占着一个三角形的情况,那么当我们需要某个三角形时我们只需要让其他三个三角形隐藏起来不就可以了,我们可以用transparent属性值来隐藏border,那么来实现一下吧。

#main {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid transparent

border-right: 200px solid transparent

border-top: 200px solid transparent

}

效果如图所示:

7.png

2.2.2 直角三角形

到此我们可以画出锐角三角形了,直角三角形我们根据上上图可以得到,只要显示两个border边即可,代码试一下吧

#main {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid red

border-right: 200px solid transparent

border-top: 200px solid transparent

}

效果如图所示:

8.png

2.2.3 钝角三角形

上图证实了之前的想法的可行性了。那么接下来让我们想想钝角三角形该怎么实现呢?按照之前的想法是不行的,那么我们就需要改变一下想法。

我们可以用两个直角三角形,将小的直角三角形覆盖在大的上面,让我们试一下吧!!

<div id="main1"></div>

<div id="main2"></div>

#main1 {

width: 0px

height: 0px

border-bottom: 200px solid red

border-left: 200px solid transparent

}

#main2 {

width: 0px

height: 0px

border-bottom: 200px solid black

border-left: 150px solid transparent

position: absolute

/*这里8px是浏览器中的margin自带的间距,之前没有处理*/

top: 8px

left: 58px

}

效果图如下所示:

9.png

这次通过绝对定位来控制小的直角三角形,那么我们可以通过控制黑色三角形的颜色来显示钝角三角形。

2.3 五边形

三角形都已经学会了,那么很多图形都可以通过三角形拼凑得来,就以五边形为例,这里将以多个三角形来画出五边形。

<div id="wrapper">

<div class="main1 tool"></div>

<div class="main2 tool"></div>

<div class="main3 tool"></div>

<div class="main4 tool"></div>

<div class="main5 tool"></div>

</div>

*{

margin: 0

}

#wrapper {

position: relative

top: 300px

margin-left: 300px

}

.main2 {

transform: rotate(72deg)

}

.main3 {

transform: rotate(144deg)

}

.main4 {

transform: rotate(216deg)

}

.main5 {

transform: rotate(288deg)

}

.tool{

width: 0px

height: 0px

border-right: 58px solid transparent

border-left: 58px solid transparent

border-bottom: 160px solid red

position: absolute

top: 0

left: 0

}

效果如下图所示:

10.png

实现五边形的主要难点在于border的三个边的取值,以及旋转的角度。

2.4 六边形

到目前为止三角行、四、五边形的三种形式都实现了一遍,他们均是通过border来实现的,那么让我们来想一下怎么画出一个六边形,有条件的可以在纸上画画,我们可以把一个五边形分成6个等边三角形,让我们通过上面所学知识来实现一下六边形吧!

<div id="wrapper">

<div class="main1 tool"></div>

<div class="main2 tool"></div>

<div class="main3 tool"></div>

<div class="main4 tool"></div>

<div class="main5 tool"></div>

<div class="main6 tool"></div>

</div>

*{

margin: 0

}

#wrapper {

position: relative

top: 300px

margin-left: 300px

}

.main2 {

transform: rotate(60deg)

}

.main3 {

transform: rotate(120deg)

}

.main4 {

transform: rotate(180deg)

}

.main5 {

transform: rotate(240deg)

}

.main6 {

transform: rotate(300deg)

}

.tool{

width: 0px

height: 0px

border-right: calc(60px / 1.732) solid transparent

border-left: calc(60px / 1.732) solid transparent

border-bottom: 60px solid red

transform-origin: top

position: absolute

top: 0

left: 0

}

11.png

通过上面的方法实现五边形,这边难点主要是画出等边三角形。

上面的方法已经实现了,让我们想想其他的方法实现一下吧,这里我们将通过三个四边形实现五边形,让我们一下实验一下吧!!

<div id="wrapper">

<div class="main1 tool"></div>

<div class="main2 tool"></div>

<div class="main3 tool"></div>

</div>

*{

margin: 0

}

#wrapper {

position: relative

top: 300px

margin-left: 300px

}

.main1 {

width: calc(120px / 1.732)

height: 120px

background-color: black

}

.main2 {

width: calc(120px / 1.732)

height: 120px

transform: rotate(120deg)

background-color: black

}

.main3 {

width: calc(120px / 1.732)

height: 120px

transform: rotate(240deg)

background-color: black

}

.tool{

position: absolute

top: 0

left: 0

}

12.png

好了,目前已经讲述了三角形,四边形,五边形,六边形得到实现方式了,更高的实现方式就以此类推了。

原文地址:https://juejin.cn/post/7001772184498601991

作者:执鸢者

更多编程相关知识,请访问:编程入门!!

以上就是css常见问题:如何画多边形(三角形~六边形)的详细内容,更多请关注php中文网其它相关文章!

声明:本文转载于:掘金--执鸢者,如有侵犯,请联系admin@php.cn删除

专题推荐:css多边形三角形四边形五边形六边形

上一篇:深入浅出解析css字体图标的制作和使用(代码分享) 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

相关文章推荐

• 如何使用HTML5+CSS3动态画一个笑脸

• 炫酷!CSS创建响应式堆叠卡片悬停效果

• 让网站更酷炫的CSS filter使用小技巧,值得收藏!

• 中秋献礼,分享一个CSS日地月公转动画效果!

技术外包,人才推荐

相关课程推荐

CSS3进阶视频教程

《CSS3进阶视频教程》本课程是由北风网录制,CSS3是CSS技术的升级版本,CSS3语言开发是朝着模块化发展的。以前的规范作为一个模块实在是太庞大而且比较复杂,所以,把它分解为一些小的模块,更多新的模块也被加入进来。这些模块包括: 盒子模型、列表模块、超链接方式 、语言模块 、背景和边框 、文字特效 、多栏布局等。

CSS3教程9235次播放

CSS3精讲视频教程

《CSS3精讲视频教程》本课程是由北风网录制,CSS3是CSS技术的升级版本,CSS3语言开发是朝着模块化发展的。以前的规范作为一个模块实在是太庞大而且比较复杂,所以,把它分解为一些小的模块,更多新的模块也被加入进来。这些模块包括: 盒子模型、列表模块、超链接方式 、语言模块 、背景和边框 、文字特效 、多栏布局等。

CSS3教程7348次播放

让布局像5G一样快:CSS Grid网格布局

Grid (网格布局): 在CSS中第一个真正意义上的布局技术, 也是CSS布局的巅峰之作, 彻底告别一维模式, 一步跨入全新的二维空间布局新时代....

CSS教程9249次播放

新独孤九贱之:CSS3 必知内容

CSS3与HTML5构成了页面的基础, 与HTML5相比, CSS3的作用更强大通常我们使用html5书写页面结构,而css3可以帮助我们完成页面元素的样式设置和元素布局,还可以完成一些动画特效

CSS教程7944次播放

最通俗易懂的html+css课程 9天速成

HTML是一种规范,一种标准,它通过标记符号来标记要显示的网页中的各个部分。CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。

HTML教程13055次播放

首页

视频

直播

社区

我的

2021年2月19日学习笔记

【椭圆】

【半椭圆】

沿纵轴对称,如果传4个值,分别从左上角开始以顺时针应用到各个拐角,如果提供3个值,意味着第4个值与第2个值相同

4个角还可以有不同的水平和垂直半径,在斜杠前指定1~4个值,在斜杠后指定1~4个值

当border-radius: 10px / 5px 20px时,相当于

border-radius: 10px 10px 10px 10px / 5px 20px 5px 20px

【四分之一椭圆】

其中一个角的水平和垂直半径值都需要是100%,而其他三个角都不能设为圆角

【扩展练习】

【平行四边形】

【平行四边形--伪元素】

【八角形】

【菱形】

需要图片的宽度与容器的对角线相等,而max-width: 100%是边长相等

scale()变形样式,是以它的中心点进行缩放的,除非额外指定了transform-origin

通过width属性来放大图片时,只会以它的左上角为原点进行缩放,需要负外边距调整

【裁切路径方案clip-path菱形】

【相关知识点】

clip-path属性 可以防止部分元素通过定义的剪切区域来显示(目前兼容性较差,IE和Edge不支持)

生成器https://www.html.cn/tool/css-clip-path/

一、基本图形

inset()矩形(上右下左的边距round上右下左圆角)

inset()可以传入5个参数,分别对应top,right,bottom,left的裁剪位置,round radius(可选,圆角)

circle圆形

circle()可以传人2个可选参数:

1. 圆的半径,默认元素宽高中短的那个为直径,支持百分比

2. 圆心位置,默认为元素中心点

半径公式

如果半径使用百分比:圆的半径 = (sqrt(width^2+height^2)/sqrt(2)) * 百分比

ellipse椭圆

ellipse()可以传人3个可选参数;

1. 椭圆的X轴半径,默认是宽度的一半,支持百分比

2. 椭圆的Y轴半径,默认是高度的一半,支持百分比

3. 椭圆中心位置,默认是元素的中心点

二、多边形polygon--正三角形

x: 0, y:100% 从元素的左上角开始,并从那里开始移动

x: 50%, y: 0

x: 100%, y: 100%  元素右边,元素底部

从左下角x: 0, y:100%开始,水平移动到50%,然后垂直向上到达顶部的坐标点(第二个点),接着水平移动到100%的位置,最后垂直向下回到底部,到达第三个坐标点

正方形

从左上角开始,垂直向下100%第二个点,平移100%第三个点,垂直向上0第四个点

正五边形  59/(59+95)=38.31%,31/(81*2)=19.14%

162/2 = 81

59是上面三角形的高度

95是下面三角形的高度

31是下面四边形的高度

正六边形  50/(100+50 2)=25%,150/(100+50 2)=75%

50 是左边三角形的高度

100 是边长

正七边形 

22/(100+62 2)=10.09%

202/(100+62 2)=90.18%

43/(43+97+78)=19.72%

(43+97)/(43+97+78)=64.22%

62/(100+62 2)=27.68%

(100+62)/(100+62 2)=72.32%

正八边形

71/(100+71 2)=29.34%

(71+100)/(100+71 2)=70.66%

五角星

红叉叉

标签

也可用于动画中

如果觉得百分比不好计算,可以换算成px

下面就是第一个点的计算方法

35.00%*800=280px

29.75%*400=119px

只要两个 clip-path,其中包含的点个数相同,在animation的帧内部就可以线性切换了

如果不同是没有效果的

小技巧,如果点不够,可以将两个坐标点进行重合即可

推荐网址:

http://species-in-pieces.com/

30个动物全部使用CSS3写的。超牛