最近在学习CSS,先从CSS画点平面图形入手,发现除了正方形、长方形此类比较简单,只要有长宽设置恰当即可,画圆要涉及radius,然后恢复到做界面的最讨厌的状态了,不断的修改设值,调整数据,所幸并不多。下面就进入正文介绍吧,先将图形以及代码摆放出来,然后讲解下如何画,以及一些小细节。

1、正方形

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
div
{
width:110px;
height:110px;
border-right: 1px solid yellow;
/*transparent 变透明*/
border-left:1px solid yellow;
border-bottom: 1px solid pink;
border-top: 1px solid pink;
} </style>
</head>
<body>
<div></div> </body>
</html>

正方形就比较简单,只要设置长宽,长宽一样则为正方形,不一样则为长方形。

2、三角形

                

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css"> div
{
width:0px;
height:0px;
border-right: 50px solid transparent;
/*transparent 变透明*/
border-left:50px solid transparent;
border-bottom: 100px solid transparent;
border-top: 100px solid pink; } </style>
</head>
<body>
<div></div> </body>
</html>

从长方形向三角形转化,首先去除宽高的像素,这样子看上去便有了四个三角形,如何去除多余三角形,这里可以利用transparent,来将他们隐藏起来,想要三角形的位置不一样,隐藏的边界也不是一样。例如只要向下的三角形,就把左右下的三条边变透明(一般左右border一样画出来的三角形是等腰三角形,上下左右border一样画出来为等边三角形,直角三角形看你要的直角转向而定,直角三角形只要有留两个边即可,示例border-left:100px solid transparent;       border-top: 100px solid pink;)

3、梯形

 div
{
width:30px;
height:0px;
border-right: 50px solid transparent;
/*transparent 变透明*/
border-left:50px solid transparent;
border-bottom: 100px solid transparent;
border-top: 100px solid pink; }

梯形是在三角形的基础上,将width不设为0,便有梯形。

4、平行四边形

 div
{
width:100px;
height:100px;
border:1px solid pink;
transform: skew(20deg,0deg);
-ms-transform: skew(20deg,0deg); /* IE 9 */
-webkit-transform: skew(20deg,0deg); /* Safari and Chrome */ }

平行四边形主要是在正方形或者长方形的基础上,利用css的transfrom:skew来拉伸扭曲,其 x 轴动,y轴不变。

5、圆形

 div
{ width:100px;
height:100px;
border:1px solid pink;
border-radius: %;
-ms-border-radius: %; /* IE 9 */
-webkit-border-radius: %; /* Safari and Chrome */ }

radius来设置其弯曲程度(用来画圆角),border-radius:50%是指其水平弯曲程度,等价于

border-top-left-radius: 50% ;border-top-right-radius: 50% ; border-bottom-right-radius: 50% ;border-bottom-left-radius: 50% ;从左上角,右上角,左下角,右下角,四个地方分别入手。

6、蛋

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
body
{
margin: 100px;
text-align: center;
}
div{
width: 100px;
height: 140px;
/*等价式border-radius: 50% 50% 50% 50% / 65% 65% 40% 40%;;*/
border-top-left-radius: % %;
border-top-right-radius: % %;
border-bottom-right-radius: % %;
border-bottom-left-radius: % %;
/* 水平半径,垂直半径*/
border: 1px solid pink; }
</style>
</head>
<body>
<div>I just an egg!</div> </body>
</html>

radius在 / 前面设置的值也不一样,前面为水平弯曲,后面为垂直弯曲,根据设置的值不同能画出不一样的图形,比如想画个椭圆,就修改下里面的值便可。

7、五角星

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
body
{
margin: 100px;
}
div{
width: 0;
height: 0;
color: red;
margin: 50px 0;
position: relative;
display: block;
border-bottom:100px solid pink;
border-left: 35px solid transparent;
border-right:35px solid transparent;
} div:before{
width: 0;
height: 0;
position: absolute;
top: -40px;
left: -98px;
color: white;
display: block;
content: "";
border-right: 60px solid pink;
/*transparent 变透明*/
border-left:90px solid transparent;
border-top: 90px solid transparent;
border-bottom: 90px solid transparent;
transform: rotate(56deg);
-moz-transform:rotate(56deg);
-webkit-transform:rotate(56deg);
-ms-transform:rotate(56deg);
}
div:after{
width: 0;
height: 0;
position: absolute;
top: -40px;
left: -49px;
color: white;
display: block;
content: "";
border-right: 60px solid pink;
/*transparent 变透明*/
border-left:90px solid transparent;
border-top: 90px solid transparent;
border-bottom: 90px solid transparent;
transform: rotate(125deg);
-moz-transform:rotate(125deg);
-webkit-transform:rotate(125deg);
-ms-transform:rotate(125deg);
} </style>
</head>
<body>
<div></div> </body>
</html>

