资讯专栏INFORMATION COLUMN

css绘制各种各样的形状图形

levinit / 2682人阅读

摘要:我们在编写前端代码时,经常会遇到各种各样的形状图形如边框对话框,三角形,平行四边形圆角边框圆形四叶草花瓣等,除了用背景图片雪碧图或精灵图定位引用和插入图片的方法,我们还可以用边框圆角渐变和定位的方法结合使用,绘制各种各样的形状图形。

我们在编写前端代码时,经常会遇到各种各样的形状图形(如:边框对话框,三角形,平行四边形、圆角边框、圆形、四叶草、花瓣等),除了用背景图片(css雪碧图或css精灵图+定位引用)和插入img图片的方法,我们还可以用css边框、圆角(border-radius)、渐变和定位的方法结合使用,绘制各种各样的形状图形。

1、实心圆

.circle {
    width: 120px;
    height: 120px;
    background: #317ef3;
    border-radius: 100%;
}
2、圆环(空心圆)

.ring {
    width: 120px;
    height: 120px;
    border: 10px solid #317ef3;
    border-radius: 100%;
    box-sizing: border-box;
}
3、半圆

//上半圆
.top-semicircle {
    width: 120px;
    height: 60px;
    background: #317ef3;
    border-radius: 60px 60px 0 0;
    /*顺时针方向,四个值依次分别表示左上、右上、右下、左下*/
}
//右半圆
.rt-semicircle {
    width: 60px;
    height: 120px;
    background: #317ef3;
    border-radius: 0 60px 60px 0;
}

//左半圆
.lf-semicircle {
    width: 60px;
    height: 120px;
    background: #317ef3;
    border-radius: 60px 0 0 60px;
}

//下半圆
.bot-semicircle {
    width: 120px;
    height: 60px;
    background: #317ef3;
    border-radius: 0 0 60px 60px;
}
四分之一圆(扇形)

.toplf-sector,
.toprt-sector,
.botlf-sector,
.botrt-sector {
    width: 60px;
    height: 60px;
    background: #317ef3;
}

.toprt-sector {
    border-radius: 60px 0 0 0;
}

.toplf-sector {
    border-radius: 0 60px 0 0;
}

.botlf-sector {
    border-radius: 0 0 60px 0;
}

.botrt-sector {
    border-radius: 0 0 0 60px;
}
心形

.love {
    width: 100px;
    height: 100px;
    background: #317ef3;
    position: relative;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
}
.love::before,.love:after{
    content: "";
    background: #317ef3;
    position: absolute;
}
.love:after {
    width: 50px;
    height: 100px;
    background: #317ef3;
    border-radius: 50px 0 0 50px;
    right: 99px;
    top: 0;
}

.love::before {
    width: 100px;
    height: 50px;
    border-radius: 50px 50px 0 0;
    bottom: 99px;
    left: 0;
}

原理图奉上

吃豆人

.eat {
    width: 0;
    height: 0;
    border: 60px solid #317ef3;
    border-radius: 100%;
    border-right-color: transparent;
}

值得注意的是如果右边框的颜色设置为白色的话,右边会有一条蓝色线条

鸡蛋

.egg {
    width: 100px;
    height: 150px;
    background: #317ef3;
    border-radius: 50px 50px 50px 50px/90px 90px 60px 60px;
}

原理图奉上:

椭圆

.ellipse1 {
    width: 180px;
    height: 120px;
    background: #317ef3;
    border-radius: 100%;
    /* border-radius: 90px/60px; */
}

.ellipse2 {
    width: 120px;
    height: 180px;
    background: #317ef3;
    border-radius: 100%;
    /* border-radius: 60px/90px; */
}
胶囊

.capsule1 {
    width: 200px;
    height: 100px;
    background: #317ef3;
    border-radius: 50px;
}

.capsule2 {
    width: 100px;
    height: 200px;
    background: #317ef3;
    border-radius: 50px;
}
太极八卦阵图
.taiji {
    width: 120px;
    height: 60px;
    background: #fff;
    border: 2px solid #317ef3;
    border-bottom: 60px solid #317ef3;
    border-radius: 100%;
    position: relative;
}
.taiji::before,.taiji::after{
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 100%;
}
.taiji::before {
    left: 0;
    top: 50%;
    background: #fff;
    border: 20px solid #317ef3;
}

.taiji::after {
    right: 0;
    top: 50%;
    background: #317ef3;
    border: 20px solid #fff;
}
叶子(花瓣)

.leaf1 {
    width: 100px;
    height: 100px;
    background: #317ef3;
    border-radius: 0 100px;
}

.leaf2 {
    width: 100px;
    height: 100px;
    background: #317ef3;
    border-radius: 80px 0px;
}

