CSS之2D转换模块

_____egon新书来袭请看:https://egonlin.com/book.html

一 2D转换模块之transform 

取值描述
transform: rotate(35deg);
以中心为准进行旋转
deg旋转多少度
transform: translate(100px,50px);
以中心为准进行平移
第一个参数是:水平方向,即x轴
第二个方向:垂直方向,即y轴
transform: scale(1.5,1);
以中心为准进行缩放
第一个参数是:水平方向,即x轴
第二个方向:垂直方向,即y轴

注意:
如果取值是1,代表不变
如果取值大于1,代表需要放大,反之代表缩小

如果水平和垂直缩放都一样,那么可以简写为一个参数
transform: rotate(35deg) translate(100px,20px) scale(2,2);
注意:
1、如果需要进行多个转换,那么用空格隔开
2、2D的转换会修改元素的坐标系,所以旋转之后再平移不是水平,(旋转之后的坐标系就变了)

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        * {
            margin: 0;
            padding: 0;
        }

        div {
            width: 150px;
            height: 150px;
            background: #cccccc;
            margin: 0 auto;

        }
        span {
            display: block;
            width: 50px;
            height: 50px;
        }

        .box1 span {
            background: #003399;
        }

        .box2 span {
            background: green;

            /*
            以中心为准进行旋转
            deg旋转多少度
            */
            transform: rotate(35deg);
        }

        .box3 span  {
            background: red;

            /*
            以中心为准进行平移
            第一个参数是:水平方向,即x轴
            第二个方向:垂直方向,即y轴
            */
            transform: translate(100px,50px);
        }

        .box4 span  {
            background: blue;

            /*
            以中心为准进行缩放
            第一个参数是:水平方向,即x轴
            第二个方向:垂直方向,即y轴

            注意:
                如果取值是1,代表不变
                如果取值大于1,代表需要放大,反之代表缩小

                如果水平和垂直缩放都一样,那么可以简写为一个参数
            */
            transform: scale(1.5,1);
        }

        .box5 span  {
            background-color: #55BBBB;

            /*
            注意:
                1、如果需要进行多个转换,那么用空格隔开
                2、2D的转换会修改元素的坐标系,所以旋转之后再平移不是水平,(旋转之后的坐标系就变了)

            */
            transform: rotate(35deg) translate(100px,20px) scale(2,2);
        }


    </style>
</head>
<body>
    <div class="box1">
        <span>正常</span>
    </div>
    <hr>
    <div class="box2">
        <span>旋转</span>
    </div>
    <hr>
    <div class="box3">
        <span>平移</span>
    </div>
    <hr>
    <div class="box4">
        <span>缩放</span>
    </div>
    <hr>
    <div class="box5">
        <span>综合</span>
    </div>

</body>
</html>
示范

二 2D转换模块之形变中心点

#1、默认情况下所有元素都是以自己的中心点作为参考来旋转的
形变中心点指的是修改元素改变形状的参考点

#2、格式:
transform-origin: 水平方向的值 垂直方向的值;

水平方向与垂直方向的值都是以自己原来的宽高为参考


#3、注意点:
取值有三种形式
    具体像素
    百分比
    特殊的关键字

 

取值描述
具体像素
transform-origin: 0px 0px; 左上角
transform-origin: 200px 0px; 右上角
百分比
transform-origin: 0% 0%; 左上角
transform-origin: 50% 50%; 中心点
关键字
transform-origin: left center; 左中

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        * {
            margin: 0;
            padding: 0;
        }

        ul {
            width: 200px;
            height: 200px;
            background: #cccccc;
            list-style: none;
            margin: 100px auto;
            position: relative;
            border: 1px solid #000;

        }

        ul li {
            width: 200px;
            height: 200px;
            position: absolute;

            left: 0;
            top: 0;
            
            /*transform-origin: center center;*/
            transform-origin: left center;
        }

        ul li:nth-of-type(1) {
            background: green;

            transform: rotate(35deg);
        }

        ul li:nth-of-type(2) {
            background: blue;

            transform: rotate(65deg);

        }

        ul li:nth-of-type(3) {
            background: yellow;

            transform: rotate(105deg);

        }


    </style>
</head>
<ul>
    <li></li>
    <li></li>
    <li></li>
</ul>
</html>
示范

三 2D转换模块之旋转轴向

http://www.zhangxinxu.com/wordpress/2012/09/css3-3d-transform-perspective-animate-transition/ 

