如何进行水平视差滚动

时间:2015-01-08 15:13:43

标签: jquery twitter-bootstrap parallax skrollr

我正在使用最新版本的Bootstrap,JQuery和Skrollr。

我希望有一个静态背景和一些场景,当您通过视差滚动滚动时。我可以在你滚动的时候制作场景,但我正在寻找一种方法来显示你没有向下移动页面。

我想制作一个像这张图片的场景:

example

请注意它是如何左右移动但从未出现过你实际上向下滚动页面。

这是我能解释的最好的。似乎无法找到任何好的教程来实现这一目标。任何朝着正确方向的帮助都会很出色。

2 个答案:

答案 0 :(得分:3)

如评论中所述,skrollr不支持水平滚动,但您可以执行其他操作:

您可以使用垂直滚动条为水平元素设置动画。

这是Horizontal scrolling effect with Skrollr上的Stack Overflow帖子 这是jsFiddle from that post

中的工作演示

希望这能让你前进。

答案 1 :(得分:1)

jInvertScroll允许水平滚动并支持视差。

这是一篇关于如何create horizontal parallax scrolling with jInvertScroll

的文章

只需对地平线和中间滚动使用不同的值

<div class="horizon scroll">
  <img src="http://i.imgur.com/IImTBHM.png" alt="Background" />
</div>

<div class="middle scroll">
  <img src="http://i.imgur.com/e2pwKbv.png" alt="Clouds and Baloons" />
</div>

这是一个堆栈摘要中的演示

  

注意:尝试在整页

中查看

&#13;
&#13;
(function($) {
  $.jInvertScroll(['.scroll']);
}(jQuery));
&#13;
html, body {
  padding: 0;
  margin: 0;
  font-family:'Open Sans', sans-serif;
  font-weight: 300;
  font-size: 16px;
  color: #555;
  background: #9fdefd;
}
h1, h2 {
  color: #238acb;
}
.horizon {
  line-height: 0;
  z-index: 100;
  width: 3000px;
}
.middle {
  line-height: 0;
  z-index: 250;
  width: 4500px;
}
.front {
  z-index: 500;
  top: 150px;
  width: 6000px;
}
.intro {
  position: absolute;
  left: 500px;
  top: 0px;
  padding-right: 50px;
  background: url('http://i.imgur.com/3woqwh2.png') no-repeat right 5px;
}
.page {
  position: absolute;  
  top: 0px;
  width: 500px;
  background: white;
  padding: 10px 30px;
  border: 1px #eee solid;

}
.panel1 {
  left: 1500px;
}
.panel2 {
  left: 2575px;
}
.panel3 {
  left: 3800px;
}
.panel4 {
  left: 5100px;
}
&#13;
<link href="http://www.pixxelfactory.net/jInvertScroll/css/jInvertScroll.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="http://www.pixxelfactory.net/jInvertScroll/js/jquery.jInvertScroll.js"></script>


<div class="container">

  <div class="horizon scroll">
    <img src="http://i.imgur.com/IImTBHM.png" alt="Background" />
  </div>

  <div class="middle scroll">
    <img src="http://i.imgur.com/e2pwKbv.png" alt="Clouds and Baloons" />
  </div>

  <div class="front scroll">
    <h1 class="intro">Scroll down</h1>

    <div class="panel1 page">
      <h2>The Hot Air Balloon</h2>

    </div>

    <div class="panel2 page">
      <h2>How they work</h2> 

    </div>

    <div class="panel3 page">
      <h2>Practicalities</h2>

    </div>

    <div class="panel4 page">
      <h2>Section 4</h2>

    </div>
  </div>
</div>
&#13;
&#13;
&#13;