简单图形

矩形

div{
width: 100px;
height: 100px;
background-color: red;
}

圆形

div{
width: 100px;
height: 100px;
background-color: red;
border-radius: %;
}

椭圆

【整个椭圆】

div{
width: 100px;
height: 50px;
background-color: red;
border-radius: %;
}

【半椭圆或半圆】

div{
width: 100px;
height: 100px;
background:red;
border-radius:50% /100% 100% 0 0 ;
}

【四分之一椭圆】

div{
width: 100px;
height: 100px;
background:red;
border-radius:100% 0 0 0 ;
}

三角形

【直角三角形】

div{
width: ;
height: ;
border: 50px solid transparent;
border-bottom-color: red;
}

【正三角形】

div{
width: ;
height: ;
border: 50px solid transparent;
border-width: 86.6px 50px;
border-bottom-color: red;
}

平行四边形

【基本图形】

div{
margin-left: 50px;
width: 100px;
height: 100px;
background-color: red;
transform: skew(30deg);
}

【改进版本】

  上面的代码中,不仅形状发生了变形,内容也发生了变形。有两种方法改进

  1、元素嵌套

.outer{
margin-left:20px;
width: 100px;
height: 100px;
background:red;
transform:skewX(-30deg);
}
.inner{
transform:skewX(30deg);
}
</style>
<div class="outer">
<div class="inner">小火柴</div>
</div>

  2、伪元素

  把所有样式都应用到伪元素上,然后再对伪元素进行变形

div{
position:relative;
margin-left:20px;
width: 100px;
height: 100px;
text-indent: 30px;
}
div::before{
content:'';
position:absolute;
top: 0;right: 0;left: 0;bottom: 0;
transform:skewX(-30deg);
background:red;
z-index:-1;
}

梯形

【基本版本】

div{
width: 50px;
border: 50px solid transparent;
border-bottom-color: red;
}

【增强版本】

  上面的代码虽然简单且巧妙,但无法在图形内容填充文本。下面是比较复杂的增强版本

div{
height: 100px;
width: 200px;
line-height: 100px;
position:relative;
display:inline-block;
text-align: center;
color:white;
padding: .5em 1em .35em;
}
div:before{
content:'';
position:absolute;
top: 0;right: 0;bottom: 0;left: 0;
z-index:-1;
background:#58a;
transform:scaleY(1.3) perspective(.5em) rotateX(5deg);
transform-origin: bottom;
}

【梯形选项卡】

<style>
a{
width: 120px;
text-align: center;
text-decoration: none;
color:inherit;
font-size: 20px
}
nav > a{
position:relative;
display:inline-block;
padding:.3em .1em 0;
}
nav > a:before{
content:'';
position:absolute;
top: 0;right: 0;left: 0;bottom: 0;
z-index:-1;
background:#ccc;
border:1px solid black;
border-radius: .5em .5em 0 0 ;
box-shadow: 0 .15em white inset; transform:scaleY(1.3) perspective(.5em) rotateX(5deg);
transform-origin: bottom;
}
</style>
<nav>
<a href="#">HTML</a>
<a href="#">CSS</a>
<a href="#">Javascript</a>
</nav>

复杂图形

多角星

【五角星】

  一个大三角形底部掏掉一个小三角形;两个前面的相同图形叠压

  经计算,五角星的夹角为36度,若小三角形的侧边为a,则大三角形的侧边为2a(1+sin18),两个三角形共同的底边为2a(sin54)

<div class="box">
  <div class="in"></div>
  <div class="in"></div>
</div>

.box{
position: relative;
}
.in{
margin-left: 100px;
position: relative;
width: 0px;
border: 10px solid transparent;
border-width: 249px 81px;
border-bottom-color: red;
position: absolute;
}
.in:after{
content: "";
position:absolute;
border: 10px solid transparent;
border-width: 59px 81px;
border-bottom-color: white;
top: 133px;
left: -81px;
}
.in:last-child{
top: 100px;
left: -134px;
transform: rotate(-73deg);
}

【六角星】

  两个三角形叠压

div{
position: relative;
width: ;
border: 50px solid transparent;
border-width: 50px .4px;
border-bottom-color: red;
}
div:after{
position: absolute;
content:"";
width: ;
border: 50px solid transparent;
border-width: 50px .4px;
border-top-color: red;
top: 16px;
left: -42px;
}

多边形

【六边形】

  两个梯形拼接

div{
position: relative;
width: 50px;
border: 50px solid transparent;
border-bottom-color: red;
}
div:after{
position: absolute;
content:"";
width: 50px;
border: 50px solid transparent;
border-top-color: red;
top:50px;
left: -50px;
}

【八边形】

.outer{
width:100px;
height: 100px;
transform:rotate(45deg);
overflow: hidden;
}
.inner{
width:100%;
height: 100%;
transform:rotate(-45deg);
background:red;
}

