首页 web前端 js教程 jQuery和CSS3实现APPLE TV海报视差效果实例分享

jQuery和CSS3实现APPLE TV海报视差效果实例分享

Jan 06, 2018 pm 01:29 PM
apple css3 jquery

本文主要介绍了基于jQuery和CSS3实现APPLE TV海报视差效果,需要的朋友可以参考下,希望能帮助到大家能用jQuery和CSS3做出一个APPLE TV海报视差效果。

用CSS和jQuery来实现它,尽量看起来和原效果一样。

本教程里,我将使用CSS,HTML和jQuery来创建一个近似Apple TV视差效果,如果你正在阅读,我假设你对上述三种技术都有基本的了解。

废话不多说,开始第一部分。

HTML页面

我们的页面结构像下面这样:

<p class="poster">
 <p class="shine"></p>
 <p class="layer-1"></p>
 <p class="layer-2"></p>
 <p class="layer-3"></p>
 <p class="layer-4"></p>
 <p class="layer-5"></p>
</p>
登录后复制

首先,需要一个样式类为 .poster 的 p ,在这个 p 里包含5个其他样式的层 p。在这五个层 p 上有一个 shine p来添加一些闪光效果。

CSS部分

首先,添加以下代码确保网页 body 部分的高度是整个页面高度:

body, html { height: 100%; min-height: 100%; }
登录后复制

再给 body 部分一些背景渐变颜色:

body { background: linear-gradient(to bottom, #f6f7fc 0%,#d5e1e8 40%); }
登录后复制

为了让 .poster 有3D旋转的效果,父容器需要设置透视和变换效果。如我们所见,p的父容器就是 body 本身,所以添加以下CSS代码:

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

现在给卡片设置样式跟大小,让它在页面居中,添加一些圆角跟阴影效果:

.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;
}
登录后复制

为了让海报居中,需要设置 position 的值为 absolute,top:50% , 'left:50%', 上部的 margin 值是 p 高度的一半的负数,左边的 margin 值是 p 宽度的一半的负数。需要记住的是 .poster 的中心也是整个页面的中心。

阴影效果

我们可以用以下的CSS选择器来选择所有的层:

p[class *= 'layer-']
登录后复制

.poster 已经设计好了,来看看效果。

所以,CSS选择了所有class类名里含有“layer-”的 p。

现在,设置所有的层的 position 值是 absolute, background-repeat 值为 no-repeat, background-position 为 top left, 层背景的大小为100%宽度和自动高度。

p[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 的值都是-10px,目的是让层的大小比 poster 的大20px,这样在各个层进行视察效果的时候就不会看到层的边缘部分了。

以下是给每个层添加背景:

.layer-1 {
  background-image: url('http://designmodo.com/demo/apple-tv-parallax/images/1.png');
}
.layer-2 {
  background-image: url('http://designmodo.com/demo/apple-tv-parallax/images/2.png');
}
.layer-3 {
  top: 0; bottom: 0;
  left: 0; right: 0;
  background-image: url('http://designmodo.com/demo/apple-tv-parallax/images/3.png');
}
.layer-4 {
  background-image: url('http://designmodo.com/demo/apple-tv-parallax/images/4.png');
}
.layer-5 {
  background-image: url('http://designmodo.com/demo/apple-tv-parallax/images/5.png');
}
登录后复制

在 layer-3 部分, 层不会移动,所以尺寸就不用太大了。

完成静态效果

JavaScript部分

在开始之前,请确保已经引入了jQuery库,否则会报错的。

视差效果的逻辑是这样的,每当鼠标移动的时候,根据光标的位置,.poster 的 transforms:translateY,rotate,rotateY 属性将会改变。光标距离页面左上角越远,动画的效果越明显。

公式就类似于这样的:offsetX=0.5-光标距离页面顶端的位置/宽度。

为了每个元素的值都不一样,将给每一个光标公式返回的值乘以一个自定义的值,返回HTML的代码给每个会有动画的层元素添加 data-offset=数字 的属性。

<p data-offset="15" class="poster">
  <p class="shine"></p>
  <p data-offset="-2" class="layer-1"></p>
  <p class="layer-2"></p>
  <p data-offset="1" class="layer-3"></p>
  <p data-offset="3" class="layer-4"></p>
  <p data-offset="10" class="layer-5"></p>
</p>
登录后复制

每一个 .layers 的规则都相同,但是我们给他们应用到 translateY 和 translateX 属性上。

data-offset 属性的值越大,动画的效果越明显,可以改变这些值体验下。

为了代码可读性,我们在JavaScript里给 .poster 赋值给 $poster 变量,.shine 给 $shine 变量,$layer 变量代表所有层,w,h代表页面的宽度和高度。

var $poster = $('.poster'),
$shine = $('.shine'),
$layer = $('p[class*="layer-"]');
登录后复制

现在,需要考虑下当光标移动的时候获取到光标位置的问题。我们可以用 $(window) 的 mousemove 事件来实现,这个事件会返回一个JavaScript对象,含有我们需要的位置信息和其他一些我们暂时还用不到的变量。

$(window).on('mousemove', function(e) {
  var w=e.currentTarget.innerWidth,h=e.currentTarget.innerHeight;
  var offsetX = 0.5 - e.pageX / w, /* where e.pageX is our cursor X coordinate */
  offsetY = 0.5 - e.pageY / h,
  offsetPoster = $poster.data('offset'), /* custom value for animation depth */
  transformPoster = 'translateY(' + -offsetX * offsetPoster + 'px) rotateX(' + (-offsetY * offsetPoster) + 'deg) rotateY(' + (offsetX * (offsetPoster * 2)) + 'deg)';
  /* apply transform to $poster */
  $poster.css('transform', transformPoster);
  /* parallax foreach layer */
  /* loop thought each layer */
  /* get custom parallax value */
  /* apply transform */
  $layer.each(function() {
    var $this = $(this);
    var offsetLayer = $this.data('offset') || 0; /* get custom parallax value, if element docent have data-offset, then its 0 */
    var transformLayer = 'translateX(' + offsetX * offsetLayer + 'px) translateY(' + offsetY * offsetLayer + 'px)';
    $this.css('transform', transformLayer);
  });
});
登录后复制

下一步,就是用上面解释的公式来计算offsetY和offsetX的值,然后就是把视差效果应用到.posert和每一个海报层。

非常酷啊,现在我们就有了一个有视差效果的小部件了。

基本完成

但是还没完,海报上的光泽部分还没设置

现在回到CSS部分,给.shine p 绝对定位,添加一个渐变颜色效果,设置z-index属性值为100,让它在所有层的上面。

.shine {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.5) 0%,rgba(255,255,255,0) 60%);
  z-index: 100;
}
登录后复制

