如何使用CSS来制作图形,比如说圆形,半圆形,三角形等。今天我特意在网上查阅了一下,介绍这样的教程还是蛮多的,因此我也决定整理一份相关教程出来与大家一起分享。

如何工作?

很少会有人意识到,当浏览器绘制的border,会有一个角度的问题。我们就是得用这样的一个技巧来制作三角的效果。我们只需要保证一边的边框是有色,其他边框色为透明色,这样我们就很容易制作出三角形,然后改变其大小来实现不同的效果。我们一起来看一段代码:

1
2
3
4
5
6
7

.css-arrow-multicolor {
border-color: red green blue orange;
border-style:solid;
border-width:20px;
width:0;
height:0;
}

正如你看到的上面代码段是使用border制作的四个三角形,这些三角形都是直角三角形边界大小,如果你改变border-width的大小,你将得到的是另一个三角形

1
2
3
4
5
6
7

.css-arrow-acute {
border-color: red green blue orange;
border-style:solid;
border-width:25px 10px 15px 30px;
width:0;
height:0;
}

当你改变border-style时,你会发现一些很神的效果:

border-style: dotted;

但这种创意在不同的浏览器下并是支持的。

下面我们一起来通过代码,看看不同类型的制作方法

一、正方形(Square)

1
2
3
4
5

#square {
width: 100px;
height: 100px;
background: red;
}

正方形是最简单的了,只需要保证元素的宽度和高度相同,这样就OK了。当然我们还可以使用border直接绘制正方形,具体如何绘制大家可以动脑想想,我就不写了,不过使用border绘制正方形,里面不能填充内容的哟。

效果:

二、长方形(Rectangle)

1
2
3
4
5

#rectangle {
width: 200px;
height: 100px;
background: red;
}

在正方形的基础上改变他们的大小,确保width和height值不相同就行了。

效果:

三、圆形(Circle)

1
2
3
4
5
6
7
8

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

效果:

圆形的制作,我们采用的是CSS3中的border-radius属性。在制作过程中,有几点需要注意,其一宽度和高度值相同,其二圆角值为宽度或高度值的一半。也有地方提使用设置圆角值为50%,但我在Webkit中有碰到过不支持百分数的情况。

四、半圆形(Semicircle)

1
2
3
4
5
6
7
8

#semicircle{
width: 100px;
height: 50px;
background: red;
-moz-border-radius: 100px 100px 0 0;
-webkit-border-radius:  100px 100px 0 0;
border-radius:  100px 100px 0 0;
}

制作半圆和圆使用的方法是一样的,但需要配合元素的高度,宽度以及圆角的方位,制作出半圆形效果。

效果:

五、扇形(Fan-Shaped)

1
2
3
4
5
6
7
8

#fanShaped {
background: none repeat scroll 0 0 red;
-webkit-border-radius: 50px 0 0 0;
-moz-border-radius: 50px 0 0 0;
border-radius: 50px 0 0 0;
height: 50px;
width: 50px;
}

扇形在这里也就是四分之一圆效果,在制作四分之一圆和制作半圆形一样的,我们需要配合的就是元素的三个属性值,具体大家可以参考上面的代码。

效果:

六、椭圆形(Oval)

1
2
3
4
5
6
7
8

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

这里使用了border-radius的X/Y两轴取值,制作出一种变形的圆角,在配合宽度等值,就制作了类似椭圆形的一个效果。

效果:

七、三角效果(Triangle)

教程起就是说的三角效果,这里不在说是如何实现的,我在这里列出几种常见的三角形代码,仅供大家参考

1、三角朝上

1
2
3
4
5
6

#triangle-up {
width: 0;
height: 0;
border: 50px solid red;
border-color: transparent transparent transparent red;}
border-bottom设置颜色

2、三角朝下

1
2
3
4
5
6
7

#triangle-down {
width: 0;
height: 0;
border: 50px solid red;
border-color: red transparent transparent;
}
border-top设置颜色

3、三角向左

1
2
3
4
5
6
7

#triangle-left {
width: 0;
height: 0;
border: 50px solid red;
border-color: transparent red transparent  transparent;
}
border-right设置颜色

4、三角向右

1
2
3
4
5
6
7

#triangle-right {
width: 0;
height: 0;
border: 50px solid red;
border-color: transparent transparent transparent red;
}
border-left设置颜色

5、左上三角形

1
2
3
4
5
6

#triangle-topleft {
width: 0;
height: 0;
border: 100px solid red;
border-color: red transparent transparent red;
}

设置顶部和左边的颜色值。

6、右上三角

1
2
3
4
5
6

#triangle-topright {
width: 0;
height: 0;
border: 100px solid red;
border-color: red red transparent transparent;
}

元素顶部和右边设置边框色

7、左下三角

1
2
3
4
5
6

#triangle-bottomleft {
width: 0;
height: 0;
border: 100px solid red;
border-color: transparent transparent red red;
}

元素底部和左边设置边框颜色

8、右下三角

1
2
3
4
5
6

#triangle-bottomright {
width: 0;
height: 0;
border: 100px solid red;
border-color: transparent red  red transparent;
}

