zoukankan      html  css  js  c++  java
  • 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: 0;
                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: 2;
                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: 0;
                top: 0;
                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: 1;
                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: 0;
                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: 1;
            }
    
            .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: 0;
                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: 0;
                }
            }
    
            @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>
  • 相关阅读:
    jichu
    scanf
    数位dp
    hdu 5667
    华东交通大学2018年ACM“双基”程序设计竞赛 K
    华东交通大学2018年ACM“双基”程序设计竞赛 D
    map
    次小生成树
    set
    c++11之为什么C++11引入了std::ref?
  • 原文地址:https://www.cnblogs.com/yingzi1028/p/6650471.html
Copyright © 2011-2022 走看看