.leaf3 {
    width: 100px;
    height: 100px;
    background: #317ef3;
    border-radius: 50px 50px 0 50px;
}
五叶花瓣

      
.five-petal {
    width: 160px;
    height: 160px;
}

.five-petal span {
    display: block;
    width: 80px;
    height: 80px;
    background: #317ef3;
    border-radius: 0 100px;
    transform-origin: 100% 100%;
    position: absolute;
}

.five-petal .petal2 {
    transform: rotate(72deg);
}

.five-petal .petal3 {
    transform: rotate(144deg);
}

.five-petal .petal4 {
    transform: rotate(216deg);
}

.five-petal .petal5 {
    transform: rotate(288deg);
}
四叶草

     
        
.four-leaf {
    width: 210px;
    height: 210px;
    position: relative;
}

.four-leaf span {
    display: block;
    width: 100px;
    height: 100px;
    background: #317ef3;
    position: absolute;
}

.four-leaf span.leaf1 {
    left: 0;
    top: 0;
    border-radius: 50px 50px 0 50px;
}

.four-leaf span.leaf2 {
    right: 0;
    top: 0;
    border-radius: 50px 50px 50px 0;
}

.four-leaf span.leaf3 {
    left: 0;
    bottom: 0;
    border-radius: 50px 0 50px 50px;
}

.four-leaf span.leaf4 {
    right: 0;
    bottom: 0;
    border-radius: 0 50px 50px 50px;
}
无穷符号

     
.infinite {
    width: 250px;
    position: relative;
}

.infinite span {
    width: 100px;
    height: 100px;
    background: #fff;
    border: 2px solid #317ef3;
    position: absolute;
}

.infinite .lf {
    border-radius: 50px 50px 0 50px;
    transform: rotate(-45deg);
    left: 0;
}

.infinite .rt {
    border-radius: 50px 50px 50px 0;
    transform: rotate(45deg);
    right: 0;
}
小尾巴

.xwb1 {
    width: 100px;
    height: 60px;
    border-top: 20px solid #317ef3;
    border-radius: 0 60px 0 0;
}

.xwb2 {
    width: 100px;
    height: 60px;
    border-left: 20px solid #317ef3;
    border-radius: 60px 0 0 0;
}
月亮

.moon {
    width: 100px;
    height: 100px;
    border-left: 30px solid #317ef3;
    border-radius: 50px 0 0 50px;
}
立体球型

