欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于JQuery和CSS3實(shí)現(xiàn)仿Apple TV海報(bào)背景視覺(jué)差特效源碼分享

 更新時(shí)間:2015年09月21日 16:23:32   投稿:mrr  
這是一款效果非常炫酷的jQuery和CSS3仿Apple TV海報(bào)背景視覺(jué)差特效。該視覺(jué)差特效在使用鼠標(biāo)在屏幕上下左右移動(dòng)的時(shí)候,海報(bào)中的各種元素以不同的速度運(yùn)動(dòng),形成視覺(jué)差效果,并且還帶有一些流光特效。

效果展示如下:

查看演示     下載源碼

HTML結(jié)構(gòu)

Apple TV是由蘋(píng)果公司繼 Airport Express 之后推出的一款高清電視機(jī)頂盒產(chǎn)品。如果你曾經(jīng)使用過(guò),一定會(huì)被其中的炫酷電影海報(bào)視覺(jué)差特效所吸引。

該視覺(jué)差特效的HTML結(jié)構(gòu)使用一個(gè)<div>作為容器,在它里面的每一個(gè)<div>都是一個(gè)“層”。

<div class="poster">
 <div class="shine"></div>
 <div class="layer-1"></div>
 <div class="layer-2"></div>
 <div class="layer-3"></div>
 <div class="layer-4"></div>
 <div class="layer-5"></div>
</div>
<div.shine>是用于制作流光效果的圖層。

CSS樣式

為了使包裹元素.poster制作出3D旋轉(zhuǎn)效果,它的父元素需要設(shè)置透視和transform-style。

body {
 background: linear-gradient(to bottom, #f6f7fc 0%,#d5e1e8 40%);
 transform-style: preserve-3d;
 transform: perspective(800px);
}

這里的海報(bào)大小設(shè)置為固定的320x500像素,相對(duì)于頁(yè)面居中,為它制作圓角效果和一些陰影效果。

.poster {
 width: 320px;
 height: 500px;
 position: absolute;
 top: 50%; left: 50%;
 margin: -250px 0 0 -160px;
 border-radius: 5px;
 box-shadow: 0 45px 100px rgba(0, 0, 0, 0.4);
 overflow:hidden;
}

海報(bào)的居中采用的是絕對(duì)定位居中法:left和top分別為50%,然后設(shè)置margin-left和margin-top為負(fù)的寬度值和高度值。

海報(bào)中所有的“層”可以通過(guò)div[class*="layer-"]選擇器來(lái)選擇。所有的圖層都被設(shè)置為絕對(duì)定位,背景圖片不重復(fù),background-position設(shè)置到左上角位置,背景的大小設(shè)置為100%的寬度和自動(dòng)高度。

div[class*="layer-"] {
 position: absolute;
 top: -10px;
 left: -10px;
 right: -10px; 
 bottom: -10px;
 background-size: 100% auto;
 background-repeat: no-repeat;
 background-position: 0 0;
 transition:0.1s;
}

注意上面代碼中的top,left,right和bottom屬性的值都是-10像素。它們用于使圖層的尺寸比海報(bào)的尺寸大20像素。這樣做的原因是在產(chǎn)生視覺(jué)差效果是可以隱藏圖層的邊部。

最后為每一個(gè)圖層設(shè)置背景圖片。

.layer-1 {
 background-image: url('images/1.png');
}
.layer-2 {
 background-image: url('images/2.png');
}
.layer-3 {
 top: 0; bottom: 0;
 left: 0; right: 0;
 background-image: url('images/3.png');
}
.layer-4 {
 background-image: url('images/4.png');
}
.layer-5 {
 background-image: url('images/5.png');
}

JavaScript

該視覺(jué)差效果的原理是每次用戶移動(dòng)鼠標(biāo)是時(shí)候,.poster的transforms: translateY、rotate和rotateY屬性將根據(jù)鼠標(biāo)的位置發(fā)生變化。鼠標(biāo)距離左上角越遠(yuǎn),動(dòng)畫(huà)可見(jiàn)的區(qū)域就越多。

計(jì)算的公式類(lèi)似于 offsetX = 0.5 – 鼠標(biāo)位置 / 窗口的寬度。

為了給各個(gè)層不同的動(dòng)畫(huà)速度,這里需要在乘以一個(gè)自定義的動(dòng)畫(huà)速率值,這個(gè)值由HTML標(biāo)簽上的data-offset="number"提供。

<div data-offset="-2" class="layer-1"></div>
<div class="layer-2"></div>
<div data-offset="1" class="layer-3"></div>
<div data-offset="3" class="layer-4"></div>
<div data-offset="10" class="layer-5"></div>

data-offset的值越大,可見(jiàn)的動(dòng)畫(huà)區(qū)域就越大。

整個(gè)視覺(jué)差效果的JS代碼如下:

var $poster = $('.poster'),
 $shine = $('.shine'),
 $layer = $('div[class*="layer-"]');
$(window).on('mousemove', function(e) {
 var w = $(window).width(), //窗口寬度
  h = $(window).height(), /窗口高度
  offsetX = 0.5 - e.pageX / w, //鼠標(biāo)X坐標(biāo)
  offsetY = 0.5 - e.pageY / h, //鼠標(biāo)Y坐標(biāo)
  dy = e.pageY - h / 2, //@h/2 = 海報(bào)容器中心
  dx = e.pageX - w / 2, //@w/2 = 海報(bào)容器中心
  theta = Math.atan2(dy, dx), //鼠標(biāo)和海報(bào)中心的RAD角度
  angle = theta * 180 / Math.PI - 90, //轉(zhuǎn)換 rad 為 degrees
  offsetPoster = $poster.data('offset'),
  transformPoster = 'translateY(' + -offsetX * offsetPoster + 'px) rotateX(' + (-offsetY * offsetPoster) + 'deg) 
            rotateY(' + (offsetX * (offsetPoster * 2)) + 'deg)'; 
 //get angle between 0-360
 if (angle < 0) {
  angle = angle + 360;
 }
 //gradient angle and opacity
 $shine.css('background', 'linear-gradient(' + angle + 'deg, rgba(255,255,255,' + e.pageY / h * .5 + ') 0%,rgba(255,255,255,0) 80%)');
 //poster transform
 $poster.css('transform', transformPoster);
 //parallax foreach layer
 $layer.each(function() {
  var $this = $(this),
   offsetLayer = $this.data('offset') || 0,
   transformLayer = 'translateX(' + offsetX * offsetLayer + 'px) translateY(' + offsetY * offsetLayer + 'px)';
  $this.css('transform', transformLayer);
 });

相關(guān)文章

最新評(píng)論