取值描述
transform: rotateZ(60deg);
默认情况下所有元素都是围绕Z轴进行旋转
transform: rotateX(60deg);
围绕X轴进行旋转
transform: rotateY(60deg);
围绕Y轴进行旋转
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        ul {
            width: 800px;
            height: 500px;
            /*border: 1px solid #000;*/
            margin: 0 auto;

            /*下一小节将讲这个属性,加上他就可以看到X轴方向的旋转了*/
            perspective: 500px;
        }

        ul li{
            list-style: none;
            width: 200px;
            height: 200px;
            margin: 0 auto;
            margin-top: 50px;
            border: 1px solid #000;
        }

        ul li img {
            width: 200px;
            height: 200px;
        }

        ul li:nth-child(1) {
            /*默认情况下所有元素都是围绕Z轴进行旋转*/
            transform: rotateZ(60deg);
        }

        ul li:nth-child(2) img{
            transform: rotateX(60deg);
        }

        ul li:nth-child(3) img{


            transform: rotateY(60deg);
        }
        /*
        总结:
            想围绕哪个轴旋转,那么只需要在rotate后面加上哪个轴即可
        */

    </style>
</head>
<body>


<ul>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102336179-1496473693.jpg" alt=""></li>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102350242-559679027.jpg" alt=""></li>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102412261-843878417.jpg" alt=""></li>
</ul>
</body>
</html>
示范

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        div {
            /*display: inline-block;*/
            width: 500px;
            height: 700px;

            margin: 100px auto;

            border: 1px solid #f6c2d2;
            background-color: #cccccc;
            box-sizing: border-box;
            perspective: 500px;

            position: relative;

        }
        span {
            position: absolute;
            width: 300px;
            left: 50%;
            margin-left: -100px;
            font-size: 5px;
            color: #55BBBB;

            transition: all 5s;


        }

        div img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;

            transform-origin: center bottom;
            transition: transform 5s;
        }

        div:hover img {
            transform: rotateX(45deg);
        }

        div:hover span {
            font-size: 30px;
            color: #e9289c;
        }


    </style>
</head>
<body>

<div class="box1">
    <span>开启一个神奇的世界</span>
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517103833496-68776850.png" alt="">
</div>

<div class="box2">
    <span>先生里边请</span>
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517104955799-454977663.png" alt="">
</div>

</body>
</html>
练习1
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        div {
            /*display: inline-block;*/
            width: 500px;
            height: 700px;

            margin: 100px auto;

            border: 1px solid #f6c2d2;
            background-color: #cccccc;
            box-sizing: border-box;
            perspective: 500px;

            position: relative;

        }
        span {
            position: absolute;
            width: 300px;
            left: 50%;
            margin-left: -100px;
            font-size: 5px;
            color: #55BBBB;

            transition: all 5s;


        }

        div img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;
        }

        .box1 img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;

            transform-origin: left center;
            transition: transform 5s;
        }

        .box1:hover img {
            transform: rotateY(45deg);
        }

        .box1:hover span {
            font-size: 30px;
            color: #e9289c;
        }



        .box2 img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;

            transform-origin: right center;
            transition: transform 5s;
        }

        .box2:hover img {
            transform: rotateY(-45deg);
        }

        .box2:hover span {
            font-size: 30px;
            color: #e9289c;
        }





        .box3 img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;

            transform-origin: right center;
            transition: transform 5s;
        }

        .box3:hover img {
            transform: rotateY(45deg);
        }

        .box3:hover span {
            font-size: 30px;
            color: #e9289c;
        }





    </style>
</head>
<body>

<div class="box1">
    <span>开启一个神奇的世界</span>
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517103833496-68776850.png" alt="">
</div>

<div class="box2">
    <span>先生里边请</span>
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517104955799-454977663.png" alt="">
</div>

<div class="box3">
    <span>先生里边请</span>
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517104955799-454977663.png" alt="">
</div>

</body>
</html>
练习2

四 2D转换模块之透视属性

#1、什么是透视属性
视线延伸到屏幕后端,呈现近大远小的效果,perspective: 10px;,值越小
近大远小的效果越明显

