HTML5特效~3D立方體旋轉


 先欣賞一下該特效的最終效果

本文源碼參考自http://www.cnblogs.com/ECJTUACM-873284962/進行一點點優化,下面是對此特效原理上的的剖析.

該特效是基於Css3的一些新特性拼接而成.主要用到了hover,transform和@keyframe屬性.下面簡述一下這三個屬性的作用.

詳情參考http://www.w3school.com.cn/css3/index.asp

hover

效果:當鼠標移到元素上時會展現你定義的hover的樣式

使用方法:假定我們有一個類,名為mystyle.修改它的css樣式的方式是.mystyle{}.修改它的css hover樣式的方式是.mystyle:hover{}.

transform

效果:對元素進行旋轉、縮放、移動或傾斜

使用方法:傳入旋轉rotate(angle),縮放scale(x,y),移動translate(x,y),傾斜skew(angle)的參數進行屬性的修改

@keyframe

效果:實現動畫效果

使用方法:@keyframe 后+動畫名{from:初始狀態;to:末狀態}

為了方便理解,我們先看一張圖片旋轉的demo版

 

 

 

 

 

 

 

代碼解析

<style>
    /*實現立體效果*/
    .img {
        width: 50px;
        height: 50px;
        margin: 0 auto;
        transform-style: preserve-3d;
        /*設置動畫播放樣式:動畫對象 播放速度 時間 播放次數*/
        animation: rotate linear 20s infinite;
    }
    /*實現動畫效果*/
    @-webkit-keyframes rotate {                /*sofari chrome*/
        from {
            transform: rotateX(0deg) rotateY(0deg);
        }
        to {
            transform: rotateX(360deg) rotateY(360deg);
        }
    }
    /*圖片樣式*/
    .pic{
        width: 200px;
        height: 200px;
        transform: rotateY(0deg) translateZ(100px);
    }
</style>

接下來是特效實現的完整代碼

<div class="wrap">
    <!--部署內外層圖片-->
    <div class="cube">
        <!--前面圖片 -->
        <div class="out_front">
            <img src="https://i.loli.net/2018/10/04/5bb5f270969f2.jpeg" class="pic">
        </div>
        <!--后面圖片 -->
        <div class="out_back">
            <img src="https://i.loli.net/2018/10/04/5bb5f23ce7f1e.jpg" class="pic">
        </div>
        <!--左面圖片 -->
        <div class="out_left">
            <img src="https://i.loli.net/2018/10/04/5bb5f26e13b28.jpg" class="pic">
        </div>
        <!--右面圖片 -->
        <div class="out_right">
            <img src="https://i.loli.net/2018/10/07/5bb9b1ca97948.jpg" class="pic">
        </div>
        <!--上面圖片 -->
        <div class="out_top">
            <img src="https://i.loli.net/2018/10/04/5bb5f2725c5c7.jpg" class="pic">
        </div>
        <!--下面圖片 -->
        <div class="out_bottom">
            <img src="https://i.loli.net/2018/10/04/5bb5f27af2e28.jpg" class="pic">
        </div>

        <!--小正方體 -->
        <span class="in_front">
                <img src="https://i.loli.net/2018/10/07/5bb9b2e441d7a.jpg" class="in_pic">
            </span>
        <span class="in_back">
                 <img src="https://i.loli.net/2018/10/07/5bb9b2e712b3f.jpg" class="in_pic">
            </span>
        <span class="in_left">
                <img src="https://i.loli.net/2018/10/07/5bb9b2e86ad25.jpg" class="in_pic">
            </span>
        <span class="in_right">
                <img src="https://i.loli.net/2018/10/07/5bb9b2eaba148.jpg" class="in_pic">
            </span>
        <span class="in_top">
                <img src="https://i.loli.net/2018/10/07/5bb9b2ebe5bd9.jpg" class="in_pic">
            </span>
        <span class="in_bottom">
                <img src="https://i.loli.net/2018/10/07/5bb9b2ed867be.jpg" class="in_pic">
            </span>

    </div>
    <style>
        /*最外層容器樣式*/
        .wrap {
            width: 100px;
            height: 100px;
            margin: 150px;
            position: relative;
        }

        /*得到立方體效果*/
        .cube {
            width: 50px;
            height: 50px;
            margin: 0 auto;
            transform-style: preserve-3d;
            /*設置動畫播放樣式:動畫對象 播放速度 時間 播放次數*/
            animation: rotate linear 20s infinite;
        }

        /*動畫旋轉的方式*/
        /*得到動畫效果*/
        @-moz-keyframes rotate {                     /*firefox*/
            from {
                transform: rotateX(0deg) rotateY(0deg);
            }
            to {
                transform: rotateX(360deg) rotateY(360deg);
            }
        }
        @-webkit-keyframes rotate {                /*sofari chrome*/
            from {
                transform: rotateX(0deg) rotateY(0deg);
            }
            to {
                transform: rotateX(360deg) rotateY(360deg);
            }
        }
        @-o-keyframes rotate {                    /*opera*/
            from {
                transform: rotateX(0deg) rotateY(0deg);
            }
            to {
                transform: rotateX(360deg) rotateY(360deg);
            }
        }
        /*每張圖片的樣式*/
        .cube div {
            position: absolute;
            width: 200px;
            height: 200px;
            opacity: 0.8;
            /*過渡效果*/
            transition: all .4s;
        }

        /*定義所有圖片樣式*/
        .pic {
            width: 200px;
            height: 200px;
        }

        .cube .out_front {
            transform: rotateY(0deg) translateZ(100px);
        }

        .cube .out_back {
            transform: translateZ(-100px) rotateY(180deg);
        }

        .cube .out_left {
            transform: rotateY(-90deg) translateZ(100px);
        }

        .cube .out_right {
            transform: rotateY(90deg) translateZ(100px);
        }

        .cube .out_top {
            transform: rotateX(90deg) translateZ(100px);
        }

        .cube .out_bottom {
            transform: rotateX(-90deg) translateZ(100px);
        }

        /*定義小正方體樣式*/
        .cube span {
            display: block;
            width: 100px;
            height: 100px;
            position: absolute;
            top: 50px;
            left: 50px;
        }

        .cube .in_pic {
            width: 100px;
            height: 100px;
        }

        .cube .in_front {
            transform: rotateY(0deg) translateZ(50px);
        }

        .cube .in_back {
            transform: translateZ(-50px) rotateY(180deg);
        }

        .cube .in_left {
            transform: rotateY(-90deg) translateZ(50px);
        }

        .cube .in_right {
            transform: rotateY(90deg) translateZ(50px);
        }

        .cube .in_top {
            transform: rotateX(90deg) translateZ(50px);
        }

        .cube .in_bottom {
            transform: rotateX(-90deg) translateZ(50px);
        }

        /*鼠標移入后樣式*/
        .cube:hover .out_front {
            transform: rotateY(0deg) translateZ(200px);
        }

        .cube:hover .out_back {
            transform: translateZ(-200px) rotateY(180deg);
        }

        .cube:hover .out_left {
            transform: rotateY(-90deg) translateZ(200px);
        }

        .cube:hover .out_right {
            transform: rotateY(90deg) translateZ(200px);
        }

        .cube:hover .out_top {
            transform: rotateX(90deg) translateZ(200px);
        }

        .cube:hover .out_bottom {
            transform: rotateX(-90deg) translateZ(200px);
        }
    </style>
</div>

覺得文章不錯,點個贊和關注吧.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM