CSS学习笔记一:css 画平面图形
最近在学习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,个人觉得其设值是很有意思,因为你在大多数情况下,你不知道你设的值回带来什么的效果。所以,尝试深入体会其趣味。
CSS学习笔记一:css 画平面图形的更多相关文章
- HTML+CSS学习笔记 (7) - CSS样式基本知识
HTML+CSS学习笔记 (7) - CSS样式基本知识 内联式css样式,直接写在现有的HTML标签中 CSS样式可以写在哪些地方呢?从CSS 样式代码插入的形式来看基本可以分为以下3种:内联式.嵌 ...
- HTML+CSS学习笔记 (12) - CSS布局模型
标签:HTML+CSS css布局模型 清楚了CSS 盒模型的基本概念. 盒模型类型, 我们就可以深入探讨网页布局的基本模型了.布局模型与盒模型一样都是 CSS 最基本. 最核心的概念. 但布局模型是 ...
- CSS学习笔记02 CSS选择器
1.通配符选择器 通配符选择器用“*"号表示,是所有选择器中作用范围最广的,能匹配页面中所有的元素 /*设置当前页面中所有标签的颜色为红色*/ * { color: red; } 2.标签选 ...
- CSS学习笔记01 CSS简介
1.CSS定义 CSS 指层叠样式表 (Cascading Style Sheets),是一种样式表语言,用来描述 HTML 或 XML(包括如 SVG.XHTML 之类的 XML 分支语言)文档的呈 ...
- DIV+CSS学习笔记(CSS)
css基础知识: css样式表的定义 css:(Cascading Style Sheets)层叠样式表: 分类及位置:内部样式-head区域style标签里面 外部样式-link调用 内联样式-标签 ...
- Head First Html and CSS学习笔记之CSS
第七章 CSS入门 元素的许多属性都可以设置样式,太多了,记不住,可以参考<CSS Pocket Reference>. 外部样式表,<link type = "text/ ...
- HTML+CSS学习笔记 (13) - CSS代码缩写,占用更少的带宽
标签:HTML+CSS 盒模型代码简写 还记得在讲盒模型时外边距(margin).内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左.具体应用在m ...
- HTML+CSS学习笔记 (15) - css样式设置小技巧
水平居中设置-行内元素 我们在实际工作中常会遇到需要设置水平居中场景,今天我们就来看看怎么设置水平居中的. 如果被设置元素为文本.图片等行内元素时,水平居中是通过给父元素设置 text-align:c ...
- HTML+CSS学习笔记 (11) - CSS盒模型
元素分类 在讲解CSS布局之前,我们需要提前知道一些知识,在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素.内联元素(又叫行内元素)和内联块状元素. 常用的块状元素有: <di ...
- HTML+CSS学习笔记 (10) - CSS格式化排版
文字排版--字体 我们可以使用css样式为网页中的文字设置字体.字号.颜色等样式属性.下面我们来看一个例子,下面代码实现:为网页中的文字设置字体为宋体. body{font-family:" ...
随机推荐
- mysql安装报错
一: -- MySQL 5.5.22Warning: Bison executable not found in PATH-- Configuring done-- Generating done-- ...
- C#之out修饰符、ref修饰符、params修饰符的简单介绍
一.out修饰符 1.调用一个带有输出参数的方法也需要使用out 修饰符,但是作为输出变量传递的本地变量在将他们作为输出变量传递前不需要赋值(因为调用后会改变或丢失),编译器允 许 ...
- 基于FPGA的彩色图像转灰度算法实现
昨天才更新了两篇博客,今天又要更新了,并不是我垃圾产,只不过这些在上个月就已经写好了,只是因为比赛忙,一直腾不出时间整理出来发表而已,但是做完一件事情总感觉不写一博文总结一下就少点什么,所以之后的一段 ...
- maven插件打包可执行jar
pom文件加 <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</grou ...
- ecshop收货地址货到付款修改
用户选择某些地址时,支付方式里则可以依据此地址来对货到付款选项进行显示或隐藏.目前仅与顺丰合作,以顺丰提供的数据为准. 使用到的数据库分别如下: ecs_region//地方数据,PRIMARY KE ...
- JavaScript面向对象之Windows对象
JavaScript之Window对象 首先我们先了解一个概念:事件. 事件,就是把一段代码设置好,满足条件时触发.或者说,事件是可以被 JavaScript 侦测到的行为. 网页中每个元素都可以触发 ...
- ionic 的缓存 和局部刷新
最近两天在做项目时,发现ionic的缓存功能非常方便好用,提高了再低端手机特别是android比较低版本上的流畅性!可是,后来发现,整体的缓存整个页面并不是一个一劳永逸的办法,结合局部刷新功能,感觉就 ...
- phpcms V9 后台验证码图片不显示
某个网站在本地运行成功,上传到服务器上后,发现后台登陆的验证码图片不显示 根据网上提供的解决方案, 网站路径变量web_path没问题 database.system的配置路径没问题 apache的G ...
- PHP+MySql实现后台数据的读取
我们使用的是PHP 的php_mysqli扩展 首先了解一些基础的用法 1.连接数据库使用 mysqli_connect() 参数:①主机地址 ②MYSQL用户名 ③MYSQL密码 ④选择 ...
- 详解 RAC 中各种IP和监听的意义
一.SCAN 概念 SCAN(Single Client Access Name)是 Oracle从11g R2开始推出的,客户端可以通过 SCAN 特性负载均衡地连接到 RAC数据库 SCAN 最明 ...