是否有使用javascript或jQuery对角滚动的项目或插件?
例如当您向下滚动内容时,它会被拉到浏览器的左上角;当您向上滚动时,您的内容将被拉到角落的右下方.
我看到一些类似的项目/网站,他们在滚动时动画他们的元素.大多数使用javascript的网站虽然有一些滞后效果.另一个我见过的是使用类似于“Nike a Better World”的html5视差效果(http://coding.smashingmagazine.com/2011/07/12/behind-the-scenes-of-nike-better-world/)
你能指出我哪里可以成为一个好的起点吗?基本上我想要对角左右滚动项目.如果这可以在HTML5中明确地完成,我会高度考虑,因为我觉得它会有更少的滞后或更少的计算.
解决方法
我能够在小提琴中创造你想要的效果:
http://jsfiddle.net/t0nyh0/8QTYt/36/
重要的花絮
>一个“固定”的全宽和全高包装器,可以容纳所有移动元素,帮助您根据滚动位置(实际上是“关键帧”数字)更加一致地设置div的动画.
> scroll_max,wrapper_width和wrapper_height有助于规范化包装器的尺寸.即滚动的最底部对应于包装器的底部/右侧,滚动的最顶部对应于包装器的顶部/左侧.
>将身体的高度设置为您想要的任意数量的“关键帧”.
>要在向下移动时从左上角移动到右下角,请调整顶部和左侧属性.相反,调整底部和右侧属性.当然,您需要为更复杂的动画制定自己的计算,但要知道做$window.scrollTop()将为您提供“关键帧”编号.
HTML
- <div id="wrapper">
- <div id="a">
- <h1>Meats</h1>
- </div>
- <div id="b">
- <h1>Veggies</h1>
- <hr/>
- <p>Veggies sunt bona vobis,proinde vos postulo esse magis daikon epazote peanut chickpea bamboo shoot rutabaga maize radish broccoli rabe lotus root kohlrabi napa cabbage courgette mustard squash mung bean.</p>
- </div>
- </div>
CSS
- body
- {
- height: 1000px; // 1000 keyframes
- }
- #wrapper
- {
- width: 100%;
- height: 100%;
- position: fixed;
- border: 2px solid navy;
- overflow:hidden;
- }
- #a {
- position:absolute;
- background-color: #daf1d7;
- width: 300px;
- height: 300px;
- }
- #b
- {
- position: absolute;
- background-color: #d2d0ee;
- width: 200px;
- height: 200px;
- bottom: 0px;
- right: 0px;
- }
Javscript
- var $window = $(window);
- var $a = $('#a');
- var $b = $('#b');
- var scroll_max = document.documentElement.scrollHeight - document.documentElement.clientHeight;
- var wrapper_height = $('#wrapper').height();
- var wrapper_width = $('#wrapper').width();
- $window.scroll(function() {
- console.log(scroll_max);
- $a.css({
- 'top': ($window.scrollTop() / scroll_max) * wrapper_height,'left': ($window.scrollTop() / scroll_max) * wrapper_width
- });
- $b.css({
- 'bottom': ($window.scrollTop() / scroll_max) * wrapper_height,'right': ($window.scrollTop() / scroll_max) * wrapper_width
- });
- });