已经有了一个漂亮的闪光层在海报上,但是为了达到更逼真的效果,光照应该随着光标的移动而变化。

更逼真些

我们怎么做呢?可能你还记得无聊的初三数学课,当你想着你在学一些你从来都不会用到的公式的时候,我们现在就用到了。

所以,倾斜的角度应该等于光标与海报中心形成三角形的角度的相反值。(还记得吧,海报的中心就是整个页面的中心啊,也就是页面宽度和高度的二分之一)

角度示意图

首先,找到光标与页面中心形成的三角形的直角边,光标与中心连线后作出一个直角三角形。

然后用 Math.atan2() 函数得到中心点的角度值。注意这个函数的返回值使用弧度值来表示的,所以我们得在CSS中转换成角的度数,用以下公式:

弧度值*180/pi = 角度值

var $poster = $('.poster');
  var $shine = $('.shine');
  var $layer = $('p[class *= "layer-"]');
  $poster.data("offset",15);
  $(window).on('mousemove', function(e) {
    var w=e.currentTarget.innerWidth,h=e.currentTarget.innerHeight;
    var offsetX = 0.5 - e.pageX / w, /* where e.pageX is our cursor X coordinate */
    offsetY = 0.5 - e.pageY / h,
    offsetPoster = $poster.data('offset'), /* custom value for animation depth */
    transformPoster = 'translateY(' + -offsetX * offsetPoster + 'px) rotateX(' + (-offsetY * offsetPoster) + 'deg) rotateY(' + (offsetX * (offsetPoster * 2)) + 'deg)';
    dy = e.pageY - h / 2,
    dx = e.pageX - w / 2,
    theta = Math.atan2(dy,dx), /* get angle in radians */
    angle = theta * 180 / Math.PI; /* convert rad in degrees */
    /* apply transform to $poster */
    $poster.css('transform', transformPoster);
    /* parallax foreach layer */
    /* loop thought each layer */
    /* get custom parallax value */
    /* apply transform */
    $layer.each(function() {
      var $this = $(this);
      var offsetLayer = $this.data('offset') || 0; /* get custom parallax value, if element docent have data-offset, then its 0 */
      var transformLayer = 'translateX(' + offsetX * offsetLayer + 'px) translateY(' + offsetY * offsetLayer + 'px)';
      $this.css('transform', transformLayer);
    });
  });
登录后复制

你会发现角度值的范围是从-180到180度,以下代码修复这个问题让角度值从0-360度:

if (angle < 0) {
  angle = angle + 360;
}
登录后复制

现在角度有了,就可以随着光标的移动来动态改变渐变颜色的角度值:

