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

css3中的border-radius可以轻松地用来绘制弧线,如果只用来做圆角矩形的话可就太浪费了,下面就来展示一下利用css3的border-radius绘制太极爱心图案示例,需要的朋友可以参考下

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

检视原始码 HTML

 

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

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

立即学习“前端免费学习笔记(深入)”;

检视原始码 CSS

.taichi {    position: relative;    width: 48px; /* 50 - 2 */ height: 96px; /* 100 - 2 - 2 */ background: #fff;    border: 2px solid #000;    border-width: 2px 50px 2px 2px;    border-radius: 50%;   }

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

当这样设定好再加上 border-radius 圆角效果之后,就会变成~
2016517110833210.png (120×120)

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

检视原始码 CSS

.white-circle {    position: absolute;    top: 0;    left: 50%;    background: #fff;    border-radius: 50%;    width: 48px;    height: 48px;   }

这边就是直接产生一个完整的白色圆形并放在上半部的中间:
2016517110925477.png (120×120)

那黑色圆形就是放在下半部囉:

检视原始码 CSS

.black-circle {    position: absolute;    top: 50%;    left: 50%;    background: #000;    border-radius: 50%;    width: 48px;    height: 48px;   }

看起来就已经有 9 成像囉~
2016517110953720.png (120×120)

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

检视原始码 CSS

.white-circle::after {    content: "";    position: absolute;    top: 17px; /* (50-16)/2 */ left: 17px; /* (50-16)/2 */ background: #000;    border-radius: 50%;    width: 16px;    height: 16px;   }   .black-circle::after {    content: "";    position: absolute;    top: 17px; /* (50-16)/2 */ left: 17px; /* (50-16)/2 */ background: #fff;    border-radius: 50%;    width: 16px;    height: 16px;   }

将将~是不是很神奇呢!?
2016517111042392.png (120×120)

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

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

 

然后指定区块的宽高:

检视原始码 CSS

.heart {    position: relative;    width: 140px;    height: 115px;   }

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

检视原始码 CSS

.heart::before {    content: "";    position: absolute;    left: 70px;    top: 0;    width: 70px;    height: 115px;    background: red;    border-radius: 50px 50px 0 0;   }

因为只有设定左上及右上的圆角效果,所以就变成圆头的柱子了:
2016517111117036.png (200×200)

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

检视原始码 CSS

.heart::before {    content: "";    position: absolute;    left: 70px;    top: 0;    width: 70px;    height: 115px;    background: red;    border-radius: 50px 50px 0 0;    -webkit-transform: rotate(-45deg);    -moz-transform: rotate(-45deg);    -o-transform: rotate(-45deg);    transform: rotate(-45deg);    -webkit-transform-origin: left bottombottom;    -moz-transform-origin: left bottombottom;    -o-transform-origin: left bottombottom;    transform-origin: left bottombottom;   }

transform-origin 可以改变元素的中心点。它跟 background-position 一样是接受两个值,第一个是设定水平,第二个是设定垂直。预设是以 center center 为主,现在笔者将它改成在左下方:
2016517111144455.png (200×200)

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

检视原始码 CSS

.heart::after {    content: "";    position: absolute;    top: 0;    left: 0;    width: 70px;    height: 115px;    background: red;    border-radius: 50px 50px 0 0;    -webkit-transform: rotate(45deg);    -moz-transform: rotate(45deg);    -o-transform: rotate(45deg);    transform: rotate(45deg);    -webkit-transform-origin: rightright bottombottom;    -moz-transform-origin: rightright bottombottom;    -o-transform-origin: rightright bottombottom;    transform-origin: rightright bottombottom;   }

当两边都产生完后,一个红通通的爱心就出现囉:
2016517111209126.png (200×200)

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

检视原始码 CSS

.heart {    -webkit-animation: jump 1s infinite ease-out;    -moz-animation: jump 1s infinite ease-out;    -o-animation: jump 1s infinite ease-out;    animation: jump 1s infinite ease-out;   }   @-webkit-keyframes jump {    0%, 60%, 75%, 90%, 100% {     -webkit-transform: scale(1);    }    15% {     -webkit-transform: scale(0.6);    }    30% {     -webkit-transform: scale(1);    }    45% {     -webkit-transform: scale(0.7);    }   }   @-moz-keyframes jump {    0%, 60%, 75%, 90%, 100% {     -moz-transform: scale(1);    }    15% {     -moz-transform: scale(0.6);    }    30% {     -moz-transform: scale(1);    }    45% {     -moz-transform: scale(0.7);    }   }   @-o-keyframes jump {    0%, 60%, 75%, 90%, 100% {     -o-transform: scale(1);    }    15% {      -o-transform: scale(0.6);    }    30% {     -o-transform: scale(1);    }    45% {     -o-transform: scale(0.7);    }   }   @keyframes jump {    0%, 60%, 75%, 90%, 100% {     transform: scale(1);    }    15% {     transform: scale(0.6);    }    30% {     transform: scale(1);    }    45% {     transform: scale(0.7);    }   }

透过 transform 的 scale(x, y) 来改变爱心的大小,让整个动画的看起来就象是噗通噗通的跳一样:
2016517111241241939.gif (200×200)

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于CSS中视窗单位和百分比单位的使用

CSS3如何实现自定义“W”形运行轨迹

利用CSS3实现文字向右循环的闪过效果

以上就是利用CSS3的border-radius实现绘制太极及爱心的图案的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1610694.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 01:37:00
下一篇 2025年12月24日 01:37:11

相关推荐

  • 如何使用css3做0.5px的细线

    这篇文章主要介绍了使用css3做0.5px的细线的示例代码的相关资料,内容挺不错的,现在分享给大家,也给大家做个参考。 Webapp中的CSS3实现 0.5px的细线 感觉很长时间没写过博客了,最近生活还算稳定,过得较为充实,所以又要开始写写东西了,一个是为了做些记录,是怕自己某一天,忘记了,回头翻…

    2025年12月24日 好文分享
    000
  • CSS3如何实现同时执行倾斜和旋转的动画效果

    这篇文章通过实例代码给大家主要介绍了,如何利用css3实现同时执行倾斜和旋转的动画效果,文中给出了完整的实例代码,大家直接运行就可以看到效果,有需要的朋友们可以参考借鉴,下面来一起看看吧。 先看看静态的效果,运行后的效果更好 示例代码如下 css3学习 .d{width: 200px;height:…

    2025年12月24日
    000
  • 利用CSS3实现地球自转

    这篇文章主要介绍了关于利用css3实现地球自转,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 CSS3实现地球自转,不可思议啊,不过确实可以实现,不信的朋友可以祥看本文,附送源码 最终成果: 素材:两张图片, 立即学习“前端免费学习笔记(深入)”; espaco.jpg(1600*1…

    2025年12月24日 好文分享
    000
  • 关于CSS3绘制六边形的方法

    下面为大家带来一篇css3绘制六边形的简单实现。内容挺不错的,现在就分享给大家,也给大家做个参考。 因为很简单,所以先总结一下:使用CSS3绘制六边形主要使用伪类:before和:after在源元素之前和之后再绘制两个元素,并利用css3的边框样式,将这两个元素变成三角形放置在源元素的两端即可。 (…

    2025年12月24日 好文分享
    000
  • 利用SVG和CSS3实现炫酷的边框动画

    这篇文章主要介绍了利用svg和css3来实现一个炫酷的边框动画,不使用javascript使得编写过程轻松了不少,需要的朋友可以参考下 今天我们来探索一下Carl Philipe Brenner的网站上一个微妙而有趣的动画效果。当鼠标经过网格元素时,会有一个微妙的动画发生——网格元素变得透明,每条边…

    2025年12月24日
    000
  • 利用CSS3实现了八组超炫酷鼠标滑过图片动画

    这篇文章主要为大家分享了8组超炫酷纯css3鼠标滑过图片动画效果,每一个动画效果都很精彩,值得大家学习借鉴,感兴趣的小伙伴们可以参考一下 这是一款效果超酷的纯CSS3鼠标滑过图片动画效果,它共分为8组不同的效果,它们分别在鼠标滑过图片时,以不同的方式显示遮罩层和图片标题。每一组效果又分为3种不同的鼠…

    2025年12月24日 好文分享
    000
  • CSS3实现的图片放大镜特效

    一款用纯css3实现的图片放大镜特效。页面打开五个小图显示于页面。当鼠标经过图片时,当前图片以灰色背景图的形式展示,需要的朋友不要错过 今天要给大家分享的的一款用纯css3实现的图片放大镜特效。页面打开五个小图显示于页面。当鼠标经过图片时,当前图片以灰色背景图的形式展示。效果非常不错。   实现的代…

    2025年12月24日
    000
  • 关于css3弹性盒模型的介绍

    这篇文章主要介绍了关于css3弹性盒模型的介绍,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 Css3引入了新的盒模型——弹性盒模型决定一个盒子在其他盒子中的分布方式以及如何处理可用的空间,使用该模型,可以很轻松的创建自适应浏览器窗口的流动布局或自适应字体大小的弹性布局 Css3引入…

    2025年12月24日
    000
  • 如何使用css3画个同心圆

    这篇文章主要给大家介绍了利用css3如何画个同心圆的相关资料,文中给出了详细的示例代码,并对代码进行了详细的解析方法大家理解和学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 基本思路 首先你得画三个圆吧,那三个圆怎么重叠到一块呢?这个就得靠-margin来控制了。 css 立即学…

    2025年12月24日
    000
  • 关于CSS3中的calc() 方法

    这篇文章主要介绍了详解css 3 的 calc() 方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下 下面一段代码给大家介绍css3中的calc()方法,具体内容如下所示: [Ctrl+A 全部选择 提示:您可先修改部分代码,再按运行] 如上代码,预览可以看出红色框超出了,因为在标准的 CSS…

    好文分享 2025年12月24日
    000
  • css3中移动属性的分析

    这篇文章主要介绍了css3学习系列之移动属性详解,内容挺不错的,现在分享给大家,也给大家做个参考。 transform功能 放缩 使用sacle方法实现文字或图像的放缩处理,在参数中指定缩放倍率,比如sacle(0.5)表示缩小50%,例子如下: scale方法使用示例 p { width: 300…

    2025年12月24日 好文分享
    000
  • 使用CSS3编写灰阶滤镜来制作黑白照片效果

    这篇文章主要介绍了使用css3编写灰阶滤镜来制作黑白照片效果的方法,css3中的filter十分强大,文中还介绍了对ie兼容的方法,需要的朋友可以参考下 CSS3 中的滤镜(filter)功能让我们轻松方便简单的处理图片,而不需要使用 PhotoShop 或者使用很多 JavaScript、PHP …

    2025年12月24日
    000
  • 利用CSS3制作的鼠标悬停时边框旋转

    本文给大家分享一段css3代码实现鼠标悬停时边框旋转的效果,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下 下面以2017年新年祝福语为例给大家展示下效果。 纯CSS3实现的鼠标悬停时边框旋转的效果: 实现代码如下,代码中注释已经比较详细,就不再多说了: Document body { …

    2025年12月24日
    000
  • 两种CSS3圆角和渐变的常用功能

    这篇文章主要介绍了css3圆角和渐变2种常用功能详解 的相关资料,需要的朋友可以参考下 Css3圆角讲解:想必大家对于图片,背景圆角,都不陌生吧, 圆角语法:border-radius:圆角值; CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案。CSS3的出现,使得我们再也不必浪…

    2025年12月24日 好文分享
    000
  • 关于HTML5和CSS3实现时钟的效果

    利用html5,css实现钟摆效果 ,在项目中经常会遇到,今天把基于html5+css3实现简单的时钟效果的实现代码分享到本站平台,需要的朋友参考下吧 目的: 利用html5,css实现钟摆效果 知识点: 1) 利用position/left/top和calc()实现元素的水平和垂直居中; 立即学习…

    好文分享 2025年12月24日
    000
  • CSS3中使用RGBa来调节透明度的方法

    这篇文章主要介绍了css3中使用rgba来调节透明度的教程,rgba是rgb色彩模型的一个扩展,这个缩写词代表红绿蓝三原色的首字母,alpha值代表颜色的透明度或者说不透明度,需要的朋友可以参考下 在 CSS3 中,增加了一个 opacity 属性,允许开发者设置元素的透明度,现在 opacity …

    2025年12月24日
    000
  • 使用 css3 实现圆形进度条的方法

    本篇文章主要介绍了使用 css3 实现圆形进度条的示例,这里整理了详细的代码,非常具有实用价值,需要的朋友可以参考下 在开发微信小程序的时候,遇到圆形进度条的需求。使用canvas绘图比较麻烦: 1、为了实现在不同屏幕上面的适配,必须动态的计算进度条的大小; 2、在小程序中,canvas的画布具有最…

    2025年12月24日
    000
  • CSS3实现背景透明文字不透明的效果

    这篇文章主要介绍了css3实现背景透明文字不透明的示例代码的相关资料,内容挺不错的,现在分享给大家,也给大家做个参考。 最近遇到一个需求,要在图片上显示带有半透明背景的文字,效果如下图所示: 需求.png 看到这个需求之后,第一反应是使用CSS3中的opacity设置元素的透明度。 背景透明,文字也…

    2025年12月24日 好文分享
    000
  • 利用css3设置没有上下边的列表间隔线的方法

    这篇文章主要给大家介绍了利用css3如何设置没有上下边的列表间隔线,文中分享了两种解决方法,分别是利用通用兄弟选择器( ~ )和伪类选择器( :first-of-type / :last-of-type )来实现的,给出了详细的示例代码供大家参考学习,下面来一起看看吧。 本文主要介绍了关于利用css…

    2025年12月24日
    000
  • CSS3 3D旋转rotate效果的使用介绍

    这篇文章主要为大家详细介绍了css3 3d旋转rotate效果实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了CSS3 3D旋转rotate效果实例,供大家参考,具体内容如下 效果图: 示例代码 立即学习“前端免费学习笔记(深入)”; 3D旋转的Demo #experim…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信