SaucySlider is a jQuery plugin that adds horizontal parallax effects to web pages. These effects are controlled with CSS transitions (and fallbacks for unsupported browsers) for a silky smooth experience. Elements are grouped into different scenes which the users can navigate to at their discretion.
- Works in all major browsers with support for IE8 and up.
- Requires jQuery 1.7+
Download SaucySlider.js and the latest version of jQuery. After ensuring both are linked on your page you can begin to create your markup. After you have laid out your markup and styled your page you then must add special properties to the elements you wish to make parallax.
The first property is the "data-scene" attribute. This attribute designates which scene the particular element belongs to.
<!-- Example 1.0 -->
<div class="example-piece" data-scene="0"></div>
Scene numbers can be any whole number. Keep in mind that scene numbers are zero based so the first scene would be data-scene="0". Later we will also add the scene locations to SaucySlider's JavaScript properties.
The next property to add is the "data-layer" attribute. This is the most important attribute as it controls the parallax effects.
<!-- Example 1.1 -->
<div class="example-piece" data-scene="0" data-layer="1"></div>
The "data-layer" attribute can be any number and acts as a multiplier to move elements at different speeds and directions.
The "data-bg-x" and "data-bg-y" attributes can also be added to move the background position of an element in the same way the "data-layer" attribute moves the whole piece.
<!-- Example 1.2 -->
<div class="example-piece" data-scene="0" data-layer="1" data-bg-x="2" data-bg-y="-1.2"></div>
The "data-inner" attribute can be added to an element to designate that it should parallax relative to its parent.
<!-- Example 1.3 -->
<div class="example-piece" data-scene="0" data-layer="1">
<img src="img.png" data-scene="0" data-layer="3" data-inner>
</div>
The "data-transtion" attribute allows you to add your own transtion values to elements without having to override SaucySlider's transtions.
<!-- Example 2 -->
<div class="example-piece-2" data-scene="0" data-layer="1" data-transition="opacity 0.2s, background-color 300ms"></div>
The elements used for the navigation are defined in the JavaScript properties. Users can navigate with either a next and previous button, pagers, or both.
Now its time to set up your JavaScript properties. Here you will defined where scenes are located, how fast to move between scenes, the name of each scene, and which elements to use for the navigation. There are also three callback functions that can be used to detect when SaucySlider is moving to a new scene, stopped at a scene, or canceled the scene movement.
This property is set to an array of integers designating the pixel value (from the left to right) where each scene is located. The location of each scene is always in the center of the screen including a location of 0.
// Example 1.0
scenePoints: [0, 1400, 2540]
This property is set to an array of integers designating the time in milliseconds to takes to travel between adjacent scenes. This means there can only be one value when changing between scenes for both directions. The length of this array will always be one less than the length of the scenePoints array.
// Example 1.1
// -----------
// It will take 2 seconds to travel between scene zero and one,
// and 3 seconds to travel between scenes one and two.
sceneTimes : [2000, 3000],
scenePoints : [0, 1400, 2540]
This property is set to an array of strings. SaucySlider will put these strings into the URL hash to designate which scene SaucySlider is currently on. These hashes can also be used to link directly to a scene.
// Example 1.2
sceneNames : ['First', 'Second', 'Third'],
sceneTimes : [2000, 3000],
scenePoints : [0, 1400, 2540]
This property is a jQuery object of the element to be used as the next scene button. The class "off" will be added to this element if there are no more scenes to travel forward to.
// Example 1.3
nextButton : $('.next'),
sceneNames : ['First', 'Second', 'Third'],
sceneTimes : [2000, 3000],
scenePoints : [0, 1400, 2540]
This property is a jQuery object of the element to be used as the previous scene button. The class "off" will be added to this element if there are no more scenes to travel back to.
// Example 1.4
prevButton : $('.prev'),
nextButton : $('.next'),
sceneNames : ['First', 'Second', 'Third'],
sceneTimes : [2000, 3000],
scenePoints : [0, 1400, 2540]
This property is a jQuery object of each pager button used to change SaucySlider to a specific scene. When moving to a scene that is not directly adjacent to the current scene all scene times SaucySlider will move through are added, divided by 2.5, and used as the sceneTime for this transition.
// Example 1.5
pagers : $('ul.pagers li'),
prevButton : $('.prev'),
nextButton : $('.next'),
sceneNames : ['First', 'Second', 'Third'],
sceneTimes : [2000, 3000],
scenePoints : [0, 1400, 2540]
This function fires every time SaucySlider moves to a new scene. It passes in the value of the scene its moving from and the scene its moving to.
// Example 2
sceneMoved: function(a){ console.log(a); }
// Result when moving from scene zero to scene one.
{ pastScene: 0, newScene: 1 }
This function fires every time SaucySlider ends its transition to a new scene. It passes in the value of the current scene.
// Example 2
sceneStopped: function(a){ console.log(a); }
// Result when the transition stopped on scene one.
{ currentScene : 1 }
This function fires every time the user changes which scene SaucySlider is moving to while a scene transition is already taking place. It passes in the value of the scene SaucySlider was originally supposed to stop on.
// Example 2
sceneCanceled: function(a){ console.log(a); }
// Result when the scene transition was canceled while moving to scene one.
{ currentScene : 1 }
Property | Default Value | Accepted Values |
---|---|---|
scenePoints | [ ] | Array of integers |
sceneTimes | [ ] | Array of integers |
sceneNames | [ ] | Array of strings |
pager | false | jQuery Object |
nextButton | false | jQuery Object |
prevButton | false | jQuery Object |
sceneMoved | function(){} | function |
sceneStopped | function(){} | function |
sceneCanceled | function(){} | function |
Attribute | Accepted Values | Definition |
---|---|---|
data-scene | Whole numbers | Designates which scene the element belongs to |
data-layer | Numbers | Designates the speed of the element's parallax effects |
data-bg-x | Numbers | Designates the speed of the element's parallax effects for its horizontal background position |
data-bg-y | Numbers | Designates the speed of the element's parallax effects for its vertical background position |
data-transition | Valid CSS transition values | Used to add other CSS transition values without overriding SaucySlider's transitions |