画五角星用到了伪类器,这里就不详细介绍,想了解伪类器就去百度下。这里运用伪类器,三层叠加,第一层是个三角形,第二层是一个钝角三角形,第三层也是个钝角三角形,第一层的三角形由前面的三角形构造而来,前面也讲过如何去画出不同方向的三角形以及设置。这里的角度利用rotate去旋转角度,然后通过top,left,以及position等来让他们位置重合,displace:block,来让他们叠合覆盖。

8、心形

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
body
{
margin: 100px;
}
div{ } div:before{
position: relative;
top: 61px;
left:43px;
display: block;
content: "";
position: relative;
display: block;
border-radius: 100px 100px 0px 0px;
background: #8AC007;
padding: 20px;
width: 40px;
height: 100px;
transform: rotate(45deg); }
div:after{
position: absolute;
top: -80px;
left:0px;
display: block;
content: "";
position: relative;
display: block;
border-radius: 100px 100px 0px 0px;
background: #8AC007;
padding: 20px;
width: 40px;
height: 100px;
transform: rotate(-45deg); } </style>
</head>
<body>
<div></div> </body>
</html>

画心形,我曾用来两种方法,最后采用第二种,第一种是用两个圆和正方形叠加来做,但是做出来的效果不好,不够圆滑,所以后来用第二种方法,用两个长方形来画,同时将长方形的左上角,右上角圆化,然后两者叠加,做出的效果也好看。(不要问我为什么这颗心时绿色我,青青草原也挺好的)

9、对话框

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
body
{
margin: 100px;
}
div{ } div:before{
position: relative;
top: 55px;
left:15px;
display: block;
content: "";
position: relative;
display: block;
width:0px;
height:0px;
border-right: 70px solid #8AC007;
/*transparent 变透明*/
border-left:100px solid transparent;
border-bottom: 10px solid transparent;
border-top: 10px solid transparent;
transform: rotate(-10deg); }
div:after{
position: absolute;
top: 0px;
left:150px;
display: block;
content: "";
position: relative;
display: block;
background: #8AC007;
border-radius: 10px 10px 10px 10px;
padding: 20px;
width: 100px;
height: 20px;
box-shadow: 2px 2px #aaaaaa; } </style>
</head>
<body>
<div></div> </body>
</html>

对话框是由长方形和三角形叠加而来的,同时将长方形做了四个圆角,看上去比较上眼,为了让对话框由立体感,增加了阴影效果box-shadow: 2px 2px #aaaaaa;

10、波浪框

 <!DOCTYPE html>
<html>
<head>
<title>triangle</title>
<style type="text/css">
body
{
margin: 100px;
text-align: center;
}
div{
width: 100px;
height: 50px;
border-radius: 2em 1em 4em / 0.5em 3em;
border: 3px solid pink; } </style>
</head>
<body>
<div>Skylar!</div> </body>
</html>

波浪框是个随机产物,但是个人觉得挺好看的保留下来。

对于CSS,个人觉得其设值是很有意思,因为你在大多数情况下,你不知道你设的值回带来什么的效果。所以,尝试深入体会其趣味。

最新文章

  1. 第八章 springboot + mybatis + 多数据源(转载)
  2. java web工程之Hibernate
  3. JS ||与&amp;&amp;总结
  4. 编译安装 php 5.4.11
  5. IOS“多继承”
  6. 浙大 pat 1007题解
  7. Java中 == 和 equals()详解
  8. Log4j.properties属性文件
  9. LeetCode 599. Minimum Index Sum of Two Lists (从两个lists里找到相同的并且位置总和最靠前的)
  10. 将meteor部署到自己的服务器(deploy meteor to your own server)
  11. 2017GCTF部分writeup
  12. python操作Excel的库openpyxl
  13. c#中打开Excel文档
  14. Angularjs演示Service功能
  15. VS 2017 安装测试
  16. svn中给个地址,然后把自己建立的项目拖进去
  17. 解决PLSQL Developer 插入中文 乱码问题(转)
  18. C#中货币类型和数值类型、字符串类型的转化
  19. swift 3.0 正则表达式查找/替换字符
  20. sql prompt 不能用

热门文章

  1. JavaSE教程-04Java中循环语句for,while,do&#183;&#183;&#183;while-练习
  2. angularJS ng-change错误的解决方案
  3. springboot问题:解决异常Unable to start embedded container;
  4. java基础(十四章)
  5. windows7 64bit下mvn命令后提示‘cmd’不是内部或外部命令,也不是可执行程序或批处理文件
  6. RabbitMQ分布式消息队列服务器(一、Windows下安装和部署)
  7. SQLServer类型与Java类型转换问题解决
  8. JS采用ActiveXObject实现用户在提交表单时屏蔽敏感词的功能
  9. VMware安装CentOS 提示:已将该虚拟机配置为使用 64 位客户机操作系统。但是,无法执行 64 位操作。解决方案
  10. Phpcms V9缩略图裁剪存在黑边的解决方法