效果预览

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

https://codepen.io/comehope/pen/MqpOdR/

可交互视频

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

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

https://scrimba.com/p/pEgDAM/czZnbsr

源代码下载

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

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

代码解读

定义 dom,容器中包含 3 个元素,分别代表头、身体和脚:

<div class="man"><span class="head"></span><span class="body"></span><span class="feet"></span>
</div>

居中显示:

body {margin: 0;height: 100vh;display: flex;align-items: center;justify-content: center;background: radial-gradient(lightgray 20%, whitesmoke);
}

定义容器尺寸:

.man {width: 12em;height: 33em;font-size: 10px;position: relative;
}

定义主色:

.man {color: white;
}

画出头部:

.head {position: absolute;width: 7em;height: 7em;background-color: currentColor;border-radius: 50%;right: 0;
}

画出身体:

.body {position: absolute;width: 6.2em;height: 14.4em;background-color: currentColor;top: 7em;border-radius: 100% 20% 0 0;
}

画出脚,现在只能看到一只脚,是因为两只脚重叠在一起,一会儿动起来时就能看到两只脚了:

.feet::before,
.feet::after {content: '';position: absolute;width: 4em;height: 1.4em;background-color: white;bottom: 0;left: -1.6em;border-radius: 1em 80% 0.4em 0.4em;
}

用伪元素画出阴影:

.man::before {content: '';position: absolute;width: 12em;height: 0.8em;background-color: rgba(0, 0, 0, 0.1);bottom: -0.2em;left: -3em;border-radius: 50%;
}

接下来增加动画效果。

增加行走的动画效果,并使两只脚的动画时间交错:

.feet::before,
.feet::after {animation: feet-animation 2s ease-in-out infinite;
}.feet::after {animation-delay: 1s;
}@keyframes feet-animation {20% {transform: translateX(3.4em) translateY(-1.6em) rotate(4deg);}30% {transform: translateX(4.6em) translateY(-1em) rotate(0deg);}40% {transform: translateX(5.6em) translateY(-0.6em) rotate(4deg);}44% {transform: translateX(5.6em) translateY(0) rotate(0deg);}
}

增加头和身体起伏的动画效果:

.head,
.body {animation: body-animation 4s ease-in-out infinite;
}@keyframes body-animation {0%, 100% {transform: translateY(0) skewX(-2deg);}25%, 75% {transform: translateY(0.5em) skewX(0deg);}50% {transform: translateY(0) skewX(0deg);}
}

增加阴影面积随身体运动而变化的动画效果:

.man::before {animation: shadow-animate 4s ease-in-out infinite;
}@keyframes shadow-animate {0%, 50%, 100% {transform: scale(1);}25%, 75% {transform: scale(1.15);}
}

大功告成!

前端每日实战:125# 视频演示如何用纯 CSS 创作一个失落的人独自行走的动画...相关推荐

  1. 如何用纯 CSS 创作一个失落的人独自行走的动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MqpOdR/ 可交互视频 ...

  2. 如何用纯 CSS 创作一个失落的人独自行走的动画 1

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MqpOdR/ 可交互视频 ...

  3. 前端每日实战:45# 视频演示如何用纯 CSS 创作一个菱形 loader 动画

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/eKzjqK 可交互视频教程 此视频 ...

  4. html鼠标拖尾效果,前端每日实战:25# 视频演示如何用纯 CSS 创作一个慧星拖尾效果的 loader 动画...

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. 可交互视频教程 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, s ...

  5. 前端每日实战:102# 视频演示如何用纯 CSS 创作一个小和尚

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oMmYXp 可交互视频 此视频是可 ...

  6. 前端每日实战:160# 视频演示如何用纯 CSS 创作一个打开内容弹窗的交互动画...

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/GYXvez 可交互视频 此视频是可 ...

  7. 前端每日实战:119# 视频演示如何用纯 CSS 创作一个接扎啤的动画(内含2个视频)...

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/rZeOQp 可交互视频 此视频是可 ...

  8. 前端每日实战:84# 视频演示如何用纯 CSS 创作一个极品飞车 loader

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MBbEMo 可交互视频 此视频是可 ...

  9. python绘制图形沙漏_前端每日实战:118# 视频演示如何用纯 CSS 创作一个沙漏 loader...

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, saf ...

最新文章

  1. java Windows7 下环境变量设置
  2. java io字符输出流_【Java的IO流之文件字符输入输出流 25】
  3. Java高版本编译低版本运行_Java高版本编译低版本运行错误(ConcurrentHashMap.keySet)...
  4. 如何求两个向交矩形的交集的面积?
  5. javaweb中实现分页,持续更新……
  6. 【编程】用户体验与软件产品
  7. android studio的 gradle 依赖同步错误解决方法
  8. 浙大 PAT 乙级1056
  9. html 自动连接websocket_SpringBoot + WebSocket 实现实时聊天
  10. 软测人员周报怎么写?(模板)
  11. C语言入门项目篇:贪吃蛇(完整代码+详细注释)
  12. 能源DEA-动态SBM模型
  13. 位图管理、图片下载缓存、管理图片内存 (三) 在非UI线程中处理位图
  14. mysql stmt语法_mysqli_stmt_fetch
  15. Mac电脑的文件快捷访问工具:Default Folder X 5
  16. 固态硬盘坏了怎么恢复数据恢复
  17. c语言产生50以内随机数,C语言产生随机数
  18. ../Libraries/core_cm3.c(445): error: non-ASM statement in naked function is not supported
  19. [深度学习论文笔记]Multi-phase Liver Tumor Segmentation with Spatial Aggregation
  20. iOS开发之Xcode8:subsystem: com.apple.siri, category: Intents, enable_level: 1, persist_level: 1, defaul

热门文章

  1. 前端图片在线压缩的网站
  2. 交换网络环路解决方案
  3. 如何通过https访问网站(也就是如何部署SSL证书)
  4. 线下auc涨,线上ctr/cpm跌的原因和解决办法
  5. STM32 GPIO 详解
  6. MySQL Cluste(进阶篇)—集群配置
  7. 物体空间姿态估计// Robust Planar Pose (RPP)algorithm
  8. c语言试题 斗牛,书戴嵩画牛阅读试题训练附答案
  9. QQ超级秘笈:免费申请QQ号码(转)
  10. java 鸢尾花分类算法_鸢尾花分类算法实现 java