最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

如何使用纯CSS实现一只红色的愤怒小鸟(附代码)

来源:懂视网 责编:小采 时间:2020-11-02 22:07:13
文档

如何使用纯CSS实现一只红色的愤怒小鸟(附代码)

如何使用纯CSS实现一只红色的愤怒小鸟(附代码):本篇文章给大家带来的内容是关于如何使用纯CSS实现一只红色的愤怒小鸟(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。效果预览源代码下载https://github.com/comehope/front-end-daily-challenges代码解读定义
推荐度:
导读如何使用纯CSS实现一只红色的愤怒小鸟(附代码):本篇文章给大家带来的内容是关于如何使用纯CSS实现一只红色的愤怒小鸟(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。效果预览源代码下载https://github.com/comehope/front-end-daily-challenges代码解读定义
本篇文章给大家带来的内容是关于如何使用纯CSS实现一只红色的愤怒小鸟(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

4067026235-5b80beb268435_articlex.png

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 6 个元素,分别代表头、眼睛、眉毛、嘴、冠羽、尾巴:

<div class="red">
 <span class="head"></span>
 <span class="eyes"></span>
 <span class="eyebrows"></span>
 <span class="mouth"></span>
 <span class="hair"></span>
 <span class="tail"></span>
</div>

居中显示:

body {
 margin: 0;
 height: 100vh;
 display: flex;
 align-items: center;
 justify-content: center;
 background-color: antiquewhite;
}

设置子元素的共有属性:

.red * {
 position: absolute;
}

.red *::before,
.red *::after {
 content: '';
 position: absolute;
}

定义容器尺寸:

.red {
 width: 12em;
 height: 11em;
 font-size: 16px;
 position: relative;
}

画出头部轮廓,把描边参数定义为变量,是因为后面还会用到:

.red {
 --border: 0.2em solid #6a0306;
}

.head {
 width: inherit;
 height: inherit;
 background-color: #dc002d;
 border-radius: 45% 55% 45% 45% / 55% 60% 40% 45%;
 border: var(--border);
}

用伪元素画出眼睛的轮廓:

.eyes::before,
.eyes::after {
 width: 2.4em;
 height: 2.6em;
 background: white;
 border-radius: 50%;
 border: var(--border);
}

.eyes::before {
 top: 3.7em;
 left: 5.5em;
 z-index: 1;
}

.eyes::after {
 top: 3.8em;
 left: 7.8em;
}

用径向渐变画出眼珠和瞳孔:

.eyes::before,
.eyes::after {
 background: 
 radial-gradient(
 circle at calc(var(--eyeball-left) + 6%) 48%,
 white 0.1em,
 transparent 0.1em
 ),
 radial-gradient(
 circle at var(--eyeball-left) 48%,
 black 0.5em,
 transparent 0.5em
 ),
 white;
}

.eyes::before {
 --eyeball-left: 65%;
}

.eyes::after {
 --eyeball-left: 41%;
}

用伪元素画出眉毛:

.eyebrows::before,
.eyebrows::after {
 height: 1.1em;
 background-color: black;
 top: 3.6em;
 z-index: 2;
}

.eyebrows::before {
 left: 5em;
 transform: skewY(12deg);
 width: 3.4em;
}

.eyebrows::after {
 left: 8.2em;
 transform: skewY(-15deg);
 width: 3.1em;
}

画出嘴的轮廓:

.mouth {
 width: 2.8em;
 height: 2.8em;
 background-color: #fca90d;
 top: 6em;
 left: 7em;
 z-index: 3;
 border-radius: 20% 0 20% 10%;
 transform: rotate(34deg) skewX(-15deg);
 border: 0.1em solid black;
}

用伪元素画出上下颌的分界线:

.mouth::before {
 width: 3.4em;
 height: 4em;
 border: 0.2em solid;
 top: -1.6em;
 left: -1.8em;
 border-radius: 0 0 40% 0;
 transform: rotate(42deg);
 border-color: transparent black transparent transparent;
}

画出冠羽的左侧:

.hair {
 width: 1.2em;
 height: 3em;
 background-color: #dc002d;
 border-radius: 50%;
 border: var(--border);
 top: -1.8em;
 left: 2.8em;
 transform: rotate(-70deg);
 border-bottom-color: transparent;
}

用伪元素画出冠羽的右侧:

.hair::before {
 width: inherit;
 height: inherit;
 background-color: inherit;
 border-radius: inherit;
 border: inherit;
 top: 1em;
 left: 0.8em;
 transform: rotate(20deg);
}

用伪元素把冠羽多余的搭边线遮盖住:

.hair::after {
 width: 3em;
 height: 2em;
 background-color: #dc002d;
 border-radius: 50%;
 top: 2.3em;
 left: -1.5em;
 transform: rotate(70deg);
}

画出尾巴中最长的一根羽毛:

.tail {
 width: 3em;
 height: 1em;
 background-color: black;
 top: 40%;
 left: -1.8em;
 z-index: -1;
 transform: rotate(15deg);
}

用伪元素画出尾巴中较短的两根羽毛:

.tail::before,
.tail::after {
 width: inherit;
 height: 70%;
 background-color: black;
 left: 0.6em;
}

.tail::before {
 transform: rotate(25deg);
 top: -0.4em;
}

.tail::after {
 transform: rotate(-20deg);
 top: 0.8em;
}

用伪元素画出胸前的羽毛:

.head {
 overflow: hidden;
}

.head::before {
 width: inherit;
 height: inherit;
 background-color: #e3c4ab;
 border-radius: inherit;
 top: 65%;
 left: 25%;
}

接下来画阴影,增强立体感。

为头部增加阴影:

.head {
 box-shadow: 
 inset 0.5em -0.5em 0.3em 0.2em rgba(0, 0, 0, 0.2),
 inset -1em 0.8em 1.5em -0.5em rgba(237, 178, 144, 0.7);
}

为眼睛增加阴影:

.eyes::before {
 box-shadow: -0.2em 0.2em 0.2em 0.3em rgba(0, 0, 0, 0.2);
}

.eyes::after {
 box-shadow: 0.2em 0.2em 0.4em 0.3em rgba(0, 0, 0, 0.1);
}

为嘴增加阴影:

.mouth {
 box-shadow: 
 inset 0.2em -0.4em 1em rgba(0, 0, 0, 0.4),
 inset 0 0.5em 0.5em rgba(255, 255, 255, 0.3);
}

大功告成!

相关推荐:

如何使用纯css实现赛车的loader动画效果(附代码)

如何使用纯CSS实现冰棍的动画效果(附代码)

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

如何使用纯CSS实现一只红色的愤怒小鸟(附代码)

如何使用纯CSS实现一只红色的愤怒小鸟(附代码):本篇文章给大家带来的内容是关于如何使用纯CSS实现一只红色的愤怒小鸟(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。效果预览源代码下载https://github.com/comehope/front-end-daily-challenges代码解读定义
推荐度:
标签: 小鸟 代码 html5
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top