前端每日实战:125# 视频演示如何用纯 CSS 创作一个失落的人独自行走的动画...
效果预览
按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。
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 创作一个失落的人独自行走的动画...相关推荐
- 如何用纯 CSS 创作一个失落的人独自行走的动画
效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MqpOdR/ 可交互视频 ...
- 如何用纯 CSS 创作一个失落的人独自行走的动画 1
效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MqpOdR/ 可交互视频 ...
- 前端每日实战:45# 视频演示如何用纯 CSS 创作一个菱形 loader 动画
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/eKzjqK 可交互视频教程 此视频 ...
- html鼠标拖尾效果,前端每日实战:25# 视频演示如何用纯 CSS 创作一个慧星拖尾效果的 loader 动画...
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. 可交互视频教程 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, s ...
- 前端每日实战:102# 视频演示如何用纯 CSS 创作一个小和尚
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oMmYXp 可交互视频 此视频是可 ...
- 前端每日实战:160# 视频演示如何用纯 CSS 创作一个打开内容弹窗的交互动画...
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/GYXvez 可交互视频 此视频是可 ...
- 前端每日实战:119# 视频演示如何用纯 CSS 创作一个接扎啤的动画(内含2个视频)...
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/rZeOQp 可交互视频 此视频是可 ...
- 前端每日实战:84# 视频演示如何用纯 CSS 创作一个极品飞车 loader
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/MBbEMo 可交互视频 此视频是可 ...
- python绘制图形沙漏_前端每日实战:118# 视频演示如何用纯 CSS 创作一个沙漏 loader...
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, saf ...
最新文章
- java Windows7 下环境变量设置
- java io字符输出流_【Java的IO流之文件字符输入输出流 25】
- Java高版本编译低版本运行_Java高版本编译低版本运行错误(ConcurrentHashMap.keySet)...
- 如何求两个向交矩形的交集的面积?
- javaweb中实现分页,持续更新……
- 【编程】用户体验与软件产品
- android studio的 gradle 依赖同步错误解决方法
- 浙大 PAT 乙级1056
- html 自动连接websocket_SpringBoot + WebSocket 实现实时聊天
- 软测人员周报怎么写?(模板)
- C语言入门项目篇:贪吃蛇(完整代码+详细注释)
- 能源DEA-动态SBM模型
- 位图管理、图片下载缓存、管理图片内存 (三) 在非UI线程中处理位图
- mysql stmt语法_mysqli_stmt_fetch
- Mac电脑的文件快捷访问工具:Default Folder X 5
- 固态硬盘坏了怎么恢复数据恢复
- c语言产生50以内随机数,C语言产生随机数
- ../Libraries/core_cm3.c(445): error: non-ASM statement in naked function is not supported
- [深度学习论文笔记]Multi-phase Liver Tumor Segmentation with Spatial Aggregation
- iOS开发之Xcode8:subsystem: com.apple.siri, category: Intents, enable_level: 1, persist_level: 1, defaul