博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何用纯 CSS 创作一只愤怒小鸟中的黑炮
阅读量:6330 次
发布时间:2019-06-22

本文共 3351 字,大约阅读时间需要 11 分钟。

在这里插入图片描述

效果预览

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

可交互视频

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

代码解读

定义 dom,容器中包含的元素分别代表

<div class="black-bomb">    <span class="head"></span>    <span class="eyes"></span>    <span class="eyebrows"></span>    <span class="mouth"></span>    <span class="hair"></span></div>

居中显示:

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);}

大功告成!

原文地址:

转载地址:http://ynboa.baihongyu.com/

你可能感兴趣的文章
ThinkPHP 3.2.x 集成极光推送指北
查看>>
MYSQL 表情评论存储(emoji)
查看>>
js作用域链
查看>>
java中如何选择Collection Class--java线程(第3版)
查看>>
为运维人员插上腾飞更远的翅膀!
查看>>
Word 2003中编辑标记与格式标记大讨论
查看>>
从国内向海外转移域名经验谈
查看>>
浅谈apache与tomact的整合
查看>>
SQL Server vNext CTP1 on Linux
查看>>
1-为 Lync Server 2010 准备 Active Directory 域服务
查看>>
SELinux安全
查看>>
NetBackup下ORACLE恢复测试方案实例解析
查看>>
【有奖征文】“失业”程序员的苦辣酸甜
查看>>
IE9是如何被FireFox4超越全球市场份额的?
查看>>
linux bunzip2命令
查看>>
敏捷个人:通过实践TOGAF来思考如何学习并应用新的方法?
查看>>
Android系统的开机画面显示过程分析(6)
查看>>
vivo Hi-Fi+QQ音乐 数字音乐市场的一剂良方
查看>>
Cocos2d-x 3.2 异步动态加载 -- 保卫萝卜开发总结
查看>>
聚焦触宝反侵权事件:中国创业者用什么护航海外市场大门
查看>>