先给大家看下画完后是什么样子:

代码看这里:

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画动态表情的更多相关文章

  1. [css]我要用css画幅画(三)

    接着之前的[css]我要用css画幅画(二), 今天,我画了一个小人,他的名字暂时叫作小明. 以下只列出本次修改增加的内容 html如下: <div class="human left ...

  2. [css]我要用css画幅画(二)

    接着之前的[css]我要用css画幅画(一) , 今天,我又画一个房子,很简单,屋顶.墙壁.门. 现在开始,做得效果都只兼容chrome,所以下面的css3的属性可能只有-webkit-前缀. 我只是 ...

  3. [css]我要用css画幅画(一)

    几年前开始就一直想用css画幅画. 今天才真正开始, 从简单的开始. 作为一个工作压力那么大的程序员,我首先要画一个太阳. html如下: <!DOCTYPE html> <html ...

  4. No.3 - CSS transition 和 CSS transform 配合制作动画

    课程概述 作业提交截止时间:09-01 任务目的 深度理解掌握 transition-timing-function 以及它的意义 学会配合使用 CSS transform 和CSS transiti ...

  5. [css]我要用css画幅画(九) - Apple Logo

    接着之前的[css]我要用css画幅画(八) - Hello Kitty,这次画的是苹果公司的logo 这次打算将分析和实现步骤尽量详细的说一说. 其实之前的也打算详细讲分析和设计过程,不过之前的图比 ...

  6. [css]我要用css画幅画(八) - Hello Kitty

    接着之前的[css]我要用css画幅画(七) - 哆啦A梦,这次画的是Hello Kitty. /* 开始前先说点废话, 一转眼就2016年了,过完年后一直没更新博客,无他,就是懒得动. 这一转眼,一 ...

  7. [css]我要用css画幅画(七) - 哆啦A梦

    接着之前的[css]我要用css画幅画(六),今天画的有所不同,画的是哆啦A梦,我们小时候对他的称呼其实是小叮当机器猫. (PS:这次我要做的事情,很多人已经做过,这并不是什么创新,我只是在学习并记录 ...

  8. [css]我要用css画幅画(六)

    接着之前的[css]我要用css画幅画(五), 由于这个画已经画了很久了,这次一次性加了比较多更新,算是让这幅画告一段落吧. 本次的更新包括: 1. 给云增加动画 2. 画了一棵树 3. 树上画了一个 ...

  9. [css]我要用css画幅画(五)

    接着之前的[css]我要用css画幅画(四), 这次我给小明和静静增加了对话,用了简单的动画效果. github:https://github.com/bee0060/Css-Paint , 完整代码 ...

随机推荐

  1. Dependency Scopes(maven)

    Dependency scope 是用来限制Dependency的作用范围的, 影响maven项目在各个生命周期时导入的package的状态. 自从2.0.9后,新增了1种,现在有了6种scope: ...

  2. [AngularJS] tips技巧收集

     单个参数调用angular.module(),用来取得该模块而不是定义新的 这样就可以在不同的地方定义app的controller而不用通过全局变量 angular.module('myapp') ...

  3. 非抢占式RCU实现(一)

    关于RCU的实现,考虑如下情形: 1.非抢占式RCU 2.限于嵌入式系统4核.每核单线程 3.RCU_FANOUT = 32 此时,RCU_TREE退化为单节点,如下,针对rcu_sched_stat ...

  4. android project 文件夹

    android多国语言文件夹 http://www.blogjava.net/zhaojianhua/archive/2012/02/09/369676.html Android平板开发精确适配不同的 ...

  5. Header的Request部分和Response部分

    转载:https://zh.wikipedia.org/wiki/HTTP%E5%A4%B4%E5%AD%97%E6%AE%B5#%E8%AF%B7%E6%B1%82%E5%AD%97%E6%AE%B ...

  6. [RN] 01 - Init: Try a little bit of React Native

    Ref: React Native跨平台移动应用开发 后记:这本书博客味有点浓. 本篇涉及新建工程的若干套路,以及一点语法知识. 创建新工程 (1) 解决的一大核心问题: (2) 使用Javascri ...

  7. [Module] 08 - MVP by Mosby

    From: Mosby MVP使用教程[作者用心] View是消极视图(Passive View), 它尽量不去主动做事, 让Presenter通过抽象方式控制View 例子: 例如Presenter ...

  8. Nexus5 破解电信关键步骤

    5儿子终于摔坏了,送去保养之后,发现之前已破解的电信3G竟然无效了,心碎!!!!!!!!!!!!!!!!!! 尝试恢复efs --还好有备份,备份万岁!!! 不行!继续尝试恢复!还是不行!再试!... ...

  9. python中安装dlib和cv2

    这两个模块是很容易出问题的模块,以下的解决办法都是从网上收集而来. 安装dlib: pypi.python.org/pypi/dlib/19.6.0 下载 dlib-19.6.0-cp36-cp36m ...

  10. 转载mysql数据库配置优化

    网上有很多的文章教怎么配置MySQL服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文章的做法只能作为初步设置参考,我们需要根据自己的情况进行配置优化,好的做法是MySQL服务器稳定运行了一 ...