元素右边和底部设置边框颜色。

效果:

有关于三角形的制作,大家可以参考:《Creating Triangles in CSS》、《How to Create p Shapes Like Triangles and Circles 》、《CSS三角形的方法》、《Using borders to produce angled shapes》等。

八、平行四边形(Parallelogram)

1
2
3
4
5
6
7
8
9

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

平行四边形是在矩形的基础上运用了一个CSS3的transform属性。使用了变形效果。

效果:

九、六角星

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

#star-six {
width: 0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-bottom: 100px solid red;
position: relative;
}
#star-six:after {
width: 0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-top: 100px solid red;
position: absolute;
content: "";
top: 30px;
left: -50px;
}

这个六角星是使用了一个“:after”制作了另一个反方向的三角形,在定位层叠到一起,从而形成六角星,说白一点就是两个三角拼在一起变成了六角星。

效果:

十、五角星

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51

#star-five {
margin: 50px 0;
position: relative;
display: block;
color: red;
width: 0px;
height: 0px;
border-right: 100px solid transparent;
border-bottom: 70px solid red;
border-left: 100px solid transparent;
-moz-transform: rotate(35deg);
-webkit-transform: rotate(35deg);
-ms-transform: rotate(35deg);
-o-transform: rotate(35deg);
transform: rotate(35deg);
}
#star-five:before {
border-bottom: 80px solid red;
border-left: 30px solid transparent;
border-right: 30px solid transparent;
position: absolute;
height: 0;
width: 0;
top: -45px;
left: -65px;
display: block;
content: '';
-webkit-transform: rotate(-35deg);
-moz-transform: rotate(-35deg);
-ms-transform: rotate(-35deg);
-o-transform: rotate(-35deg);
transform: rotate(-35deg);
}
#star-five:after {
position: absolute;
display: block;
color: red;
top: 3px;
left: -105px;
width: 0px;
height: 0px;
border-right: 100px solid transparent;
border-bottom: 70px solid red;
border-left: 100px solid transparent;
-webkit-transform: rotate(-70deg);
-moz-transform: rotate(-70deg);
-ms-transform: rotate(-70deg);
-o-transform: rotate(-70deg);
transform: rotate(-70deg);
content: '';
}

五角星制作,大家可以参考Kit MacAllister写的《CSS Only 5-Point Star》一文。

效果:

十一、心形

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37

.heart{
    width:160px;
    height:200px;
    position:relative
}
.heart:before{
    content:" ";
    border: 0 solid transparent;
    -moz-border-radius:100px;
    -webkit-border-radius:100px;
    border-radius:100px 100px 0 0;
    width:80px; height:120px;
    background:#669;
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    position:absolute;
    left:20px;
}
.heart:after{
    content:" ";
    border: 0 solid transparent;
    -moz-border-radius:100px;
    -webkit-border-radius:100px;
    border-radius:100px 100px 0 0;
    width:80px;
    height:120px;
    background:#669;
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    position:absolute;
    left:48px;
    top:0px;
}

效果:

十二、Pac-Man

1
2
3
4
5
6
7
8
9

#pac-man {
width: 0px;
height: 0px;
border: 60px solid red;
border-color: red transparent red red ;
-moz-border-radius: 60px;
-webkit-border-radius: 60px;
border-radius: 60px;
}

效果:

十三、对话泡泡(Talk Bubble)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

#talkbubble {
width: 120px;
height: 80px;
background: red;
position: relative;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
border-radius: 10px;
}
#talkbubble:before {
content:"";
position: absolute;
right: 100%;
top: 26px;
width: 0;
height: 0;
border-top: 13px solid transparent;
border-right: 26px solid red;
border-bottom: 13px solid transparent;
}

有关于更多的对话泡泡的制作,大家还可以参考Nicolas的《Pure CSS speech bubbles》。

效果:

十四、Point Burst

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30

#burst-12 {
background: red;
width: 80px;
height: 80px;
position: relative;
text-align: center;
}
#burst-12:before,
#burst-12:after {
content: "";
position: absolute;
top: 0; left: 0;
height: 80px;
width: 80px;
background: red;
}
#burst-12:before {
-webkit-transform: rotate(30deg);
-moz-transform: rotate(30deg);
-ms-transform: rotate(30deg);
-o-transform: rotate(30deg);
transform: rotate(30deg);
}
#burst-12:after {
-webkit-transform: rotate(60deg);
-moz-transform: rotate(60deg);
-ms-transform: rotate(60deg);
-o-transform: rotate(60deg);
transform: rotate(60deg);
}

效果:

十五、阴阳图

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33

#yin-yang {
width: 96px;
height: 48px;
background: #eee;
border-color: red;
border-style: solid;
border-width: 2px 2px 50px 2px;
border-radius: 100%;
position: relative;
}
#yin-yang:before {
content: "";
position:
absolute;
top: 50%;
left: 0;
background: #eee;
border: 18px solid red;
border-radius: 100%;
width: 12px;
height: 12px;
}
#yin-yang:after {
content: "";
position: absolute;
top: 50%;
left: 50%;
background: red;
border: 18px solid #eee;
border-radius:100%;
width: 12px;
height: 12px;
}

