本篇文章给大家带来的内容是关于如何使用纯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实现货车loader的效果

php开发愤怒的小鸟,如何使用纯CSS实现一只黑色的愤怒小鸟(附代码)相关推荐

  1. html用css写彩虹,如何使用纯CSS实现彩虹条纹文字的效果(附代码)

    本篇文章给大家带来的内容是关于如何使用纯CSS实现彩虹条纹文字的效果(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 效果预览 源代码下载 https://github.co ...

  2. html导航去下划线,纯CSS实现导航栏下划线跟随的示例代码

    本篇文章主要介绍了纯CSS实现导航栏下划线跟随的示例代码,分享给大家,具体如下: 效果: 代码: html: aaaa bbbbbbb cccc dddd eeee css: ul { padding ...

  3. 用css做一个移动射击动画,如何使用纯CSS实现一只移动的小白兔动画效果

    本篇文章给大家带来的内容是关于如何使用纯CSS实现一只移动的小白兔动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 效果预览 代码解读 定义 dom,页面中包含 2 个元素,分 ...

  4. 73.纯 CSS 创作一只卡通狐狸

    73.纯 CSS 创作一只卡通狐狸 原文地址:https://segmentfault.com/a/1190000015566332 学习效果地址:https://scrimba.com/c/cz6E ...

  5. 纯CSS实现简约大方灰紫色下拉菜单代码

    代码简介:又一个漂亮的纯CSS实现的下拉导航菜单,横向布局,适合作网站导航条,银色渐变色,鼠标放上更换菜单背景,用户体验极好,而且兼容性好,特别是对IE比较友好,火狐下也几乎不错位,推荐给站长使用. ...

  6. 心形源码HTML,纯CSS实现心形加载动画(附源码)

    本篇文章给大家介绍一下纯CSS实现心形加载动画的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. 废话不多说上代码,代码很简答,研究一下就明白了,有不明白的可以问我. .hear ...

  7. php万圣节源码,如何使用纯CSS实现万圣节的toggle控件(附源码)

    本篇文章给大家带来的内容是关于如何使用纯CSS实现万圣节的toggle控件(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 效果预览 源代码地址 https://github ...

  8. 轮回眼css,纯CSS如何实现血轮眼+轮回眼特效(代码详解)

    本篇文章给大家介绍一下使用纯CSS实现血轮眼+轮回眼特效的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助. 效果(完整代码在底部) 其实实现并不难,都是重复的代码比较多. 实现(可 ...

  9. html表格实现图片排列布局,纯css实现朋友圈照片排列布局(附单图自适应宽高)...

    效果图 image.png image.png image.png image.png image.png 思路 设置flex实现正常的三列布局 ul{ padding:0px; width:300p ...

最新文章

  1. 6.package配置相关
  2. python单词意思-Python这个单词是什么含义??????????????
  3. mysql stored procedures with return values
  4. Confluence 6 归档一个空间
  5. linux CentOS7 磁盘分区fdisk 、df 、du、parted 命令实例
  6. Ubuntu apt update(apt-get update)报错、失败
  7. 关于对玩过的游戏的想法汇总
  8. 传感器工作原理_荧光氧气传感器工作原理简介
  9. 初学oracle遇到些小麻烦
  10. static_cast、dynamic_cast、reinterpret_cast、和const_cast
  11. python系统下载-python
  12. 纯JavaScript实现HTML5 Canvas六种特效滤镜
  13. 配置Android的SDK,DNK,JDK,ANT打包APK环境
  14. 关于travis scott的网名_异地恋情侣网名甜蜜秀恩爱
  15. 深度学习双显卡配置_更新深度学习装备:双(1080Ti)显卡装机实录
  16. wordpress主题安装,wp主题模板安装技巧
  17. 世界上最值钱的初创公司
  18. RabbitMQ入门中篇
  19. excel打不开怎么办_第52期分享:Excel大佬有哪些骚操作呢?
  20. Mysql分组取每组排序后第一个

热门文章

  1. AJAX跨域访问(不同域之间相互访问)
  2. 素数(质数)判断的五种方法
  3. python爬虫框架scrap_python的爬虫框架scrap是什么?怎么用?
  4. Linq to Sql 语句全集
  5. cas5.3.14二,cas介绍及登陆流程
  6. php 微信支付证书,微信支付后台进行退款操作时提示证书已过期处理(PHP)
  7. Web开发-简单BBS论坛
  8. MATH-现代=矩阵
  9. GLUT使用の太阳系天体绘制
  10. JavaScript Extensible Attributes 常用匹配方法