返回顶部
首页 > 资讯 > 前端开发 > node.js >css中怎么画多边形
  • 318
分享到

css中怎么画多边形

2024-04-02 19:04:59 318人浏览 安东尼
摘要

这篇文章主要为大家展示了“CSS中怎么画多边形”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中怎么画多边形”这篇文章吧。一、基础知识储备由上图可以看出标准

这篇文章主要为大家展示了“CSS中怎么画多边形”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中怎么画多边形”这篇文章吧。

一、基础知识储备

css中怎么画多边形

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

<!--html部分,此部分代码若是不变,后面将复用不在赘述-->
<div id="main"></div>
 
#main { 
  width: 100px;
  height: 100px;
  border: 200px solid red; 
}

效果图如下:

css中怎么画多边形

二、实战

光说不练假把式,现在就由利用这些基本的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;
}

效果如下图所示:

css中怎么画多边形

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;
}

效果如下图所示:

css中怎么画多边形

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;
}

效果如下图所示:

css中怎么画多边形

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;
}

效果图如下:

css中怎么画多边形

从图可以看出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;
}

效果如图所示:

css中怎么画多边形

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;
}

效果如图所示:

css中怎么画多边形

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;
  
  top: 8px;
  left: 58px;
}

效果图如下所示:

css中怎么画多边形

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

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;
}

效果如下图所示:

css中怎么画多边形

实现五边形的主要难点在于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;
}

css中怎么画多边形

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

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

<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;
}

css中怎么画多边形

以上是“css中怎么画多边形”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网node.js频道!

--结束END--

本文标题: css中怎么画多边形

本文链接: https://lsjlt.com/news/81496.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • css中怎么画多边形
    这篇文章主要为大家展示了“css中怎么画多边形”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中怎么画多边形”这篇文章吧。一、基础知识储备由上图可以看出标准...
    99+
    2024-04-02
  • PHP画一个多边形
    这篇文章将为大家详细讲解有关PHP画一个多边形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PHP 中绘制多边形 简介 多边形是一种具有多个直边的封闭几何形状。在 PHP 中,可以通过使用 GD 库的图像...
    99+
    2024-04-02
  • 如何使用SVG 画多边形
    这篇文章主要讲解了“如何使用SVG 画多边形”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用SVG 画多边形”吧!一、 Polygon 画多边形简单的...
    99+
    2024-04-02
  • PHP画一多边形并填充
    这篇文章将为大家详细讲解有关PHP画一多边形并填充,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PHP 绘制和填充多边形 简介 PHP GD 库提供了一组功能用于在图像上绘制和填充多边形。以下指南将介绍如...
    99+
    2024-04-02
  • Flutter绘制3.4边形及多边形渐变动画实现示例
    目录正文绘制3.4边形整数边形的绘制分数边形的绘制具体代码效果改进1效果改进2正文 项目被优化了,人也跟着被优化了,正好趁这一个月整理整理关于flutter的一些东西。 绘制3.4边...
    99+
    2022-11-13
    Flutter绘制3.4边形渐变动画 Flutter绘制渐变动画
  • css实现多边形的方法
    这篇文章主要介绍“css实现多边形的方法”,在日常操作中,相信很多人在css实现多边形的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css实现多边形的方法”的疑惑有所帮...
    99+
    2024-04-02
  • CSS怎么构建变形边框
    本篇内容介绍了“CSS怎么构建变形边框”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!border基础回顾b...
    99+
    2024-04-02
  • css圆形边框怎么设置
    通过使用 css 中的 border-radius 属性,可以轻松地为元素设置圆形边框:定义 border-radius 属性的值为水平半径和垂直半径,以设置圆角程度。使用百分比值来指定...
    99+
    2024-05-21
    css
  • css如何实现多边形和梯形盒阴影
    小编给大家分享一下css如何实现多边形和梯形盒阴影,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一般情况下,我们给块状元素(四边形)添加阴影样式,直接用css box-shadow: 0 1px 3px 0 rgba(0,...
    99+
    2023-06-08
  • CSS怎么实现平行四边形
    这篇文章主要介绍CSS怎么实现平行四边形,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:先上效果图平行四边形可以用做导航栏部分。原理:利用transform属性拉伸矩形。CSS代码transform:&nbs...
    99+
    2023-06-08
  • Android 多边形导圆角(Path画折线导圆角)
    前言:用path画折线,2条线相交处导圆角 简介:为开发者提供工具类,方便对使用path画折线设置圆角。使用path画多边形,如三角形、矩形、平行四边形等,同时设置圆角。另外提供计算直线上某点坐标。 实现原理 三个点,2条直线相交,给中间...
    99+
    2023-10-10
    android path 圆角
  • 基于OpenCV实现动态画矩形和多边形并保存坐标
    目录1 画矩形和多边形,模式通过键盘控制2 修改后默认情况下直接画多边形,按鼠标中键切换为画矩形模式现在画矩形和多边形一次只能画一个,还需要修改让其一次可画多个? 1 画矩形和多边形...
    99+
    2023-03-23
    OpenCV绘制矩形 多边形 OpenCV绘制矩形 OpenCV绘制多边形
  • 怎么用HTML5 Canvas绘制三角形和矩形等多边形
    本篇内容介绍了“怎么用HTML5 Canvas绘制三角形和矩形等多边形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够...
    99+
    2024-04-02
  • CSS中怎么实现多重边框效果
    本篇文章为大家展示了CSS中怎么实现多重边框效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1 利用描边(outline)属性方案1利用描边(outline)属性...
    99+
    2024-04-02
  • 利用canvas怎么绘制一个多边形
    利用canvas怎么绘制一个多边形?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 初始化js代码  //初始化  (function()...
    99+
    2023-06-09
  • 怎么用css绘制蜂巢六边形效果
    本篇内容介绍了“怎么用css绘制蜂巢六边形效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!undefin...
    99+
    2024-04-02
  • CSS中怎么绘制曲线图形及展示动画
    这篇文章主要介绍CSS中怎么绘制曲线图形及展示动画,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!理解 box-shadow首先,回顾一下box-shadow这个属性。基本属性用法就是给元素创造一层阴影。再简单提一下,...
    99+
    2023-06-15
  • 基于OpenCV如何实现动态画矩形和多边形并保存坐标
    这篇文章主要讲解了“基于OpenCV如何实现动态画矩形和多边形并保存坐标”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于OpenCV如何实现动态画矩形和多边形并保存坐标”吧!1 画矩形和多...
    99+
    2023-07-05
  • CSS怎么实现心形加载的动画
    本文将为大家详细介绍“CSS怎么实现心形加载的动画”,内容步骤清晰详细,细节处理妥当,而小编每天都会更新不同的知识点,希望这篇“CSS怎么实现心形加载的动画”能够给你意想不到的收获,请大家跟着小编的思路慢慢深入,具体内容如下,一起去收获新知...
    99+
    2023-06-08
  • CSS中怎么实现多重背景动画
    CSS中怎么实现多重背景动画,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。CSS代码给一个页面元素设置多个背景图片,这种技术很早就可行了,你只...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作