CSS+transform画动态表情
先给大家看下画完后是什么样子:

代码看这里:
html代码:
<body>
<div class="emoji emoji_like">
<div class="emoji_hand">
<div class="emoji_thumb"></div>
</div>
</div>
<div class="emoji emoji_love">
<div class="emoji_heart"></div>
</div>
<div class="emoji emoji_haha">
<div class="emoji_face">
<div class="emoji_eyes"></div>
<div class="emoji_mouth">
<div class="emoji_tongue"></div>
</div>
</div>
</div>
<div class="emoji emoji_yay">
<div class="emoji_face">
<div class="emoji_eyebrows"></div>
<div class="emoji_mouth"></div>
</div>
</div>
<div class="emoji emoji_wow">
<div class="emoji_face">
<div class="emoji_eyebrows"></div>
<div class="emoji_eyes"></div>
<div class="emoji_mouth"></div>
</div>
</div>
<div class="emoji emoji_sad">
<div class="emoji_face">
<div class="emoji_eyebrows"></div>
<div class="emoji_eyes"></div>
<div class="emoji_mouth"></div>
</div>
</div>
<div class="emoji emoji_angry">
<div class="emoji_face">
<div class="emoji_eyebrows"></div>
<div class="emoji_eyes"></div>
<div class="emoji_mouth"></div>
</div>
</div>
<div><a href="http://www.cnblogs.com/yingzi1028/"></a></div>
</body>
css代码:
<style>
body {
text-align: center;
margin: 80px auto 0;
font-family: "Lucida Sans Unicode", "Lucida Grande", sans-serif;
} .emoji {
width: 120px;
height: 120px;
margin: 15px;
background: #FFDA6A;
display: inline-block;
border-radius: 50%;
position: relative;
} .emoji:after {
position: absolute;
bottom: -40px;
font-size: 18px;
width: 60px;
left: calc(50% - 30px);
color: #8A8A8A;
} .emoji_face,
.emoji_eyebrows,
.emoji_eyes,
.emoji_mouth,
.emoji_tongue,
.emoji_heart,
.emoji_hand,
.emoji_thumb {
position: absolute;
} .emoji_face:before,
.emoji_face:after,
.emoji_eyebrows:before,
.emoji_eyebrows:after,
.emoji_eyes:before,
.emoji_eyes:after,
.emoji_mouth:before,
.emoji_mouth:after,
.emoji_tongue:before,
.emoji_tongue:after,
.emoji_heart:before,
.emoji_heart:after,
.emoji_hand:before,
.emoji_hand:after,
.emoji_thumb:before,
.emoji_thumb:after {
position: absolute;
content: '';
} .emoji_face {
width: inherit;
height: inherit;
} .emoji_like {
background: #fdbfca;
} .emoji_like:after {
content: 'Like';
} .emoji_like .emoji_hand {
left: 25px;
bottom: 30px;
width: 20px;
height: 40px;
background: #FFFFFF;
border-radius: 5px;
z-index:;
animation: hands-up 2s linear infinite;
} .emoji_like .emoji_hand:before {
left: 25px;
bottom: 5px;
width: 40px;
background: inherit;
height: 10px;
border-radius: 2px 10px 10px 2px;
box-shadow: 1px -9px 0 1px #FFFFFF, 2px -19px 0 2px #FFFFFF, 3px -29px 0 3px #FFFFFF;
} .emoji_like .emoji_thumb {
border-bottom: 20px solid #FFFFFF;
border-left: 20px solid transparent;
top: -25px;
right: -25px;
z-index:;
transform: rotate(5deg);
transform-origin: 0% 100%;
animation: thumbs-up 2s linear infinite;
} .emoji_like .emoji_thumb:before {
border-radius: 50% 50% 0 0;
background: #FFFFFF;
width: 10px;
height: 12px;
left: -10px;
top: -8px;
transform: rotate(-15deg);
transform-origin: 100% 100%;
box-shadow: -1px 4px 0 -1px #FFFFFF;
} .emoji_love {
background: #fdbfca;
} .emoji_love:after {
content: 'Love';
} .emoji_love .emoji_heart {
left: calc(50% - 40px);
top: calc(50% - 40px);
width: 80px;
height: 80px;
animation: heart-beat 1s linear infinite alternate;
} .emoji_love .emoji_heart:before,
.emoji_love .emoji_heart:after {
left: calc(50% - 20px);
top: calc(50% - 32px);
width: 40px;
height: 64px;
background: #fdf81f;
border-radius: 20px 20px 0 0;
} .emoji_love .emoji_heart:before {
transform: translate(20px) rotate(-45deg);
transform-origin: 0 100%;
} .emoji_love .emoji_heart:after {
transform: translate(-20px) rotate(45deg);
transform-origin: 100% 100%;
} .emoji_haha:after {
content: 'Haha';
} .emoji_haha .emoji_face {
animation: haha-face 2s linear infinite;
} .emoji_haha .emoji_eyes {
width: 26px;
height: 6px;
border-radius: 2px;
left: calc(50% - 13px);
top: 35px;
transform: rotate(20deg);
background: transparent;
box-shadow: -25px 5px 0 0 #000000, 25px -5px 0 0 #000000;
} .emoji_haha .emoji_eyes:after {
left:;
top:;
width: 26px;
height: 6px;
border-radius: 2px;
transform: rotate(-40deg);
background: transparent;
box-shadow: -25px -5px 0 0 #000000, 25px 5px 0 0 #000000;
} .emoji_haha .emoji_mouth {
width: 80px;
height: 40px;
left: calc(50% - 40px);
top: 50%;
background: #000000;
border-radius: 0 0 40px 40px;
overflow: hidden;
z-index:;
animation: haha-mouth 2s linear infinite;
} .emoji_haha .emoji_tongue {
width: 70px;
height: 30px;
background: #F55064;
left: calc(50% - 35px);
bottom: -10px;
border-radius: 50%;
} .emoji_yay:after {
content: 'Yay';
animation: yay-reverse 1s linear infinite;
} .emoji_yay .emoji_face {
animation: yay 1s linear infinite alternate;
} .emoji_yay .emoji_eyebrows {
left: calc(50% - 3px);
top: 30px;
height: 6px;
width: 6px;
border-radius: 50%;
background: transparent;
box-shadow: -6px 0 0 0 #000000, -36px 0 0 0px #000000, 6px 0 0 0 #000000, 36px 0 0 0px #000000;
} .emoji_yay .emoji_eyebrows:before,
.emoji_yay .emoji_eyebrows:after {
width: 36px;
height: 18px;
border-radius: 60px 60px 0 0;
background: transparent;
border: 6px solid black;
box-sizing: border-box;
border-bottom:;
bottom: 3px;
left: calc(50% - 18px);
} .emoji_yay .emoji_eyebrows:before {
margin-left: -21px;
} .emoji_yay .emoji_eyebrows:after {
margin-left: 21px;
} .emoji_yay .emoji_mouth {
top: 60px;
background: transparent;
left: 50%;
} .emoji_yay .emoji_mouth:after {
width: 80px;
height: 80px;
left: calc(50% - 40px);
top: -75px;
border-radius: 50%;
background: transparent;
border: 6px solid #000000;
box-sizing: border-box;
border-top-color: transparent;
border-left-color: transparent;
border-right-color: transparent;
z-index:;
} .emoji_yay .emoji_mouth:before {
width: 6px;
height: 6px;
background: transparent;
border-radius: 50%;
bottom: 5px;
left: calc(50% - 3px);
box-shadow: -25px 0 0 0 #000000, 25px 0 0 0 #000000, -35px -2px 30px 10px #D5234C, 35px -2px 30px 10px #D5234C;
} .emoji_wow:after {
content: 'Wow';
} .emoji_wow .emoji_face {
animation: wow-face 3s linear infinite;
} .emoji_wow .emoji_eyebrows {
left: calc(50% - 3px);
height: 6px;
width: 6px;
border-radius: 50%;
background: transparent;
box-shadow: -18px 0 0 0 #000000, -33px 0 0 0 #000000, 18px 0 0 0 #000000, 33px 0 0 0 #000000;
animation: wow-brow 3s linear infinite;
} .emoji_wow .emoji_eyebrows:before,
.emoji_wow .emoji_eyebrows:after {
width: 24px;
height: 20px;
border: 6px solid #000000;
box-sizing: border-box;
border-radius: 50%;
border-bottom-color: transparent;
border-left-color: transparent;
border-right-color: transparent;
top: -3px;
left: calc(50% - 12px);
} .emoji_wow .emoji_eyebrows:before {
margin-left: -25px;
} .emoji_wow .emoji_eyebrows:after {
margin-left: 25px;
} .emoji_wow .emoji_eyes {
width: 16px;
height: 24px;
left: calc(50% - 8px);
top: 35px;
border-radius: 50%;
background: transparent;
box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
} .emoji_wow .emoji_mouth {
width: 30px;
height: 45px;
left: calc(50% - 15px);
top: 50%;
border-radius: 50%;
background: #000000;
animation: wow-mouth 3s linear infinite;
} .emoji_sad:after {
content: 'Sad';
} .emoji_sad .emoji_face {
animation: sad-face 2s ease-in infinite;
} .emoji_sad .emoji_eyebrows {
left: calc(50% - 3px);
top: 35px;
height: 6px;
width: 6px;
border-radius: 50%;
background: transparent;
box-shadow: -40px 9px 0 0 #000000, -25px 0 0 0 #000000, 25px 0 0 0 #000000, 40px 9px 0 0 #000000;
} .emoji_sad .emoji_eyebrows:before,
.emoji_sad .emoji_eyebrows:after {
width: 30px;
height: 20px;
border: 6px solid #000000;
box-sizing: border-box;
border-radius: 50%;
border-bottom-color: transparent;
border-left-color: transparent;
border-right-color: transparent;
top: 2px;
left: calc(50% - 15px);
} .emoji_sad .emoji_eyebrows:before {
margin-left: -30px;
transform: rotate(-30deg);
} .emoji_sad .emoji_eyebrows:after {
margin-left: 30px;
transform: rotate(30deg);
} .emoji_sad .emoji_eyes {
width: 14px;
height: 16px;
left: calc(50% - 7px);
top: 50px;
border-radius: 50%;
background: transparent;
box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
} .emoji_sad .emoji_eyes:after {
background: #548DFF;
width: 12px;
height: 12px;
margin-left: 6px;
border-radius: 0 100% 40% 50% / 0 50% 40% 100%;
transform-origin: 0% 0%;
animation: tear-drop 2s ease-in infinite;
} .emoji_sad .emoji_mouth {
width: 60px;
height: 80px;
left: calc(50% - 30px);
top: 80px;
box-sizing: border-box;
border: 6px solid #000000;
border-radius: 50%;
border-bottom-color: transparent;
border-left-color: transparent;
border-right-color: transparent;
background: transparent;
animation: sad-mouth 2s ease-in infinite;
} .emoji_sad .emoji_mouth:after {
width: 6px;
height: 6px;
background: transparent;
border-radius: 50%;
top: 4px;
left: calc(50% - 3px);
box-shadow: -18px 0 0 0 #000000, 18px 0 0 0 #000000;
} .emoji_angry {
background: linear-gradient(#D5234C -10%, #FFDA6A);
background-size: 100%;
animation: angry-color 2s ease-in infinite;
} .emoji_angry:after {
content: 'Angry';
} .emoji_angry .emoji_face {
animation: angry-face 2s ease-in infinite;
} .emoji_angry .emoji_eyebrows {
left: calc(50% - 3px);
top: 55px;
height: 6px;
width: 6px;
border-radius: 50%;
background: transparent;
box-shadow: -44px 5px 0 0 #000000, -7px 16px 0 0 #000000, 7px 16px 0 0 #000000, 44px 5px 0 0 #000000;
} .emoji_angry .emoji_eyebrows:before,
.emoji_angry .emoji_eyebrows:after {
width: 50px;
height: 20px;
border: 6px solid #000000;
box-sizing: border-box;
border-radius: 50%;
border-top-color: transparent;
border-left-color: transparent;
border-right-color: transparent;
top:;
left: calc(50% - 25px);
} .emoji_angry .emoji_eyebrows:before {
margin-left: -25px;
transform: rotate(15deg);
} .emoji_angry .emoji_eyebrows:after {
margin-left: 25px;
transform: rotate(-15deg);
} .emoji_angry .emoji_eyes {
width: 12px;
height: 12px;
left: calc(50% - 6px);
top: 70px;
border-radius: 50%;
background: transparent;
box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
} .emoji_angry .emoji_mouth {
width: 36px;
height: 18px;
left: calc(50% - 18px);
bottom: 15px;
background: #000000;
border-radius: 50%;
animation: angry-mouth 2s ease-in infinite;
} @keyframes heart-beat {
25% {
transform: scale(1.1);
}
75% {
transform: scale(0.6);
}
} @keyframes haha-face {
10% {
transform: translateY(25px);
}
20% {
transform: translateY(15px);
}
30% {
transform: translateY(25px);
}
40% {
transform: translateY(15px);
}
50% {
transform: translateY(25px);
}
60% {
transform: translateY(0);
}
70% {
transform: translateY(-10px);
}
80% {
transform: translateY(0);
}
90% {
transform: translateY(-10px);
}
} @keyframes haha-mouth {
10% {
transform: scale(0.6);
top: 45%;
}
20% {
transform: scale(0.8);
top: 45%;
}
30% {
transform: scale(0.6);
top: 45%;
}
40% {
transform: scale(0.8);
top: 45%;
}
50% {
transform: scale(0.6);
top: 45%;
}
60% {
transform: scale(1);
top: 50%;
}
70% {
transform: scale(1.2);
top: 50%;
}
80% {
transform: scale(1);
top: 50%;
}
90% {
transform: scale(1.1);
top: 50%;
}
} @keyframes yay {
25% {
transform: rotate(-15deg);
}
75% {
transform: rotate(15deg);
}
} @keyframes wow-face {
15%,
25% {
transform: rotate(20deg) translateX(-25px);
}
45%,
65% {
transform: rotate(-20deg) translateX(25px);
}
75%,
100% {
transform: rotate(0deg) translateX(0);
}
} @keyframes wow-brow {
15%,
65% {
top: 25px;
}
75%,
100%,
0% {
top: 15px;
}
} @keyframes wow-mouth {
10%,
30% {
width: 20px;
height: 20px;
left: calc(50% - 10px);
}
50%,
70% {
width: 30px;
height: 40px;
left: calc(50% - 15px);
}
75%,
100% {
height: 50px;
}
} @keyframes sad-face {
25%,
35% {
top: -15px;
}
55%,
95% {
top: 10px;
}
100%,
0% {
top:;
}
} @keyframes sad-mouth {
25%,
35% {
transform: scale(0.85);
top: 70px;
}
55%,
100%,
0% {
transform: scale(1);
top: 80px;
}
} @keyframes tear-drop {
0%,
100% {
display: block;
left: 35px;
top: 15px;
transform: rotate(45deg) scale(0);
}
25% {
display: block;
left: 35px;
transform: rotate(45deg) scale(2);
}
49.9% {
display: block;
left: 35px;
top: 65px;
transform: rotate(45deg) scale(0);
}
50% {
display: block;
left: -35px;
top: 15px;
transform: rotate(45deg) scale(0);
}
75% {
display: block;
left: -35px;
transform: rotate(45deg) scale(2);
}
99.9% {
display: block;
left: -35px;
top: 65px;
transform: rotate(45deg) scale(0);
}
} @keyframes hands-up {
25% {
transform: rotate(15deg);
}
50% {
transform: rotate(-15deg) translateY(-10px);
}
75%,
100% {
transform: rotate(0deg);
}
} @keyframes thumbs-up {
25% {
transform: rotate(20deg);
}
50%,
100% {
transform: rotate(5deg);
}
} @keyframes angry-color {
45%,
60% {
background-size: 250%;
}
85%,
100%,
0% {
background-size: 100%;
}
} @keyframes angry-face {
35%,
60% {
transform: translateX(0) translateY(10px) scale(0.9);
}
40% {
transform: translateX(-5px) translateY(10px) scale(0.9);
}
45% {
transform: translateX(5px) translateY(10px) scale(0.9);
}
50% {
transform: translateX(-5px) translateY(10px) scale(0.9);
}
55% {
transform: translateX(5px) translateY(10px) scale(0.9);
}
} @keyframes angry-mouth {
25%,
50% {
height: 6px;
bottom: 25px;
}
}
</style>
CSS+transform画动态表情的更多相关文章
- [css]我要用css画幅画(三)
接着之前的[css]我要用css画幅画(二), 今天,我画了一个小人,他的名字暂时叫作小明. 以下只列出本次修改增加的内容 html如下: <div class="human left ...
- [css]我要用css画幅画(二)
接着之前的[css]我要用css画幅画(一) , 今天,我又画一个房子,很简单,屋顶.墙壁.门. 现在开始,做得效果都只兼容chrome,所以下面的css3的属性可能只有-webkit-前缀. 我只是 ...
- [css]我要用css画幅画(一)
几年前开始就一直想用css画幅画. 今天才真正开始, 从简单的开始. 作为一个工作压力那么大的程序员,我首先要画一个太阳. html如下: <!DOCTYPE html> <html ...
- No.3 - CSS transition 和 CSS transform 配合制作动画
课程概述 作业提交截止时间:09-01 任务目的 深度理解掌握 transition-timing-function 以及它的意义 学会配合使用 CSS transform 和CSS transiti ...
- [css]我要用css画幅画(九) - Apple Logo
接着之前的[css]我要用css画幅画(八) - Hello Kitty,这次画的是苹果公司的logo 这次打算将分析和实现步骤尽量详细的说一说. 其实之前的也打算详细讲分析和设计过程,不过之前的图比 ...
- [css]我要用css画幅画(八) - Hello Kitty
接着之前的[css]我要用css画幅画(七) - 哆啦A梦,这次画的是Hello Kitty. /* 开始前先说点废话, 一转眼就2016年了,过完年后一直没更新博客,无他,就是懒得动. 这一转眼,一 ...
- [css]我要用css画幅画(七) - 哆啦A梦
接着之前的[css]我要用css画幅画(六),今天画的有所不同,画的是哆啦A梦,我们小时候对他的称呼其实是小叮当机器猫. (PS:这次我要做的事情,很多人已经做过,这并不是什么创新,我只是在学习并记录 ...
- [css]我要用css画幅画(六)
接着之前的[css]我要用css画幅画(五), 由于这个画已经画了很久了,这次一次性加了比较多更新,算是让这幅画告一段落吧. 本次的更新包括: 1. 给云增加动画 2. 画了一棵树 3. 树上画了一个 ...
- [css]我要用css画幅画(五)
接着之前的[css]我要用css画幅画(四), 这次我给小明和静静增加了对话,用了简单的动画效果. github:https://github.com/bee0060/Css-Paint , 完整代码 ...
随机推荐
- 使用nginx反向代理解决前端跨域问题
1. 首先去Nginx官网下载一个最新版本的Nginx,下载地址:http://nginx.org/en/download.html.我这里下载的版本是:nginx/Windows-1.12.0.下载 ...
- 系统目录结构/ls命令/文件类型/alias命令
2.1/2.2 系统目录结构 2.3 ls命令 2.4 文件类型 2.5 alias命令 linux文件目录结构 linux文件结构 / 系统跟目录 root root用户主目录,存放启动linux ...
- 【Intel AF 2.1 学习笔记三】
AF中自带一些Css矢量图标,使用时需要设置class,例如下面代码显示一个左箭头图标: <a class="icon left"></a> AF中可用的图 ...
- 网页CSS常用中英文字体收集
Windows的中文字体: 黑体:SimHei 宋体:SimSun 新宋体:NSimSun 仿宋:FangSong 楷体:KaiTi 仿宋_GB2312:FangSong_GB2312 楷体_GB23 ...
- Spring Boot项目使用Eclipse进行断点调试Debug
1.在命令行下定位到项目根目录,启动Spring Boot项目,命令如下: java -Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=80 ...
- VS常用快捷鍵
折疊所有方法 Ctrl +M +M 折疊單個方法 Ctrl +M +O 折疊單個方法
- springmvc+jsp 拦截器下如何设置欢迎页面
0.需求 如何让用户在浏览器地址栏键入[http://XXX.XXX.XX.XX:端口号/应用名/]以后自动跳转到系统的登录界面 1.web.xml 1.1 注意welcome-file-list的配 ...
- Vim终极指南:所思即所得
https://blog.csdn.net/dc_726/article/details/78981756
- IOS 基于APNS消息推送原理与实现(JAVA后台)--转
Push的原理: Push 的工作机制可以简单的概括为下图 图中,Provider是指某个iPhone软件的Push服务器,这篇文章我将使用.net作为Provider. APNS 是Apple ...
- Android开发真机测试方法 (转)
转自:http://blog.csdn.net/china_lzn/article/details/7461963 Android的AVD无比的慢,无语啊,程序编的再好,都无法体验到流畅的感觉,索性, ...