利用CSS3的border-radius绘制太极及爱心图案示例


Posted in HTML / CSS onMay 17, 2016

太极图
border-radius 除了做边框圆角效果之外,把它用在画图示上的话,其实能产生出很多不同的创意哩。笔者今天要继续使用它来教各位画-太极图。

检视原始码 HTML

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <div class="taichi">  
  3.   <div class="white-circle"></div>  
  4.   <div class="black-circle"></div>  
  5.  </div>  
  6. </body>  

因为太极图中有一黑一白的圆,所以多放了两个 div 在区块中。

接着请张大眼仔细看,笔者要先将大区块分成一白一黑:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .taichi {   
  2.  positionrelative;   
  3.  width48px/* 50 - 2 */  
  4.  height96px/* 100 - 2 - 2 */  
  5.  background#fff;   
  6.  border2px solid #000;   
  7.  border-width2px 50px 2px 2px;   
  8.  border-radius: 50%;   
  9. }  

一般的盒子模式(Box Model)是连同边框宽度都计算在区块的宽高中的,所以我们想要做一个宽高 100×100 的区块,但边框宽度如果是 2px 的话,那么里面的部份应该就是只有 96px。再来特别的是,笔者将右边的边框宽度直接设定成 50px,所以区块内部的宽度就只需要 48px 就可以了。

当这样设定好再加上 border-radius 圆角效果之后,就会变成~
利用CSS3的border-radius绘制太极及爱心图案示例

嘿嘿~已经有一黑一白的区块的,再来先补上一颗白圆:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .white-circle {   
  2.  positionabsolute;   
  3.  top: 0;   
  4.  left: 50%;   
  5.  background#fff;   
  6.  border-radius: 50%;   
  7.  width48px;   
  8.  height48px;   
  9. }  

这边就是直接产生一个完整的白色圆形并放在上半部的中间:
利用CSS3的border-radius绘制太极及爱心图案示例

那黑色圆形就是放在下半部?樱?/p>

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .black-circle {   
  2.  positionabsolute;   
  3.  top: 50%;   
  4.  left: 50%;   
  5.  background#000;   
  6.  border-radius: 50%;   
  7.  width48px;   
  8.  height48px;   
  9. }  

看起来就已经有 9 成像??
利用CSS3的border-radius绘制太极及爱心图案示例

最后还差两个相反颜色的小圆点在这两个圆形中,这两个小圆点我们只要使用 ::after 拟元素(Pseudo-elements) 就可以了:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .white-circle::after {   
  2.  content"";   
  3.  positionabsolute;   
  4.  top17px/* (50-16)/2 */  
  5.  left17px/* (50-16)/2 */  
  6.  background#000;   
  7.  border-radius: 50%;   
  8.  width16px;   
  9.  height16px;   
  10. }   
  11. .black-circle::after {   
  12.  content"";   
  13.  positionabsolute;   
  14.  top17px/* (50-16)/2 */  
  15.  left17px/* (50-16)/2 */  
  16.  background#fff;   
  17.  border-radius: 50%;   
  18.  width16px;   
  19.  height16px;   
  20. }  

将将~是不是很神奇呢!?
利用CSS3的border-radius绘制太极及爱心图案示例

爱心
上面教各位使用 border-radius 来画太极图,下面则是要教各位一样是使用圆角效果来爱心。

我们只需要一个 div 区块就可以了:

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <div class="heart"></div>  
  3. </body>  

然后指定区块的宽高:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .heart {   
  2.  positionrelative;   
  3.  width140px;   
  4.  height115px;   
  5. }  

一样是将爱心分成左右两区块,一样是先用 ::before 拟元素(Pseudo-elements)来产生左边的区块:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .heart::before {   
  2.  content"";   
  3.  positionabsolute;   
  4.  left70px;   
  5.  top: 0;   
  6.  width70px;   
  7.  height115px;   
  8.  backgroundred;   
  9.  border-radius: 50px 50px 0 0;   
  10. }  

因为只有设定左上及右上的圆角效果,所以就变成圆头的柱子了:
利用CSS3的border-radius绘制太极及爱心图案示例

