本篇文章给大家带来的内容是关于如何使用纯css实现一只黑色的愤怒小鸟(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
效果预览
源代码下载
https://github.com/comehope/front-end-daily-challenges
代码解读
定义 dom,容器中包含的元素分别代表
登录后复制
居中显示:
body { margin: 0; height: 100vh; display: flex; align-items: center; justify-content: center; background-color: turquoise;}
登录后复制
定义容器尺寸和伪元素的共同属性:
立即学习“前端免费学习笔记(深入)”;
.black-bomb { width: 13em; height: 13em; font-size: 16px;}.black-bomb *::before,.black-bomb *::after { content: ''; position: absolute;}
登录后复制
画出头部轮廓:
.black-bomb { position: relative;}.head { position: absolute; width: inherit; height: inherit; background-color: #0f1110; border-radius: 45% 55% 45% 55% / 55% 50% 50% 45%;}
登录后复制
用伪元素画出眼睛的轮廓:
.eyes::before,.eyes::after { width: 3.4em; height: 3.4em; background-color: #4e4e4e; border-radius: 50%;}.eyes::before { top: 2.7em; left: 21%;}.eyes::after { top: 2.5em; right: 7%;}
登录后复制
用径向渐变画出眼球和瞳孔:
.eyes::before,.eyes::after { background-image: radial-gradient( circle at var(--left3) 1.7em, white 0.1em, transparent 0.1em ), radial-gradient( circle at var(--left2) 1.6em, black 0.6em, transparent 0.6em ), radial-gradient( circle at var(--left1) 1.4em, white 1em, transparent 1em );}.eyes::before { --left1: 2em; --left2: 2.3em; --left3: 2.4em;}.eyes::after { --left1: 1.2em; --left2: 0.9em; --left3: 0.8em;}
登录后复制
用伪元素画出眉毛:
.eyebrows::before,.eyebrows::after { width: 5.3em; height: 0.8em; background: #cb3c1a;}.eyebrows::before { top: 2.3em; left: 1em; transform: rotate(10deg);}.eyebrows::after { top: 2.2em; right: -0.6em; transform: rotate(-10deg);}
登录后复制
画出嘴的轮廓:
.mouth { position: absolute; width: 3.6em; height: 3.6em; background-color: #fca90d; top: 4em; left: 6.4em; border-radius: 80% 0 30% 20%; transform: rotate(34deg); border: 0.1em solid black;}
登录后复制
用伪元素画出上下颌的分界线:
.mouth::before { width: 2.6em; height: 5.7em; border: 0.2em solid; border-radius: 80% 0 0 16%; transform: rotate(35deg); top: -1.1em; left: 1.4em; border-color: transparent transparent transparent black;}
登录后复制
画出胸前的羽毛:
.head { overflow: hidden;}.head::before { width: inherit; height: inherit; background-color: #474642; border-radius: inherit; top: 76%; left: 12%;}
登录后复制
画出冠羽:
.hair { position: absolute; width: 1.4em; height: 5em; background-color: #0f1110; top: -3.8em; left: 20%; border-radius: 0 0 40% 40% / 0 0 100% 100%;}.hair::before { width: 80%; height: 1em; background-color: #ffc000; top: 0.3em; left: 10%;}
登录后复制
调整冠羽的形状:
.hair { transform: rotate(-28deg) skewX(10deg) skewY(-50deg);}
登录后复制
接下来画阴影,增强立体感。
为头部增加阴影:
.head { box-shadow: inset -1em 0.5em 1.5em -0.5em rgba(255, 255, 255, 0.3);}.head::after { width: inherit; height: inherit; border-radius: inherit; box-shadow: inset 0.5em -0.5em 0.3em 0.2em rgba(0, 0, 0, 0.2);}
登录后复制
为嘴增加阴影:
.mouth { box-shadow: inset 0 0.5em 0.5em rgba(255, 255, 255, 0.3), inset 0.2em -0.5em 1.2em rgba(0, 0, 0, 0.5);}
登录后复制
大功告成!
相关推荐:
如何使用CSS和D3实现黑白交叠的动画效果
如何使用CSS和D3实现黑白交叠的动画效果
以上就是如何使用纯CSS实现一只黑色的愤怒小鸟(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2743127.html