.litiqiuxing1 {
    width: 100px;
    height: 100px;
    border-radius: 100%;
    background: #317ef3;
    background: radial-gradient(circle at 25% 35%, #fff, #317ef3, #071529);
}

.litiqiuxing2 {
    width: 100px;
    height: 100px;
    border-radius: 100%;
    background: #317ef3;
    background: radial-gradient(circle at top, #fff, #317ef3, #071529)
}

.litiqiuxing3 {
    width: 100px;
    height: 100px;
    border-radius: 100%;
    background: #317ef3;
    background: radial-gradient(circle at left top, #fff 10%, #78a8f2 30%, #0b59ca 60%, #04409a 80%, #202b3a 100%)
}
三角形实现原理

.triangle-shiyi {
    width: 0;
    height: 0;
    border: 50px solid #317ef3;
    border-left-color: red;
    border-top-color: aquamarine;
    border-right-color: bisque;
}
等腰直角三角

.dbzj-sanjiao1 {
    width: 0;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-right: 100px solid transparent;
}

.dbzj-sanjiao2 {
    width: 0;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-left: 100px solid transparent;
}

.dbzj-sanjiao3 {
    width: 0;
    height: 0;
    border-top: 100px solid #317ef3;
    border-right: 100px solid transparent;
}

.dbzj-sanjiao4 {
    width: 0;
    height: 0;
    border-top: 100px solid #317ef3;
    border-left: 100px solid transparent;
}

.dbzj-sanjiao5 {
    width: 0;
    height: 0;
    border-bottom: 50px solid #317ef3;
    border-left: 100px solid transparent;
    /* border-left、border-right决定宽度 */
    /* border-top、border-bottom决定高度 */
}

.dbzj-sanjiao6 {
    width: 0;
    height: 0;
    border-bottom: 50px solid #317ef3;
    border-right: 100px solid transparent;
}

.dbzj-sanjiao7 {
    width: 0;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-right: 50px solid transparent;
}

.dbzj-sanjiao8 {
    width: 0;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-left: 50px solid transparent;
}

.dbzj-sanjiao9 {
    width: 0;
    height: 0;
    border-top: 50px solid #317ef3;
    border-right: 100px solid transparent;
}

.dbzj-sanjiao10 {
    width: 0;
    height: 0;
    border-top: 50px solid #317ef3;
    border-left: 100px solid transparent;
}
锐角三角形

.dbzj-sanjiao11 {
    width: 0;
    height: 0;
    border-left: 40px solid transparent;
    border-right: 40px solid transparent;
    border-bottom: 100px solid #317ef3;
    /*三角形的宽度w=left+right,h=bottom*/
}
钝角三角形

.dbzj-sanjiao12 {
    width: 0;
    height: 0;
    border-bottom: 50px solid #317ef3;
    border-right: 100px solid transparent;
    position: relative;
}

.dbzj-sanjiao12::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    border-bottom: 50px solid #fff;
    border-right: 20px solid transparent;
}
平行四边形

.pxsbx1 {
    width: 200px;
    height: 120px;
    background: #317ef3;
    color: #fff;
    text-align: center;
    line-height: 120px;
    font-size: 18px;
    transform: skewX(30deg);
}

.pxsbx2 {
    width: 200px;
    height: 120px;
    text-align: center;
    line-height: 120px;
    position: relative;
    font-size: 18px;
    color: #fff;
}

.pxsbx2::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
    width: 200px;
    height: 120px;
    background: #317ef3;
    transform: skewX(30deg);
}

与上面的平行四边形相比,可以看到该图形中的文字不会发生倾斜,方法是在文字层后添加一个伪元素绘制平行四边。

.pxsbx3 {
    width: 100px;
    height: 160px;
    background: #317ef3;
    transform: skewY(30deg);
}

.pxsbx4 {
    width: 100px;
    height: 160px;
    background: #317ef3;
    transform: skewY(-30deg);
}
梯形

.tixing1 {
    width: 100px;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-left: 50px solid transparent;
    border-right: 50px solid transparent;
}

.tixing2 {
    width: 100px;
    height: 100px;
    background: #317ef3;
    position: relative;
}

.tixing2::before {
    content: "";
    width: 0;
    height: 0;
    border-bottom: 100px solid #317ef3;
    border-right: 50px solid transparent;
    position: absolute;
    left: 100%;
    top: 0;
}
边框对话框

.duihuakuang1 {
    width: 200px;
    height: 120px;
    border: 2px solid #317ef3;
    position: relative;
}

.duihuakuang1::before {
    content: "";
    position: absolute;
    left: 40px;
    top: 92%;
    width: 20px;
    height: 20px;
    border-right: 2px solid #317ef3;
    border-bottom: 2px solid #317ef3;
    transform: rotate(45deg);
    background: #fff;
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/116992.html

相关文章

  • css绘制各种各样形状图形

    摘要:我们在编写前端代码时,经常会遇到各种各样的形状图形如边框对话框,三角形,平行四边形圆角边框圆形四叶草花瓣等,除了用背景图片雪碧图或精灵图定位引用和插入图片的方法,我们还可以用边框圆角渐变和定位的方法结合使用,绘制各种各样的形状图形。 我们在编写前端代码时,经常会遇到各种各样的形状图形(如:边框对话框,三角形,平行四边形、圆角边框、圆形、四叶草、花瓣等),除了用背景图片(css雪碧图或c...

    mingde 评论0 收藏0
  • css绘制各种形状图形(第二版)

    摘要:虽然我们现在大都使用字体图标或者图片,似乎使用来做图标意义不是很大,但怎么实现这些图标用到的一些技巧及思路是很值得我们的学习。 虽然我们现在大都使用字体图标或者svg图片,似乎使用 CSS 来做图标意义不是很大,但怎么实现这些图标用到的一些技巧及思路是很值得我们的学习。 一、实心圆 showImg(https://segmentfault.com/img/bVbsV6v?w=171&h...

    CoreDump 评论0 收藏0
  • css绘制各种形状图形(第二版)

    摘要:虽然我们现在大都使用字体图标或者图片,似乎使用来做图标意义不是很大,但怎么实现这些图标用到的一些技巧及思路是很值得我们的学习。 虽然我们现在大都使用字体图标或者svg图片,似乎使用 CSS 来做图标意义不是很大,但怎么实现这些图标用到的一些技巧及思路是很值得我们的学习。 一、实心圆 showImg(https://segmentfault.com/img/bVbsV6v?w=171&h...

    yibinnn 评论0 收藏0
  • 翻译 | 编写SVG口袋指南(上)

    摘要:元素元素归属于容器和结构元素,在文档内允许嵌套使用独立的片段。如果包含葡萄的组被移动到文档的末尾,它将出现在西瓜的前面。例如,将葡萄的茎的路径移动到组的末尾将导致茎在顶部。 作者:DDU(沪江前端开发工程师)本文是原文翻译,转载请注明作者及出处。 简介 Scalable Vector Graphics (SVG)是在XML中描述二维图形的语言。这些图形由路径,图片和(或)文本组成,并能...

    Brenner 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<