接着笔者要改变它的旋转中心点来把它往左旋转 45 度:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .heart::before {   
  2.  content"";   
  3.  positionabsolute;   
  4.  left70px;   
  5.  top: 0;   
  6.  width70px;   
  7.  height115px;   
  8.  backgroundred;   
  9.  border-radius: 50px 50px 0 0;   
  10.  -webkit-transform: rotate(-45deg);   
  11.  -moz-transform: rotate(-45deg);   
  12.  -o-transform: rotate(-45deg);   
  13.  transform: rotate(-45deg);   
  14.  -webkit-transform-origin: left bottombottom;   
  15.  -moz-transform-origin: left bottombottom;   
  16.  -o-transform-origin: left bottombottom;   
  17.  transform-origin: left bottombottom;   
  18. }  

transform-origin 可以改变元素的中心点。它跟 background-position 一样是接受两个值,第一个是设定水平,第二个是设定垂直。预设是以 center center 为主,现在笔者将它改成在左下方:
利用CSS3的border-radius绘制太极及爱心图案示例

右边的部份也一样,但只是旋转中心点改在右下,并往右旋转:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .heart::after {   
  2.  content"";   
  3.  positionabsolute;   
  4.  top: 0;   
  5.  left: 0;   
  6.  width70px;   
  7.  height115px;   
  8.  backgroundred;   
  9.  border-radius: 50px 50px 0 0;   
  10.  -webkit-transform: rotate(45deg);   
  11.  -moz-transform: rotate(45deg);   
  12.  -o-transform: rotate(45deg);   
  13.  transform: rotate(45deg);   
  14.  -webkit-transform-origin: rightright bottombottom;   
  15.  -moz-transform-origin: rightright bottombottom;   
  16.  -o-transform-origin: rightright bottombottom;   
  17.  transform-origin: rightright bottombottom;   
  18. }  

当两边都产生完后,一个红通通的爱心就出现?樱?br />利用CSS3的border-radius绘制太极及爱心图案示例

什么~中和的钟先生问说怎么不会动...没关系,补上个 animation 的动画效果给它:

检视原始码 CSS

CSS Code复制内容到剪贴板
  1. .heart {   
  2.  -webkit-animation: jump 1s infinite ease-out;   
  3.  -moz-animation: jump 1s infinite ease-out;   
  4.  -o-animation: jump 1s infinite ease-out;   
  5.  animation: jump 1s infinite ease-out;   
  6. }   
  7. @-webkit-keyframes jump {   
  8.  0%, 60%, 75%, 90%, 100% {   
  9.   -webkit-transform: scale(1);   
  10.  }   
  11.  15% {   
  12.   -webkit-transform: scale(0.6);   
  13.  }   
  14.  30% {   
  15.   -webkit-transform: scale(1);   
  16.  }   
  17.  45% {   
  18.   -webkit-transform: scale(0.7);   
  19.  }   
  20. }   
  21. @-moz-keyframes jump {   
  22.  0%, 60%, 75%, 90%, 100% {   
  23.   -moz-transform: scale(1);   
  24.  }   
  25.  15% {   
  26.   -moz-transform: scale(0.6);   
  27.  }   
  28.  30% {   
  29.   -moz-transform: scale(1);   
  30.  }   
  31.  45% {   
  32.   -moz-transform: scale(0.7);   
  33.  }   
  34. }   
  35. @-o-keyframes jump {   
  36.  0%, 60%, 75%, 90%, 100% {   
  37.   -o-transform: scale(1);   
  38.  }   
  39.  15% {   
  40.    -o-transform: scale(0.6);   
  41.  }   
  42.  30% {   
  43.   -o-transform: scale(1);   
  44.  }   
  45.  45% {   
  46.   -o-transform: scale(0.7);   
  47.  }   
  48. }   
  49. @keyframes jump {   
  50.  0%, 60%, 75%, 90%, 100% {   
  51.   transform: scale(1);   
  52.  }   
  53.  15% {   
  54.   transform: scale(0.6);   
  55.  }   
  56.  30% {   
  57.   transform: scale(1);   
  58.  }   
  59.  45% {   
  60.   transform: scale(0.7);   
  61.  }   
  62. }  

透过 transform 的 scale(x, y) 来改变爱心的大小,让整个动画的看起来就象是噗通噗通的跳一样:
利用CSS3的border-radius绘制太极及爱心图案示例