#2、注意:
    透视属性必须添加到需要呈现近大远小的效果的元素的父元素上
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        div {
            /*display: inline-block;*/
            width: 500px;
            height: 700px;

            margin: 100px auto;

            border: 1px solid #f6c2d2;
            background-color: #cccccc;
            box-sizing: border-box;
            position: relative;

            /*!!!推荐添加的直接的父元素上*/
            /*perspective: 100px;*/
            perspective: 500px;


        }

        div img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;
        }

        .box1 img {
            width: 100%;
            height: 100%;
            position: absolute;
            left: 0;
            top: 0;

            transform-origin: center bottom;
            transition: transform 5s;
        }

        .box1:hover img {
            transform: rotateX(45deg);
       }



    </style>
</head>
<body>

<div class="box1">
    <img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102350242-559679027.jpg" alt="">
</div>

</body>
</html>
示范

五 盒子阴影与文字阴影

#1、如何给盒子添加阴影
    box-shadow:水平阴影的位置(可为负值) 垂直阴影的位置(可为负值)模糊距离 阴影的尺寸 阴影颜色 内外阴影inset/outset;

注意点:
    1.1 水平偏移与垂直偏移为必须要有的,其余均为可选

    1.1盒子的阴影分为内外阴影,默认情况下就是外阴影outset,内阴影为inset
   
    1.3 快速添加阴影,只需要编写三个参数即可
    box-shadow:水平偏移 垂直偏移 模糊度;
    默认情况下阴影的颜色和盒子的颜色一致


#2、如何给文字添加阴影
    text-shadow:水平偏移 垂直偏移 模糊度 阴影颜色;

注意点:
    阴影颜色默认跟文字颜色一致 
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        .box1 {
            width: 200px;
            height: 200px;
            background-color: red;
            margin: 100px auto;

            text-align: center;
            line-height: 200px;

            /*box-shadow:水平阴影的位置(可为负值) 垂直阴影的位置(可为负值)模糊距离 阴影的尺寸 阴影颜色 内外阴影inset/outset;*/
            /*box-shadow: 0px 0px 0px 0px black;*/
            /*box-shadow: 10px 0px 0px 0px black;*/
            /*box-shadow: 0px 10px 0px 0px black;*/
            /*box-shadow: 10px 10px 0px 0px black;*/
            /*box-shadow: 10px 10px 10px 0px black;*/
            /*box-shadow: 10px 10px 10px 10px black;*/
            /*box-shadow: 10px 10px 10px 10px skyblue;*/
            /*box-shadow: 10px 10px 10px 10px skyblue ;*/

            /*快速添加阴影*/
            box-shadow: 10px 10px 10px blue;
            color: yellow;
        }

        .box2 {
            width: 200px;
            height: 200px;
            margin: 0 auto;
            background-color: pink;

            text-align: center;
            line-height: 200px;

            font-size: 40px;


            /*text-shadow: 10px 0px 0px black;*/
            /*text-shadow: 10px 10px 10px black;*/
            text-shadow: 10px 10px 10px purple;
            color: #666666;

        }
    </style>
</head>
<body>

<div class="box1">我是盒子1</div>

<div class="box2">我是盒子</div>
</body>
</html>
示范 

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        ul {
            height: 400px;
            border: 1px solid #000;
            background-color: skyblue;
            margin-top: 100px;

            text-align: center;
        }

        ul li {
            list-style: none;
            width: 150px;
            height: 200px;
            background-color: red;

            display: inline-block;

            margin-top: 100px;

            transition: all 1s;

            position: relative;


            /*添加阴影*/
            box-shadow: 0 0 10px;

        }

        ul li img {
            width: 150px;
            height: 200px;
            border: 5px solid #fff;
            box-sizing: border-box;
        }

        ul li:nth-child(1) {
            transform: rotate(30deg);
        }
        ul li:nth-child(2) {
            transform: rotate(-40deg);
        }
        ul li:nth-child(3) {
            transform: rotate(10deg);
        }
        ul li:nth-child(4) {
            transform: rotate(45deg);
        }

        ul li:hover {
            /*transform: rotate(0deg);*/
            /*同上*/
            /*transform: none;*/
            /*放大*/
            transform: rotate(0deg) translate(0,0) scale(2);
            z-index: 998;

        }


    </style>
</head>
<body>


<ul>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102336179-1496473693.jpg" alt=""></li>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102350242-559679027.jpg" alt=""></li>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102412261-843878417.jpg" alt=""></li>
    <li><img src="https://images2018.cnblogs.com/blog/1036857/201805/1036857-20180517102428440-2124533640.jpg" alt=""></li></ul>
</body>
</html>
练习:相片墙

 

posted @ 2018-05-17 09:43  linhaifeng  阅读(365)  评论(0编辑  收藏  举报