$shine.css('background', 'linear-gradient(' + (angle - 90) + 'deg, rgba(255,255,255,' + e.pageY / h + ') 0%,rgba(255,255,255,0) 80%)');
登录后复制

大家学会了吗?赶紧动手尝试一下吧。

相关推荐:

分享一个用canvas合成海报图片的移动端项目

制作动态视觉差背景(h5)的方法

关于8 个 3D 视觉效果的 HTML5 动画图文欣赏

以上是jQuery和CSS3实现APPLE TV海报视差效果实例分享的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

更新 |黑客解释如何在欧盟以外的 iPad 上安装 Epic Games Store 和 Fortnite 更新 |黑客解释如何在欧盟以外的 iPad 上安装 Epic Games Store 和 Fortnite Aug 18, 2024 am 06:34 AM

更新:Saunders Tech 已将教程上传到他的 YouTube 频道(下面嵌入视频),解释如何在欧盟境外的 iPad 上安装 Fortnite 和 Epic Games Store。然而,该过程不仅需要特定的 iO 测试版

苹果的'HomeAccessory”设备配备 A18 芯片组以及其他功能 苹果的'HomeAccessory”设备配备 A18 芯片组以及其他功能 Sep 27, 2024 am 09:02 AM

苹果带有集成屏幕的类似 HomePod 的设备的最新细节已经浮出水面,它们描绘了该设备的更清晰的图片,该设备被称为“HomeAccessory”。当它推出时,它将是苹果对谷歌 Nest Hub Max 的回应

iPhone 16 Pro 和 iPhone 16 Pro Max 正式发布,配备新相机、A18 Pro SoC 和更大的屏幕 iPhone 16 Pro 和 iPhone 16 Pro Max 正式发布,配备新相机、A18 Pro SoC 和更大的屏幕 Sep 10, 2024 am 06:50 AM

苹果终于揭开了其新款高端 iPhone 机型的面纱。与上一代产品相比,iPhone 16 Pro 和 iPhone 16 Pro Max 现在配备了更大的屏幕(Pro 为 6.3 英寸,Pro Max 为 6.9 英寸)。他们获得了增强版 Apple A1

苹果 iPhone 16 和 iPhone 16 Plus 推出配备 48MP'融合相机”、相机控制和 A18 芯片 苹果 iPhone 16 和 iPhone 16 Plus 推出配备 48MP'融合相机”、相机控制和 A18 芯片 Sep 10, 2024 am 09:30 AM

Apple 正式发布了 iPhone 16 和 iPhone 16 Plus,引入了采用全新 A18 芯片的关键硬件更新。这两款型号都有两种尺寸:6.1 英寸和 6.7 英寸,均配备 Super Retina XDR 显示屏。它们还具有铝制设计和 ar

苹果分析师对即将推出的 iPhone 16、iPhone SE 4 甚至传闻中的 iPhone 17 Air 发布提供了新的见解 苹果分析师对即将推出的 iPhone 16、iPhone SE 4 甚至传闻中的 iPhone 17 Air 发布提供了新的见解 Aug 12, 2024 pm 10:01 PM

Apple 的下一代 iPhone 即将推出。虽然该公司尚未透露新机发布会的日期,但所有迹象似乎都表明将在 9 月发布,就像去年的 iPhone 15 系列一样。顺便说一句,假人的镜头

新款 Apple iPhone 16 设计和颜色与 iPhone 15 的对比视频 新款 Apple iPhone 16 设计和颜色与 iPhone 15 的对比视频 Aug 12, 2024 am 06:59 AM

预计苹果公司的下一代 iPhone 至少还要过一个月才会发布。尽管如此,网上仍不断出现显示具有所谓官方发布颜色的 iPhone 16 假机的视频。顺便说一句,虽然谷歌之前发布了

分析师讨论传闻中的 Meta Quest 3S VR 耳机的发布定价 分析师讨论传闻中的 Meta Quest 3S VR 耳机的发布定价 Aug 27, 2024 pm 09:35 PM

自 Meta 首次发布 Quest 3(亚马逊售价 499.99 美元)以来,已经过去一年多了。此后,苹果推出了价格昂贵得多的 Vision Pro,而字节跳动现在在中国推出了 Pico 4 Ultra。然而,有

iOS 18 Beta 现在支持 Matter 智能灯泡上的自适应照明 iOS 18 Beta 现在支持 Matter 智能灯泡上的自适应照明 Aug 14, 2024 pm 12:48 PM

除了计划在 iOS 18 中使用的生成式 AI 功能外,一些 Reddit 用户还发现,iOS 18.1 Beta 版默认为 Nanoleaf 的 Matter 兼容智能灯泡启用自适应照明。自适应闪电,Apple Home 的主打产品

See all articles