美文网首页
圆角、阴影、rgba、动画

圆角、阴影、rgba、动画

作者: 时光清浅_许你心安_ | 来源:发表于2018-10-25 20:48 被阅读0次

    圆角

    设置某一个角的圆角,比如设置左上角的圆角:
    border-top-left-radius:30px 60px;
    同时分别设置四个角: border-radius:30px 60px 120px 150px;
    设置四个圆角相同:
    border-radius:50%;

    阴影

    box-shadow:h-shadow v-shadow blur spread color inset;
    分别设置阴影:水平偏移 垂直偏移 羽化大小 扩展大小 颜色 是否内阴影

    <style type="text/css">
        .box{
            width:200px;
            height:50px;
            background-color:gold;
            /* box-shadow:10px 10px 5px 2px pink inset; */
            box-shadow:10px 10px 5px 2px pink;
        }
    </style>
    ......
    <div class="box"></div>
    
    <!-- 给盒子加上了粉红色的阴影 -->
    

    rgba(新的颜色值表示法)

    1、盒子透明度表示法:opacity:0.1;filter:alpha(opacity=10)(兼容IE);
    2、rgba(0,0,0,0.1) 前三个数值表示颜色,第四个数值表示颜色的透明度

    动画

    transition动画

    1、transition-property 设置过渡的属性,比如:width height background-color
    2、transition-duration 设置过渡的时间,比如:1s 500ms
    3、transition-timing-function 设置过渡的运动方式

    • linear 匀速
    • ease 开始和结束慢速
    • ease-in 开始是慢速
    • ease-out 结束时慢速
    • ease-in-out 开始和结束时慢速
    • cubic-bezier(n,n,n,n)

    4、transition-delay 设置动画的延迟
    5、transition: property duration timing-function delay 同时设置四个属性

    举例:

    <style type="text/css">        
    .box{
        width:100px;
        height:100px;
        background-color:gold;
        transition:width 300ms ease,height 300ms ease 300ms,background-color 300ms ease 600ms;            
    }
    .box:hover{
        width:300px;
        height:300px;
        background-color:red;
    }
    </style>
    ......
    <div class="box"></div>
    

    transform变换

    1、translate(x,y) 设置盒子位移
    2、scale(x,y) 设置盒子缩放
    3、rotate(deg) 设置盒子旋转
    4、skew(x-angle,y-angle) 设置盒子斜切
    5、perspective 设置透视距离
    6、transform-style flat | preserve-3d 设置盒子是否按3d空间显示
    7、translateX、translateY、translateZ 设置三维移动
    8、rotateX、rotateY、rotateZ 设置三维旋转
    9、scaleX、scaleY、scaleZ 设置三维缩放
    10、tranform-origin 设置变形的中心点
    11、backface-visibility 设置盒子背面是否可见

    举例:(翻面效果)

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>翻面</title>
        <style type="text/css">
            .box{
                width:300px;
                height:272px;
                margin:50px auto 0;
                transform-style:preserve-3d;
                position:relative;            
            }
            .box .pic{
                width:300px;
                height:272px;
                position:absolute;
                background-color:cyan;
                left:0;
                top:0;
                transform:perspective(800px) rotateY(0deg);
                backface-visibility:hidden;
                transition:all 500ms ease;
            }
            .box .back_info{
                width:300px;
                height:272px;
                text-align:center;
                line-height:272px;
                background-color:gold;
                position:absolute;
                left:0;
                top:0;
                transform:rotateY(180deg);
                backface-visibility:hidden;
                transition:all 500ms ease;            
            }
            .box:hover .pic{
                transform:perspective(800px) rotateY(180deg);
            }
            .box:hover .back_info{
                transform:perspective(800px) rotateY(0deg);
            }
        </style>
    </head>
    <body>
        <div class="box">        
            <div class="pic"><img src="images/location_bg.jpg"></div>
            <div class="back_info">背面文字说明</div>
        </div>
    </body>
    </html>
    

    animation动画

    1、@keyframes 定义关键帧动画
    2、animation-name 动画名称
    3、animation-duration 动画时间
    4、animation-timing-function 动画曲线

    linear 匀速
    ease 开始和结束慢速
    ease-in 开始是慢速
    ease-out 结束时慢速
    ease-in-out 开始和结束时慢速
    steps 动画步数

    5、animation-delay 动画延迟
    6、animation-iteration-count 动画播放次数 n|infinite
    7、animation-direction

    normal 默认动画结束不返回
    Alternate 动画结束后返回

    8、animation-play-state 动画状态

    paused 停止
    running 运动

    9、animation-fill-mode 动画前后的状态

    none 不改变默认行为
    forwards 当动画完成后,保持最后一个属性值(在最后一个关键帧中定义)
    backwards 在 animation-delay 所指定的一段时间内,在动画显示之前,应用开始属性值(在第一个关键帧中定义)
    both 向前和向后填充模式都被应用
    10、animation:name duration timing-function delay iteration-count direction;同时设置多个属性

    举例:(人物走路动画)

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>走路动画</title>
        <style type="text/css">        
            .box{
                width:120px;
                height:180px;
                border:1px solid #ccc;            
                margin:50px auto 0;
                position:relative;
                overflow:hidden;            
            }
    
            .box img{
                display:block;
                width:960px;
                height:182px;
                position: absolute;
                left:0;
                top:0;
                animation:walking 1.0s steps(8) infinite;            
            }
            @keyframes walking{
                from{
                    left:0px;
                }
    
                to{
                    left:-960px;
                }
            }
        </style>
    </head>
    <body>
        <div class="box"><img src="images/walking.png"></div>
    </body>
    </html>
    

    动画中使用的图片如下:

    走路动画

    作业

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>动画作业</title>
        <style type="text/css">
            .box{
                width:460px;
                height:200px;
                border:solid 3px;
            }
            .box1{
                width:40px;
                height:100px;
                background-color:green;
                animation:moving 1s ease 0s infinite alternate;
                margin-top:20px;
                margin-left:40px;
                display:inline-block;
                border-radius:20px;
            }
            .box2{
                width:40px;
                height:100px;
                background-color:yellow;
                margin-top:20px;
                margin-left:40px;
                animation:moving 1s ease 0.2s infinite alternate;
                display:inline-block;
                border-radius:20px;
            }
            .box3{
                width:40px;
                height:100px;
                background-color:red;
                margin-top:20px;
                margin-left:40px;
                display:inline-block;
                animation: moving 1s ease 0.4s infinite alternate;
                border-radius:20px;
            }
            .box4{
                width:40px;
                height:100px;
                background-color:black;
                margin-top:20px;
                margin-left:40px;
                display:inline-block;
                animation:moving 1s ease 0.6s infinite alternate;
                border-radius:20px;
            }
            .box5{
                width:40px;
                height:100px;
                background-color:blue;
                margin-top:20px;
                margin-left:40px;
                display:inline-block;
                animation:moving 1s ease 0.8s infinite alternate;
                border-radius:20px;
            }
            .t1{
                display:inline-block;
                margin:0 auto;
                position:absolute;
                top:150px;
                left:180px;
            }
            @keyframes moving{
                from{
                    /*height:50px;*/
                    transform:scaleY(1);/*缩放用transform*/
                    /*scroll-behavior:50px;*/
                }
                to{
                    /*height:120px;*/
                    transform:scaleY(0.5);/*缩放Y轴*/
                    /*scroll-behavior: 100px;*/
                }
            }
        </style>
    </head>
    <body>
        <div class="box">
            <div class="box1"></div>
            <div class="box2"></div>
            <div class="box3"></div>
            <div class="box4"></div>
            <div class="box5"></div>
            <h1 class="t1">loiging...</h1>
        </div>
    </body>
    </html>
    
    image.png

    相关文章

      网友评论

          本文标题:圆角、阴影、rgba、动画

          本文链接:https://www.haomeiwen.com/subject/quzctqtx.html