HTML5特效~3D立方體旋轉

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

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

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

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

hover

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

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

transform

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

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

@keyframe

效果:實現動畫效果firefox

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

爲了方便理解,咱們先看一張圖片旋轉的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>

以爲文章不錯,點個贊和關注吧.

相關文章
相關標籤/搜索