【菱形】

<style>
.outer{
margin:50px 0 0 50px;
width:100px;
height: 100px;
transform:rotate(45deg);
overflow: hidden;
}
.inner{
width:100%;
height: 100%;
transform:rotate(-45deg) scale(1.42);
background:red;
}
</style>

桃心

  创建一个方形div,分别用css控制div的两个伪元素平移到正方形相邻两边,圆形与边中点重合。最后将总的div旋转45度

<style>
div{
display:inline-block;
margin:50px;
height: 100px;
width: 100px;
background-color: red;
transform: rotate(-45deg);
}
div:before,div:after{
display:block;
content:"";
width: 100px;
height: 100px;
background-color: red;
border-radius: 50%;
margin-top:-50%;
}
div:after{
margin-left:50%;
}
</style>
<div></div>

切角效果

【单角】

background: linear-gradient(-45deg,transparent 5%,#58a 0);

【双角】

  background: linear-gradient(-45deg,transparent 5%,#58a 0) right,linear-gradient(45deg,transparent 5%,#58a 0) left;
background-size:50% 100%;
background-repeat:no-repeat;

【四角】

  background: linear-gradient(-135deg,transparent 5%,#58a 0) top right,linear-gradient(135deg,transparent 5%,#58a 0) top left,linear-gradient(-45deg,transparent 5%,#58a 0) bottom right,linear-gradient(45deg,transparent 5%,#58a 0) bottom left;
background-size:50% 50%;
background-repeat:no-repeat;

【弧形切角】

  background: radial-gradient(circle at top right,transparent 5%,#58a 0) top right,radial-gradient(circle at top left,transparent 5%,#58a 0) top left,radial-gradient(circle at bottom right,transparent 5%,#58a 0) bottom right,radial-gradient(circle at bottom left,transparent 5%,#58a 0) bottom left;
background-size:50% 50%;
background-repeat:no-repeat;

折角效果

background:linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,0.4) 0) no-repeat 100% 0 /2em 2em,linear-gradient(-135deg,transparent 1.414em ,#58a 0);

饼图效果

  饼图在网页中的运用极为普遍,比如简单的统计图表、进度指示器、定时器等

【静态效果】

<style>
@keyframes spin{
to{transform: rotate(.5turn);}
}
@keyframes bg{50%{background:#655;}}
.pie{
width: 100px;line-height: 100px;
position:relative;
background-color: yellowgreen;
border-radius: 50%;
color:transparent;
text-align:center;
background-image: linear-gradient(to right, transparent 50%,#655 0);
}
.pie:before{
content:'';
position:absolute;
top: 0;left: 50%;
width: 50%;height: 100%;
border-radius: 0 100% 100% 0 /50%;
background-color: inherit;
transform-origin: left;
animation: spin 50s linear infinite,bg 100s step-end infinite;
animation-play-state:paused;
animation-delay:inherit;
}
</style>
<div class="pie" style="animation-delay:-20s">20%</div>
<div class="pie" style="animation-delay:-90s">90%</div>

【动态效果】

<style>
@keyframes spin{
to{transform: rotate(.5turn);}
}
@keyframes bg{50%{background:#655;}} .pie{
width: 100px;height: 100px;
position:relative;
background-color: yellowgreen;
border-radius: 50%;
background-image: linear-gradient(to right, transparent 50%,#655 0);
}
.pie:before{
content:'';
position:absolute;
top: 0;left: 50%;
width: 50%;height: 100%;
border-radius: 0 100% 100% 0 /50%;
background-color: inherit;
transform-origin: left;
animation: spin 3s linear infinite,bg 6s step-end infinite;
animation-play-state: paused;
}
.pie:hover:before{
animation-play-state: running;
}
</style>
<div class="pie"></div>

  鼠标移入时,饼图发生移动

【SVG实现】

  让圆形的周长接近于100,方便计算。r = 100/(2*PI) = 16

<style>
@keyframes fillup{to{stroke-dasharray:100 100;}}
svg{
width: 100px;
height: 100px;
transform: rotate(-90deg);
background: yellowgreen;
border-radius: 50%;
}
circle{
fill:yellowgreen;
stroke:#655;
stroke-width:32;
stroke-dasharray: 0 100;
animation: fillup 5s linear infinite;
}
</style>
<svg viewbox="0 0 32 32" xmlns="http://www.w3.org/2000/svg">
<circle r=16 cx=16 cy=16></circle>
</svg>

最后

  除了使用CSS画图之后,实现各种形状更简单的方法是使用clip-path路径裁剪样式

  欢迎交流

CSS画出的图的更多相关文章

  1. 用css画出三角形

    看到有面试题里会有问到如何用css画出三角形 众所周知好多图形都可以拆分成三角形,所以说会了画三角形就可以画出很多有意思的形状 画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及 ...

  2. 如何用css画出三角形

    看到有面试题里会有问到如何用css画出三角形 众所周知好多图形都可以拆分成三角形,所以说会了画三角形就可以画出很多有意思的形状 画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及 ...

  3. 用css画出三角形【转】

    看到有面试题里会有问到如何用css画出三角形 众所周知好多图形都可以拆分成三角形,所以说会了画三角形就可以画出很多有意思的形状 画出三角形的原理是调整border(边框)的四个方向的宽度,线条样式以及 ...

  4. css 画出三角形

    技术分享不一定行文累赘 这里说说最简洁的 css 画出三角形 display: inline-block; border: 10px dashed transparent; border-left: ...

  5. 用HTML+CSS画出一个同心圆

    参加web前端校招的同学们经常会遇到这样的面试题:用HTML+CSS画出一个同心圆. 例如: 这道题主要考验的是基础盒模型布局能力和倒圆角属性的巧用. 1.html代码 <body> &l ...

  6. CSS画出的各种形状图

    利用CSS可以画出各种需要的图形目录[1]矩形[2]圆形[3]椭圆[4]直角三角形[5]正三角形[6]平行四边形[7]梯形[8]六角星[9]六边形[10]五角星简单图形 矩形div{ width: 1 ...

  7. 情人节,教大家使用css画出一朵玫瑰花。

    情人节到了,给大家来一朵高端的玫瑰花. 在网上看到的一个canvas实现的玫瑰花,效果很好,但是代码被压缩过,也没有注释,看的云里雾里的. 今天我教大脚用CSS来实现一朵玫瑰花. 先看效果 首先我们画 ...

  8. 灵悟礼品网上专卖店——画出E-R图

    一.小组成员: 洪雪意(产品负责人) 陈淑筠(Master) 二.组内人员任务情况 计划完成的任务的第三个模块:分析并建立数据库 已完成的任务: 任务的第三个模块: 陈淑筠(完成任务1):画出商品资料 ...

  9. 用css画出对话框

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAa4AAAFSCAYAAACqpTv4AAAgAElEQVR4nO3deZBU5b3GcUIlVTG3bi

随机推荐

  1. OPC的理解Open Packaging Conventions

    Open Packaging Conventions (OPC) 博客地址:www.cnblogs.com/icmzn OPC是一个文件容器技术.被微软创建,用来存储XML或者非XML文件结合起来的规 ...

  2. JavaScript 基础第三天

    一.前言 在前天的内容我们提到了有关于JS的一些语言结构,这些语言结构都是语法中最为基本的内容必须予以熟记并可以灵活掌握. 二.引入 在今天内容中我们将讨论两个很重要的概念,数组与函数. 三.重点内容 ...

  3. Ubuntu/Linux 下pdf阅读器Zathura(类vim操作)

    Ubuntu下源安装: sudo apt-get install zathura 操作总结: 基本操作与vim一致,对于熟悉vim快捷键的十分方便: 向下移动一页是J(Ctrl+f),向上移动一页是K ...

  4. XML dom

    将文件解析为文档 三步过程 为了使用 XML 文件中的信息,必须解析文件以创建一个 Document 对象. Document 对象是一个接口,因而不能直接将它实例化:一般情况下,应用程序会相应使用一 ...

  5. smartroute简单集成集群聊天通讯

    在制定一个规模比较多大的聊天应用时,往往需要制定部署多个应用服务,其一可以保障服务的可靠性,其二可以增加用户负载量.但制定这样一种应用体系是一件复杂的事情,毕竟同一群体的用户实际上会在不同的服务器接入 ...

  6. 【推荐】【给中高级开发者】构建高性能ASP.NET应用的几点建议

    本篇目录 早期阶段就要对应用进行负载测试 使用高性能类库 你的应用是CPU密集还是IO密集的 使用基于Task的异步模型,但要慎重 分发缓存和会话(session)状态 创建Web Gardens 巧 ...

  7. UWP?UWP! - Build 2015有些啥?(2)

    UWP?UWP! - Build 2015有些啥? Build 2015圆满落幕了,不知大家有多少人刷夜看了直播呢?不管怎么说,想必各位都很好奇在这场微软开发者盛宴上,Microsoft又发布了什么令 ...

  8. MySQL7:视图

    什么是视图 数据库中的视图是一个虚拟表.视图是从一个或者多个表中导出的表,视图的行为与表非常相似,在视图中用户可以使用SELECT语句查询数据,以及使用INSERT.UPDATE和DELETE修改记录 ...

  9. js作用域问题一步步透彻理解

    黄金守则第一条: js没有块级作用域(你可以自己闭包或其他方法实现),只有函数级作用域,函数外面的变量函数里面可以找到,函数里面的变量外面找不到. first try: 这是为什么呢?? var a ...

  10. Django集成百度富文本编辑器uEditor

    UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码. 首先从ueEditor官网下载最新版本的包, ...