HTML / CSS 相关文章推荐
移动端rem布局的两种实现方法
Jan 03 HTML / CSS
纯CSS3打造动感漂亮时尚的扇形菜单
Mar 18 HTML / CSS
CSS3制作炫酷带方向感应的鼠标滑过图片3D动画
Mar 16 HTML / CSS
Css3新特性应用之形状总结
Dec 08 HTML / CSS
详解css3 Transition属性(平滑过渡菜单栏案例)
Sep 05 HTML / CSS
详解CSS3选择器:nth-child和:nth-of-type之间的差异
Sep 18 HTML / CSS
html5 input元素新特性_动力节点Java学院整理
Jul 06 HTML / CSS
HTML5之SVG 2D入门11—用户交互性(动画)介绍及应用
Jan 30 HTML / CSS
HTML5+JS实现俄罗斯方块原理及具体步骤
Nov 29 HTML / CSS
2014年圣诞节倒计时网页的制作过程
Dec 05 HTML / CSS
HTML5语义化元素你真的用对了吗
Aug 22 HTML / CSS
HTML5 直播疯狂点赞动画实现代码 附源码
Apr 14 HTML / CSS
CSS3的常见transformation图形变化用法小结
May 13 #HTML / CSS
使用CSS3的font-face字体嵌入样式的方法讲解
May 13 #HTML / CSS
几个CSS3的flex弹性盒模型布局的简单例子演示
May 12 #HTML / CSS
CSS3中的transform属性进行2D和3D变换的基本用法
May 12 #HTML / CSS
CSS3制作气泡对话框的实例教程
May 10 #HTML / CSS
详解CSS3的box-shadow属性制作边框阴影效果的方法
May 10 #HTML / CSS
解决CSS3的opacity属性带来的层叠顺序问题
May 09 #HTML / CSS
You might like
SWFUpload与CI不能正确上传识别文件MIME类型解决方法分享
2011/04/18 PHP
奇怪的PHP引用效率问题分析
2012/03/23 PHP
PHP获取某个月最大天数(最后一天)的方法
2015/07/29 PHP
PHP+Redis 消息队列 实现高并发下注册人数统计的实例
2018/01/29 PHP
Span元素的width属性无效果原因及解决方案
2010/01/15 Javascript
仅用[]()+!等符号就足以实现几乎任意Javascript代码
2010/03/01 Javascript
Extjs4.0设置Ext.data.Store传参的请求方式(默认为GET)
2013/04/02 Javascript
js如何取消事件冒泡
2013/09/23 Javascript
Javascript核心读书有感之词法结构
2015/02/01 Javascript
JavaScript中实现map功能代码分享
2015/06/11 Javascript
js数组去重的5种算法实现
2015/11/04 Javascript
Markdown与Bootstrap相结合实现图片自适应属性
2016/05/04 Javascript
js实现返回顶部效果
2017/03/10 Javascript
vue.extend与vue.component的区别和联系
2018/09/19 Javascript
原生js通过一行代码实现简易轮播图
2019/06/05 Javascript
微信小程序用户授权弹窗 拒绝时引导用户重新授权实现
2019/07/29 Javascript
layui lay-verify form表单自定义验证规则详解
2019/09/18 Javascript
JavaScript鼠标悬停事件用法解析
2020/05/15 Javascript
Python 字符串操作方法大全
2014/03/11 Python
python实现马耳可夫链算法实例分析
2015/05/20 Python
Python使用Scrapy爬取妹子图
2015/05/28 Python
Python装饰器使用实例:验证参数合法性
2015/06/24 Python
python subprocess 杀掉全部派生的子进程方法
2017/01/16 Python
python爬虫实例详解
2018/06/19 Python
django queryset 去重 .distinct()说明
2020/05/19 Python
matplotlib.pyplot.plot()参数使用详解
2020/07/28 Python
python的dict判断key是否存在的方法
2020/12/09 Python
Python用户自定义异常的实现
2020/12/25 Python
pyspark对Mysql数据库进行读写的实现
2020/12/30 Python
工业设计专业个人求职信范文
2013/12/28 职场文书
班组长岗位职责范本
2014/01/05 职场文书
2015年学生会个人工作总结
2015/04/09 职场文书
html+css实现环绕倒影加载特效
2021/07/07 HTML / CSS
Win11黑色桌面背景怎么办?Win11黑色壁纸解决方法汇总
2022/04/05 数码科技
vue实现列表垂直无缝滚动
2022/04/08 Vue.js
MySQL数据库查询进阶之多表查询详解
2022/04/08 MySQL