纯CSS绘制图形的三种方法

绘制图形

第一种方式:使用裁剪可视区的方式显示

clip-path

该属性使用裁剪方式创建元素的可显示区域,区域内的显示,区域外的不显示。

比如:构建一个三角形

   <div class="mybox"></div>
    <style>
        .mybox {
    width: 100px;
    height: 100px;
    background-color: yellow;
    clip-path: polygon(0% 0%,100% 0%,0% 100%);
}
    </style>

结果为:

image.png

该属性的使用:
属性值可以是函数:
circle:绘制圆
ellipse:绘制椭圆
polygon:绘制多边形
path: 用来定义形状的通用元素,所有的基本形状都可以用path来创建,是一种svg路径。

  • circle

只指明半径,其中半径可以是百分比或者是数值,此时圆心默认为元素中心

.mybox {
    width: 100px;
    height: 100px;
    background-color: yellow;
    clip-path: circle(50%);
}
image.png

指明圆心,使用at标识符
此时,可以绘制圆的任意部分

.mybox {
    width: 100px;
    height: 100px;
    background-color: yellow;
    clip-path: circle(50% at 100% 100%);
}
image.png

使用场景:需要绘制与圆弧相关的图形

  • ellipse
    需要同时指明横轴、竖轴、以及轴中心
    第一个参数表示横轴长度,第二个参数表示竖轴长度
    轴中心使用坐标表示,与横竖轴之间使用at连接

比如:

.mybox {
    width: 100px;
    height: 100px;
    background-color: yellow;
    clip-path: ellipse(50% 100% at 100% 100%);
}
image.png

其实只要合理运用横竖轴的长度,其作用还可以类比于圆的功能

使用场景:绘制有圆弧的图形

  • polygon
    由于多边形是由点线组成,如果需要形成一个图形,至少需要三个点构成一个面,点之间相互连接

比如:

.mybox {
    width: 100px;
    height: 100px;
    background-color: yellow;
    clip-path: polygon(0% 0%,100% 0%,0% 100%);
}
image.png

使用场景:需要绘制线条形状的图形

  • path

类似canvas绘图
用一串字符串来表示,其中常用的参数有:

  • moveTo(m|M)
    表明鼠标抬起,需要落到的点,不会绘制线条,只用于改变画笔的位置。如果最开始绘制的时候不指明,则默认是上一个点的位置

  • LineTo(L|l)
    画笔需要到达的下一个点的位置,会绘制线条,上一个点与当前所处的点会连接成一条线。

  • ClosePath(z|Z)
    从当前点到第一个点绘制一条线,主要用于闭合所绘制的图形。

以上参数一般使用其的缩写,但是有一点需要注意的是,除了(z|Z)外,参数大小写敏感
大写字母表示绝对位置,小写字母表示相对位置,相对于上一个点的位置。

例子:绘制一个T形

.mybox {
    width: 600px;
    height: 600px;
    background-color: yellow;
    clip-path: path('M 100 100 L 400 100 L 400 200 L 275 200 L 275 500 L 225 500 L 225 200 L 100 200 z');
}
image.png

以上属性常用来绘制多边形状的图形,还有一些其他属性可以用来绘制除多边形以外的其他图形,用途场景很多。


总结:

属性 场景
circle 含有圆弧图形
ellipse 含有圆弧图形
polygon 多边形
path 任意图形

第二种方式:使用border属性来绘制

该方式只能绘制与三角形有关的图形,比如:三角形、梯形、以及他们之间的组合。
border这个属性涉及到三个属性,分别是:
border-color:边框颜色
border-style:边框样式
border-width:边框宽度

以上三个属性可以分别对left right bottom top进行设置,而border是对以上三个属性的总写。

设置border的属性,可以看出,如果在不设置元素的width/height的情况下,元素的border是由四个三角形组成

image.png

代码如下:

<div class="test"></div>

<style>
    .test {
    width: 0;
    height: 0;
    border-style: solid;
    border-color: red yellow khaki hotpink;
    border-width: 30px;
}
</style>

比如:绘制向右的三角形,此时只需要左边框保留,其余边框透明即可

image.png
<div class="test"></div>

<style>
    .test {
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent transparent transparent hotpink;
    border-width: 30px;
}
</style>

由于相邻两个三角形可以组成一个斜着的三角形,所以保留相邻的边框,便可以实现效果:

image.png
<div class="test"></div>

<style>
    .test {
    width: 0;
    height: 0;
    border-style: solid;
    border-color: yellow transparent transparent yellow;
    border-width: 30px;
}
</style>

以上都是元素width/height为0的情况,如果设置width不为0,便可以得到一个梯形。
原因:盒子模型中content区域被撑开,使得其边框向四周扩散
比如:

image.png
<div class="test"></div>

<style>
    .test {
    width: 40px;
    height: 40px;
    border-style: solid;
    border-color: red yellow skyblue yellow;
    border-width: 30px;
}
</style>

所以从以上的思路可以衍生,我们可以利用这一点绘制梯形:
比如:一个正放的梯形

image.png
<div class="test"></div>

<style>
    .test {
    width: 40px;
    height: 0;
    border-style: solid;
    border-color: transparent transparent skyblue transparent;
    border-width: 30px;
}
</style>

可以看到这里height设置为0,我的理解就是减少多余的留白,本来使用border属性绘制图形,利用的就是border的其他边透明,但是实际上边还是存在的,而如果加上了height,留白便会增加。

小的案例:
步骤条:利用border属性完成

image.png
        <div class="step">
            <div class="chess leftrevel">
                <span>热卖<i></i></span>
            </div>
            <div class="chess">
                <span>热卖<i></i></span>
            </div>
            <div class="chess">
                <span>热卖 <i class="isrevel"></i></span>
            </div>
        </div>
        
        <style>
            .step {
    display: flex;
    .chess {
        width: 0;
        width: 0;
        margin-right:20px;
        border-style: solid;
        border-width: 25px 150px  25px 20px;
        border-color: #d7d7d7 #d7d7d7 #d7d7d7 transparent;
        position: relative;
        &.leftrevel{
            border-color: #ff6600;
            & i {
                border-left-color: #ff6600;
            }

            & span {
                color: white;
            }
        }

        & span {
            position: absolute;
            bottom: -10px;
            right: -50px;
            font-size: 18px;
            color: #5a5a5a;
            i {
                position: absolute;
                right: -150px;
                top: -12px;
                border-style: solid;
                border-width: 25px;
                border-color: transparent transparent transparent #d7d7d7;
            }

            .isrevel {
                display: none;
            }
        }


    }
}
        </style>

第三种方法:svg路径

利用path元素定义形状,所有的基本形状都可以使用该元素来创建。
比如:正方形

image.png
<svg width="600px" height="600px" viewBox="-300 -300 600 600">
   <path d="M 0 0 L 200 0 L 200 200 L 0 200 z" fill="#e94242"></path>
</svg>

其中d指明如何去绘制,fill指明填充区域的颜色

更复杂的使用还待研究

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352