效果:

上面的图形都是彩用CSS或者部分采用了CSS3的属性制作出来的,是不是很有意思呀,如果你喜欢这样的教程,大家还可以点击CSS3-Tricks提供的《The Shapes of CSS》里面展示了十多种图形的制作方法。由于部分图形效果使用了CSS3的部分属性,如果你还在使用IE的话,我建议你使用现代浏览器,比如:Mozilla Firefox、Google Chrome、Safari、Opera。上面展示的效果可能部分实用性不大,但是使用css制作三角和圆有效果应用还是很多了,特别是用来制作tips效果。

css3绘制各种图形效果相关推荐

  1. CSS3绘制不规则图形(一)

    由于近期的项目中出现了不规则的边框和图形, 所以只好提前先温习一下,以前收集的一些CSS3绘制的图形...样式绘制的图形比图片的性能要好,体验更佳. 废话不多说,我们直接看效果: 1.三角形系列(三角 ...

  2. html怎么设置不规则图形,CSS3绘制不规则图形的一些方法示例

    前言 CSS 创建复杂图形的技术即将会被广泛支持,并且应用到实际项目中.本篇文章的目的是为大家开启它的冰山一角.我希望这篇文章能让你对不规则图形有一个初步的了解. 现在,我们已经可以使用CSS 3 常 ...

  3. html如何绘制棒棒糖,CSS3绘制好玩ICON-有棒棒糖转转效果哦

    CSS3可以用来实现很多很棒的UI效果,包括样式上的提升以及动画效果方面的改善.有很多文章讲述了如何用纯CSS画出一些基本的图形,比如说各种形状的三角形,具体可见文末参考资料3中的<The Sh ...

  4. css3绘制八卦图及动画效果

    原理很简单,就是外面加个盒子box.作为旋转动画的box,然后里面分别利用两个div使用css3的 border-radius绘制半圆,分别定位在上下中间对齐两个位置,里面在放两个小的原点水平和垂直方 ...

  5. 线性箭头用css3,css3实现小箭头各种图形效果

    css实现各种图形真是太赞了,再也不用切图了,直接用css就可以实现. 最常用的就是用css实现的小三角了 #triangle-up{ display:inline-block; width:0; h ...

  6. css3控制html中图片,精选4款用纯CSS3绘制的有趣图形

    今天我们要来分享一些设计非常独特的人物和动物动画效果,它们都是通过HTML5和CSS3制作而成,有一些动画是利用纯CSS3实现的,一起来看看. 1.纯CSS3绘制可爱的蚱蜢 今天我们要分享一个利用纯C ...

  7. css3绘制黑色可爱的小猫咪和爱心图形动画特效

    这个是用css3绘制黑色可爱的小猫咪,如果喜欢的你们可以试一下哦~ html代码 <body> <div class="container"><div ...

  8. 纯CSS制作的图形效果

    纯CSS制作的图形效果 很少会有人意识到,当浏览器绘制的border,会有一个角度的问题.我们就是得用这样的一个技巧来制作三角的效果.我们只需要保证一边的边框是有色,其他边框色为透明色,这样我们就很容 ...

  9. CSS 魔法系列:纯 CSS 绘制基本图形(圆、椭圆等)

    我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使用,更多新奇的 CSS 作品涌现出来. ...

最新文章

  1. NBT-新年4篇35分文章聚焦宏基因组研究
  2. js 包含某个字符串_[译] 5 大 JavaScript 字符串操作库
  3. 几何画板表现两集合的差集的教程
  4. linux php 如何停止,如何关闭linux
  5. win10 server 安装CUDA 9.0
  6. Kafka在ZooKeeper中的应用
  7. Magicodes.IE之导入学生数据教程
  8. python自动计算多个教学班的优秀率_第二个月课堂009python之总结(002)
  9. ffmpeg合并音频(转)
  10. 计算机组成原理白朔飞,计算机组成原理(第四章复习).ppt
  11. tomcat访问manager报404;server.xml中配置了Context path
  12. 亚马逊RDS使用的第三方扩展有漏洞,可导致内部凭据遭泄露
  13. 前端报错http 405错误
  14. 31个惊艳的数据可视化作品,感受“数据之美”!
  15. SPI器件的菊链配置
  16. CS:APP CH02信息的表示和处理知识点总结
  17. 【Android】从无到有:手把手一步步教你自定义RecyclerView手势监听
  18. 【Serverlet】学习
  19. python基础-PyYaml操作yaml文件
  20. U盘无法格式化的几个解决方法

热门文章

  1. Netdiscover网络扫描工具
  2. 办公用品申请领用管理
  3. 3GPP R16 TSN 时间同步相关的能力提升
  4. 面对世界不安,与其担忧,不如行动
  5. Windows boost 下编译 python 库 boost_python-vc120-mt-1_58.lib
  6. [日语二级词汇]日语二级必会汉字总结6
  7. Django Model用户头像设置
  8. WP响应式平扁设计风格Uigreat V1.5.1主题 源代码
  9. 深度学习文本识别之表格识别
  10. 十六进制数据原样转换成字符串