Monday, 13 February 2017
AUTO CSS JS SLIDER WITH ARROW BULLET
-------------------------------------------------------------------------------------------------------
BX SLIDER CODE:
READ MORE:
BX SLIDER IN BLOGGER TEMPALTE - YouTube
https://www.youtube.com/watch?v=C76MSvddKSU
22 mins ago - Uploaded by SAVE MONEY
BX SLIDER IN BLOGGER TEMPALTE. SAVE MONEY ... How to make a pop up card box tutorial FREE Card ...BXSLIDER CODE PEN
https://s.codepen.io/boomerang/iFrameKey-d648dd64-73cf-9563-7f25-b946371202d4/index.html http://bxslider.com/examples/auto-show-start-stop-controls
https://codepen.io/tobydennison/pen/azZroz
http://www.jqueryscript.net/slider/Super-Simple-jQuery-Image-Slider-Plugin-with-jQuery-CSS3-Slippry.html
http://www.jqueryscript.net/slider/Responsive-jQuery-Slider-Plugin-with-CSS3-Transitions-Glide-js.html
https://www.w3schools.com/w3css/w3css_slideshow.asp
http://slippry.com/examples/css-vs-jquery/
https://flickity.metafizzy.co/
https://css-tricks.com/creating-responsive-touch-friendly-carousels-with-flickity/
FIND HEADER CLOSED TAG AND PASTE BELOW CODE
</header>
-------------------------------------------------------------------------------------------------------
<html> <head> <title>Examples | Responsive jQuery Slider | bxSlider</title> <link href="https://fonts.googleapis.com/css?family=Overpass+Mono:300,400,600,700" rel="stylesheet"> <link href="https://fonts.googleapis.com/css?family=Muli" rel="stylesheet"> <link href="https://fonts.googleapis.com/css?family=Lato:300,400,500,600,900" rel="stylesheet"> <link rel="stylesheet" href="https://cdn.jsdelivr.net/bxslider/4.2.12/jquery.bxslider.css"> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script> <script src="https://cdn.jsdelivr.net/bxslider/4.2.12/jquery.bxslider.min.js"></script> <link type="text/css" rel="stylesheet" href="css/style.css"/> </head> <body class="example-item"> <script type="text/javascript"> $(document).ready(function(){ $('.bxslider').bxSlider({ auto: true, autoControls: true, captions: true }); }); </script> <h1>Carousel - dynamic number of slides</h1> <div class="slider"> <ul class="bxslider"> <li><img src="https://picsum.photos/1600/600?random=1" /></li> <li><img src="https://picsum.photos/1600/600?random=2" /></li> <li><img src="https://picsum.photos/1600/600?random=3" /></li> <li><img src="https://picsum.photos/1600/600?random=4" /></li> <li><img src="https://picsum.photos/1600/600?random=5" /></li> <li><img src="https://picsum.photos/1600/600?random=6" /></li> </ul> </div> </body> </html>
------------------------------------------------------------------
BX CAROUSEL SLIDER CODE
DIFFERENT CODE FROM UPPER SLIDER
<script src="http://bxslider.com/js/jquery.min.js"></script>
---------------------------------------------------------------------
CHANGE BLOW CODE SLIDER WIDTH SETTING AND PAGINATION 3 BUTTON CODE
---------------------------------------------------------------------
<script type="text/javascript">//3 BUTTON SLIDER CODE
$(document).ready(function(){
$('.bxslider').bxSlider({
minSlides: 2,
maxSlides: 2,
slideWidth: 200,
slideMargin: 2
});
});
</script>
---------------------------------------------------------------------
<script type="text/javascript">
$(document).ready(function(){
$('.bxslider').bxSlider({
minSlides: 3,
maxSlides: 4,
slideWidth: 170,
slideMargin: 10
});
});
</script>
------------------------------------------------------------------
<html>
<!-- https://wesbos.com/javascript/15-final-round-of-exercise/84-web-speech-colours-game#combining-speech-and-words -->
<head>
<title>Examples | Responsive jQuery Slider | bxSlider</title>
<link href="https://fonts.googleapis.com/css?family=Overpass+Mono:300,400,600,700" rel="stylesheet">
<link href="https://fonts.googleapis.com/css?family=Muli" rel="stylesheet"><link href="https://fonts.googleapis.com/css?family=Lato:300,400,500,600,900" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/bxslider/4.2.12/jquery.bxslider.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/bxslider/4.2.12/jquery.bxslider.min.js"></script>
<link type="text/css" rel="stylesheet" href="css/style.css"/>
</head>
<body class="example-item">
<h1>Carousel - dynamic number of slides</h1>
<div class="example__slider">
<div class="bxslider">
<div><img src="https://bxslider.com/assets/images/coffee1.jpg" title="Funky roots"></div>
<div><img src="https://bxslider.com/assets/images/coffee2.jpg" title="The long and winding road"></div>
<div><img src="https://bxslider.com/assets/images/coffee3.jpg" title="Happy trees"></div>
</div>
</div>
<script>
$(function(){
$('.bxslider').bxSlider({
auto: true,
autoControls: true,
mode: 'fade',
captions: true,
slideWidth: 600
});
});
</script>
</body>
</html>
------------------------------------------------------------------
CHANGE UPPER SLIDER INTO AUTO SLIDERNEED TWO LINES
auto: true,
autoControls: true,
------------------------------------------------------------------
<!DOCTYPE html>
<head>
<title>Examples | Responsive
jQuery Slider | bxSlider</title>
<link rel="stylesheet" href="http://bxslider.com/lib/jquery.bxslider.css" type="text/css" />
<script src="http://bxslider.com/js/jquery.min.js"></script>
<script src="http://bxslider.com/lib/jquery.bxslider.js"></script>
</head>
<body class="example-item">
<script type="text/javascript">
$(document).ready(function(){
$('.bxslider').bxSlider({
minSlides: 2,
maxSlides: 4,
slideWidth: 200,
slideheight:170,
slideMargin: 0,
auto: true,
autoControls: true,
});
});
</script>
<h1>Carousel - dynamic
number of slides</h1>
<div class="slider">
<ul class="bxslider">
<li><img src="http://bxslider.com/images/170_200/trees.jpg" /></li>
<li><img src="http://bxslider.com/images/170_200/tree_root.jpg" /></li>
<li><img src="http://bxslider.com/images/170_200/houses.jpg" /></li>
<li><img src="http://bxslider.com/images/170_200/hill_road.jpg" /></li>
<li><img src="http://bxslider.com/images/170_200/me_trees.jpg" /></li>
<li><img src="http://bxslider.com/images/170_200/hill_trees.jpg" /></li>
</ul>
</div>
</body>
</html>
-------------------------------------------------------------------
SLIPPERY SLIDER CSS VS JQUERY CODE
-------------------------------------------------------------------
<!doctype html>
<html lang="en">
<!-- Copy From:
http://slippry.com/examples/css-vs-jquery/ -->
<head>
<meta charset="utf-8">
<meta name="description" content="Slippry is a responsive content slider by booncon PIXELS. Slippry
is truly responsive, built on modern web standards and is packed with options,
so it can be as simple or complex as you want, so give it a go!" />
<meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">
<meta name="viewport" content="width=device-width">
<title>Examples - CSS vs
jQuery transitions</title>
<script src="https://use.edgefonts.net/cabin:n4,i4,n7,i7;source-sans-pro:n3,i3.js"></script>
<link href="http://cdn-images.mailchimp.com/embedcode/slim-081711.css" rel="stylesheet" type="text/css" />
<link href="http://slippry.com/assets/css/styles.css" rel="stylesheet" type="text/css" />
</head>
<body class="examples examples_css-vs-jquery
examples_css-vs-jquery_index">
<section class="restricted-width">
<h2 class="slider-title">CSS vs jQuery</h2>
<p>This demo shows the
differences between using CSS transitions and jQuery transitions. What's the
difference? In a nutshell,
CSS uses your graphic card to process
the transition, where as using jQuery uses your main processor.
However jQuery is generally more
backwards compatible than CSS. That said,
CSS transitions will revert to jQuery
if the browser doesn't support CSS transitions.
Read More:
http://slippry.com/examples/css-vs-jquery/
</p>
<h3>CSS</h3>
<ul id="css-demo">
<li><a href="#slide1"><img src="http://slippry.com/assets/img/image-1.jpg" alt="This is
caption 1 <a href='#link'>Even with links!</a>"></a></li>
<li><a href="#slide2"><img src="http://slippry.com/assets/img/image-2.jpg" alt="This is caption 2"></a></li>
<li><a href="#slide3"><img src="http://slippry.com/assets/img/image-3.jpg" alt="And this is some very long caption for slide
3. Yes, really long."></a></li>
<li><a href="#slide4"><img src="http://slippry.com/assets/img/image-4.jpg" alt="And this is
some very long caption for slide 4."></a></li>
</ul>
<h3>jQuery</h3>
<ul id="jquery-demo">
<li><a href="#slide1"><img src="http://slippry.com/assets/img/image-1.jpg" alt="This is
caption 1 <a href='#link'>Even with links!</a>"></a></li>
<li><a href="#slide2"><img src="http://slippry.com/assets/img/image-2.jpg" alt="This is caption 2"></a></li>
<li><a href="#slide3"><img src="http://slippry.com/assets/img/image-3.jpg" alt="And this is some very long caption for slide
3. Yes, really long."></a></li>
<li><a href="#slide4"><img src="http://slippry.com/assets/img/image-4.jpg" alt="And this is
some very long caption for slide 4."></a></li>
</ul>
</section>
<script src="https://use.edgefonts.net/source-code-pro:n4,n7.js" type="text/javascript"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js" type="text/javascript"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js" type="text/javascript"></script>
<script src="http://slippry.com/assets/js/scripts.js" type="text/javascript"></script>
</body>
</html>
-----------------------------------------------------------------------
Bootstrap Carousel Plugin Code
IT IS AUTO CSS JS SLIDER WITH ARROW BULLET
-----------------------------------------------------------------------
-----------------------------------------------------------------------
-----------------------------------------------------------------------
Bootstrap Carousel Plugin Code
IT IS AUTO CSS JS SLIDER WITH ARROW BULLET
-----------------------------------------------------------------------
-----------------------------------------------------------------------
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<style>
.carousel-inner > .item > img,
.carousel-inner > .item > a >
img {
width: 70%;
margin: auto;
}
</style>
</head>
<body>
<div class="container">
<br>
<div id="myCarousel" class="carousel slide" data-ride="carousel">
<!-- Indicators -->
<ol class="carousel-indicators">
<li data-target="#myCarousel" data-slide-to="0" class="active"></li>
<li data-target="#myCarousel" data-slide-to="1"></li>
<li data-target="#myCarousel" data-slide-to="2"></li>
<li data-target="#myCarousel" data-slide-to="3"></li>
</ol>
<!-- Wrapper for slides -->
<div class="carousel-inner" role="listbox">
<div class="item active">
<img src="https://www.w3schools.com/bootstrap/img_chania.jpg" alt="Chania" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_chania2.jpg" alt="Chania" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_flower.jpg" alt="Flower" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_flower2.jpg" alt="Flower" width="460" height="345">
</div>
</div>
<!-- Left and right controls -->
<a class="left carousel-control" href="#myCarousel" role="button" data-slide="prev">
<span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="right carousel-control" href="#myCarousel" role="button" data-slide="next">
<span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
</div>
</body>
</html>
-----------------------------------------------------------------------
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<style>
.carousel-inner > .item > img,
.carousel-inner > .item > a >
img {
width: 70%;
margin: auto;
}
</style>
</head>
<body>
<div class="container">
<br>
<div id="myCarousel" class="carousel slide" data-ride="carousel">
<!-- Indicators -->
<ol class="carousel-indicators">
<li data-target="#myCarousel" data-slide-to="0" class="active"></li>
<li data-target="#myCarousel" data-slide-to="1"></li>
<li data-target="#myCarousel" data-slide-to="2"></li>
<li data-target="#myCarousel" data-slide-to="3"></li>
</ol>
<!-- Wrapper for slides -->
<div class="carousel-inner" role="listbox">
<div class="item active">
<img src="https://www.w3schools.com/bootstrap/img_chania.jpg" alt="Chania" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_chania2.jpg" alt="Chania" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_flower.jpg" alt="Flower" width="460" height="345">
</div>
<div class="item">
<img src="https://www.w3schools.com/bootstrap/img_flower2.jpg" alt="Flower" width="460" height="345">
</div>
</div>
<!-- Left and right controls -->
<a class="left carousel-control" href="#myCarousel" role="button" data-slide="prev">
<span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="right carousel-control" href="#myCarousel" role="button" data-slide="next">
<span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
</div>
</body>
</html>
FILES CODES
----------------------------------------------------------------------------------------------------------
<link href='http://bxslider.com/lib/jquery.bxslider.css'
rel='stylesheet' type='text/css'/>
-------------------------------------------------------------------------------------------------------
**
* BxSlider v4.1.2 - Fully loaded, responsive content slider
* http://bxslider.com
*
* Written by:
Steven Wanderski, 2014
* http://stevenwanderski.com
* (while drinking Belgian ales and
listening to jazz)
*
* CEO and founder of bxCreative, LTD
* http://bxcreative.com
*/
/** RESET AND LAYOUT
===================================*/
.bx-wrapper {
position: relative;
margin: 0 auto 60px;
padding: 0;
*zoom: 1;
}
.bx-wrapper img {
max-width: 100%;
display: block;
}
/** THEME
===================================*/
.bx-wrapper .bx-viewport {
-moz-box-shadow: 0 0 5px #ccc;
-webkit-box-shadow: 0 0 5px #ccc;
box-shadow: 0 0 5px #ccc;
border: 5px solid #fff;
left: -5px;
background: #fff;
/*fix other elements on the page moving (on
Chrome)*/
-webkit-transform: translatez(0);
-moz-transform: translatez(0);
-ms-transform: translatez(0);
-o-transform: translatez(0);
transform: translatez(0);
}
.bx-wrapper .bx-pager,
.bx-wrapper .bx-controls-auto {
position: absolute;
bottom: -30px;
width: 100%;
}
/* LOADER */
.bx-wrapper .bx-loading {
min-height: 50px;
background: url(images/bx_loader.gif) center center no-repeat #fff;
height: 100%;
width: 100%;
position: absolute;
top: 0;
left: 0;
z-index: 2000;
}
/* PAGER */
.bx-wrapper .bx-pager {
text-align: center;
font-size: .85em;
font-family: Arial;
font-weight: bold;
color: #666;
padding-top: 20px;
}
.bx-wrapper .bx-pager .bx-pager-item,
.bx-wrapper .bx-controls-auto .bx-controls-auto-item {
display: inline-block;
*zoom: 1;
*display: inline;
}
.bx-wrapper .bx-pager.bx-default-pager a {
background: #666;
text-indent: -9999px;
display: block;
width: 10px;
height: 10px;
margin: 0 5px;
outline: 0;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
border-radius: 5px;
}
.bx-wrapper .bx-pager.bx-default-pager a:hover,
.bx-wrapper .bx-pager.bx-default-pager a.active {
background: #000;
}
/* DIRECTION CONTROLS (NEXT / PREV) */
.bx-wrapper .bx-prev {
left: 10px;
background: url(images/controls.png) no-repeat 0 -32px;
}
.bx-wrapper .bx-next {
right: 10px;
background: url(images/controls.png) no-repeat -43px -32px;
}
.bx-wrapper .bx-prev:hover {
background-position: 0 0;
}
.bx-wrapper .bx-next:hover {
background-position: -43px 0;
}
.bx-wrapper .bx-controls-direction a {
position: absolute;
top: 50%;
margin-top: -16px;
outline: 0;
width: 32px;
height: 32px;
text-indent: -9999px;
z-index: 9999;
}
.bx-wrapper .bx-controls-direction a.disabled {
display: none;
}
/* AUTO CONTROLS (START / STOP) */
.bx-wrapper .bx-controls-auto {
text-align: center;
}
.bx-wrapper .bx-controls-auto .bx-start {
display: block;
text-indent: -9999px;
width: 10px;
height: 11px;
outline: 0;
background: url(images/controls.png) -86px -11px no-repeat;
margin: 0 3px;
}
.bx-wrapper .bx-controls-auto .bx-start:hover,
.bx-wrapper .bx-controls-auto .bx-start.active {
background-position: -86px 0;
}
.bx-wrapper .bx-controls-auto .bx-stop {
display: block;
text-indent: -9999px;
width: 9px;
height: 11px;
outline: 0;
background: url(images/controls.png) -86px -44px no-repeat;
margin: 0 3px;
}
.bx-wrapper .bx-controls-auto .bx-stop:hover,
.bx-wrapper .bx-controls-auto .bx-stop.active {
background-position: -86px -33px;
}
/* PAGER WITH AUTO-CONTROLS HYBRID LAYOUT */
.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-pager {
text-align: left;
width: 80%;
}
.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-controls-auto {
right: 0;
width: 35px;
}
/* IMAGE CAPTIONS */
.bx-wrapper .bx-caption {
position: absolute;
bottom: 0;
left: 0;
background: #666\9;
background: rgba(80, 80, 80, 0.75);
width: 100%;
}
.bx-wrapper .bx-caption span {
color: #fff;
font-family: Arial;
display: block;
font-size: .85em;
padding: 10px;
}
----------------------------------------------------------------------------------------------------------
OR USE THIS KEY FRAME CSS SLIDER 1
http://fbgadgets.blogspot.co.uk/2013/07/AutoFlipRotateForBloggerPost.html
-----------------------------------------------------------------------------------------------------------
AUTO KEY FRAME SLIDER CODE:
-----------------------------------------------------------------------------------------------------------
AUTO OWL CAROUSEL SLIDER CODE
----------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------
JATINDER CSS SLIDER CODE YOUTUBE
-----------------------------------------------------------------------------------------------------------
<!DOCTYPE html>
<!-- https://www.youtube.com/watch?v=xVaW-e_eOPs&t=115s -->
<!-- http://stackoverflow.com/questions/40204345/moving-a-slide-show-to-the-left-in-html -->
<html>
<head>
<style>
#outerbox{
}
#sliderbox{
position:relative;
width:2800px;
animation-name:jatinder;
animation-duration: 2s;
}
#sliderbox img{
float:left;
border-color:#0000FF;
border-style:solid;
}
@keyframes jatinder{
0%{
left:0px;
}
20%{
left:0px;
}
25%{
left:-700px;
}
45%{
left:-700px;
}
50%{
left:-1400px;
}
70%{
left:-1400px;
}
75%{
left:-2100px;
}
100%{
left:-2800px;
}
}
</style>
</head>
<body>
<div id="outerbox">
<div id="sliderbox">
<img src="http://fo.demo.prestashop.com/1-home_default/faded-short-sleeves-tshirt.jpg"/>
<img src="http://fo.demo.prestashop.com/7-home_default/blouse.jpg"/>
<img src="http://fo.demo.prestashop.com/8-home_default/printed-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/10-home_default/printed-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/12-home_default/printed-summer-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/16-home_default/printed-summer-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/20-home_default/printed-chiffon-dress.jpg"/>
</body>
</html>
------------------------------------------------------------------------------------------------------------
MAGENTO NEW PRODUCTS WITH OWL CAROUSEL
https://www.magentocommerce.com/magento-connect/new-products-2.html
----------------------------------------------------------------------------------------------------------------
OR USE THIS KEY FRAME CSS SLIDER 1
http://fbgadgets.blogspot.co.uk/2013/07/AutoFlipRotateForBloggerPost.html
-----------------------------------------------------------------------------------------------------------
AUTO KEY FRAME SLIDER CODE:
-----------------------------------------------------------------------------------------------------------
<html>
<head>
<meta charset=utf-8 />
<meta name="description" content="description">
<title>Design Shack Animated Photo Banner</title>
<style>
/*body and container*/
* {
margin: 0;
padding: 0;
}
body {
background: url('dark_geometric.png');
}
#container {
width: 1000px;
overflow: hidden;
margin: 50px auto;
background: white;
}
/*header*/
header {
width: 800px;
margin: 40px auto;
}
header h1 {
text-align: center;
font: 100 60px/1.5 Helvetica, Verdana, sans-serif;
}
header p {
font: 100 15px/1.5 Helvetica, Verdana, sans-serif;
text-align: justify;
}
/*photobanner*/
.photobanner {
height: 233px;
width: 3550px;
margin-bottom: 80px;
}
.photobanner img {
-webkit-transition: all 0.5s ease;
-moz-transition: all 0.5s ease;
-o-transition: all 0.5s ease;
-ms-transition: all 0.5s ease;
transition: all 0.5s ease;
}
.photobanner img:hover {
-webkit-transform: scale(1.1);
-moz-transform: scale(1.1);
-o-transform: scale(1.1);
-ms-transform: scale(1.1);
transform: scale(1.1);
cursor: pointer;
-webkit-box-shadow: 0px 3px 5px rgba(0,0,0,0.2);
-moz-box-shadow: 0px 3px 5px rgba(0,0,0,0.2);
box-shadow: 0px 3px 5px rgba(0,0,0,0.2);
}
/*keyframe animations*/
.first {
-webkit-animation: bannermove 30s linear infinite;
-moz-animation: bannermove 30s linear infinite;
-ms-animation: bannermove 30s linear infinite;
animation: bannermove 30s linear infinite;
}
@keyframes
"bannermove" {
0% {
margin-left: 0px;
}
100% {
margin-left: -2125px;
}
}
@-moz-keyframes
bannermove {
0% {
margin-left: 0px;
}
100% {
margin-left: -2125px;
}
}
@-webkit-keyframes
"bannermove" {
0% {
margin-left: 0px;
}
100% {
margin-left: -2125px;
}
}
@-ms-keyframes
"bannermove" {
0% {
margin-left: 0px;
}
100% {
margin-left: -2125px;
}
}
@-o-keyframes
"bannermove" {
0% {
margin-left: 0px;
}
100% {
margin-left: -2125px;
}
}
</style>
</head>
<body>
<div id="container">
<header>
<h1>Animated Photo Banner</h1>
<p>An animated banner of photos that automatically
scrolls horizontally through an infinite loop.
The best part: no JavaScript! It also uses individual images inserted via HTML,
not simply one long repeating CSS background.
<a href="http://designshack.net/articles/css/infinitephotobanner/">Click here</a>
to
return to the tutorial on Design Shack.</p>
</header>
<div class="photobanner">
<img class="first" src="http://designshack.net/tutorialexamples/photobanner/image-1.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-2.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-3.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-4.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-5.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-6.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-1.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-2.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-3.jpg" alt="" />
<img src="http://designshack.net/tutorialexamples/photobanner/image-4.jpg" alt="" />
</div>
</div>
</body>
</html>
------------------------------------------------------------------------
OR USE SIMPLE JS CAROUSEL
http://ryrych.pl/rcarousel/
--------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
OR USE SIMPLE JS CAROUSEL
http://ryrych.pl/rcarousel/
--------------------------------------------------------------------------
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML
1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<!-- saved from
url=(0047)http://ryrych.pl/rcarousel/examples/simple.html -->
<html xmlns="http://www.w3.org/1999/xhtml" lang="pl" xml:lang="pl">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>rcarousel simple carousel</title>
<link type="text/css" rel="stylesheet" href="http://ryrych.pl/rcarousel/examples/css/reset.css">
<link type="text/css" rel="stylesheet" href="http://ryrych.pl/rcarousel/examples/css/style.css">
<link type="text/css" rel="stylesheet" href="http://ryrych.pl/rcarousel/widget/css/rcarousel.css">
<style type="text/css">
#carousel {
width: 300px;
}
</style>
</head>
<body>
<div id="header">
<p>
This is an example of <em>rcarousel</em> a jQuery UI continuous carousel.
Go back to the <a href="http://ryrych.github.com/rcarousel/">documentation</a>
</p>
</div>
<div id="content">
<h1>simple carousel
without navigation but with Auto mode</h1>
<div id="carousel">
<img src="http://ryrych.pl/rcarousel/examples/images/001.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/002.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/003.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/004.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/005.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/006.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/007.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/008.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/009.jpg" />
<img src="http://ryrych.pl/rcarousel/examples/images/010.jpg" />
</div>
<script type="text/javascript" src="https://code.jquery.com/jquery-1.7.1.js"></script>
<script type="text/javascript" src="https://code.jquery.com/ui/1.8.0/jquery-ui.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
<script type="text/javascript">
(function ($) {
$.widget("ui.rcarousel", {
_create: function() {
var data,
$root = $( this.element ),
_self = this,
options = this.options;
// if options were default there should be no
problem
// check if user set options before init:
$('element').rcarousel({with: "foo", visible: 3});
// in above example exception will be thrown
because 'with' should be a number!
this._checkOptionsValidity( this.options );
// for every carousel create a data object and
keeps it in the element
this._createDataObject();
data = $root.data( "data" );
// create wrapper inside root element; this is
needed for animating
$root
.addClass( "ui-carousel" )
.children()
.wrapAll( "<div
class='wrapper'></div>" );
// save all children of root element in paths array
this._saveElements();
// make pages using paginate algorithm
this._generatePages();
this._loadElements();
this._setCarouselWidth();
this._setCarouselHeight();
// handle default event handlers
$( options.navigation.next ).click(
function( event ) {
_self.next();
event.preventDefault();
}
);
$( options.navigation.prev ).click(
function( event ) {
_self.prev();
event.preventDefault();
}
);
data.navigation.next = $( options.navigation.next
);
data.navigation.prev = $( options.navigation.prev
);
// stop on hover feature
$root.hover(
function() {
if ( options.auto.enabled
) {
clearInterval( data.interval );
data.hoveredOver = true;
}
},
function() {
if ( options.auto.enabled
) {
data.hoveredOver = false;
_self._autoMode( options.auto.direction );
}
}
);
this._setStep();
// if auto mode is enabled run it
if ( options.auto.enabled
) {
this._autoMode( options.auto.direction );
}
// broadcast event
this._trigger( "start" );
},
_addElement: function( jQueryElement, direction ) {
var $root = $( this.element ),
$content = $root.find( "div.wrapper" ),
options = this.options;
jQueryElement
.width( options.width
)
.height( options.height
);
if ( options.orientation
=== "horizontal" ) {
$( jQueryElement ).css( "marginRight", options.margin );
} else {
$( jQueryElement ).css({
marginBottom: options.margin,
"float": "none"
});
}
if ( direction ===
"prev" ) {
// clone event handlers and data as well
$content.prepend( jQueryElement.clone(true, true) );
} else {
$content.append( jQueryElement.clone(true, true) );
}
},
append: function( jqElements ) {
var $root = $( this.element ),
data = $root.data( "data" );
// add new elements
jqElements.each(
function( i, el ) {
data.paths.push( $(el) );
}
);
data.oldPage = data.pages[data.oldPageIndex].slice(0);
data.appended = true;
// rebuild pages
this._generatePages();
},
_autoMode: function( direction ) {
var options = this.options,
data = $( this.element ).data(
"data" );
if ( direction ===
"next" ) {
data.interval = setTimeout( $.proxy(this.next,
this), options.auto.interval );
} else {
data.interval = setTimeout( $.proxy(this.prev,
this), options.auto.interval );
}
},
_checkOptionsValidity: function( options ) {
var i,
self = this,
_correctSteps = "";
// for every element in options object check its
validity
$.each(options,
function( key, value ) {
switch ( key ) {
case "visible":
// visible should be a positive integer
if ( !value
|| typeof value !== "number" || value <= 0 || (Math.ceil(value) - value >
0) ) {
throw new Error( "visible
should be defined as a positive integer" );
}
break;
case "step":
if ( !value
|| typeof value !== "number" || value <= 0 || (Math.ceil(value) - value >
0) ) {
throw new Error( "step
should be defined as a positive integer" );
} else if ( value >
self.options.visible ) {
// for example for visible: 3 the following array
of values for 'step' is valid
// 3 <= step >= 1 by 1 ==> [1,2,3]
// output correct values
for ( i = 1; i <= Math.floor(options.visible); i++ )
{
_correctSteps += ( i < Math.floor(value)
) ? i + ", " : i;
}
throw new Error( "Only
following step values are correct: " + _correctSteps
);
}
break;
case "width":
// width & height is defined by default so you
can omit them to some extent
if ( !value
|| typeof value !== "number" || value <= 0 || Math.ceil(value) - value > 0 ) {
throw new Error( "width
should be defined as a positive integer" );
}
break;
case "height":
if ( !value
|| typeof value !== "number" || value <= 0 || Math.ceil(value) - value > 0 ) {
throw new Error("height
should be defined as a positive integer");
}
break;
case "speed":
if ( !value
&& value !== 0 ) {
throw new Error("speed
should be defined as a number or a string");
}
if ( typeof value === "number" && value < 0 ) {
throw new Error( "speed
should be a positive number" );
} else if ( typeof value === "string" && !(value === "slow" || value === "normal" || value === "fast") ) {
throw new Error( 'Only
"slow", "normal" and "fast" values are valid' );
}
break;
case "navigation":
if ( !value
|| $.isPlainObject(value) === false ) {
throw new Error( "navigation
should be defined as an object with at least one of the properties: 'prev' or
'next' in it");
}
if ( value.prev &&
typeof value.prev !==
"string" ) {
throw new Error( "navigation.prev
should be defined as a string and point to '.class' or '#id' of an
element" );
}
if ( value.next &&
typeof value.next !==
"string" ) {
throw new Error("
navigation.next should be defined as a string and point to '.class' or '#id' of
an element" );
}
break;
case "auto":
if ( typeof value.direction !== "string" ) {
throw new Error( "direction
should be defined as a string" );
}
if ( !(value.direction
=== "next" || value.direction
=== "prev") ) {
throw new Error( "direction:
only 'right' and 'left' values are valid" );
}
if ( isNaN(value.interval)
|| typeof value.interval !==
"number" || value.interval < 0 || Math.ceil(value.interval) - value.interval
> 0 ) {
throw new Error( "interval
should be a positive number" );
}
break;
case "margin":
if ( isNaN(value)
|| typeof value !== "number" || value < 0 || Math.ceil(value) - value > 0 ) {
throw new Error( "margin
should be a positive number" );
}
break;
}
}
);
},
_createDataObject: function() {
var $root = $( this.element );
$root.data("data",
{
paths: [],
pathsLen: 0,
pages: [],
lastPage: [],
oldPageIndex: 0,
pageIndex: 0,
navigation: {},
animated: false,
appended: false,
hoveredOver: false
}
);
},
_generatePages: function() {
var self = this,
options = this.options,
data = $( this.element ).data(
"data" ),
_visible = options.visible,
_pathsLen = data.paths.length;
// having 10 elements: A, B, C, D, E, F, G, H, I, J
the algorithm
// creates 3 pages for visible: 5 and step: 4:
// [ABCDE], [EFGHI], [FGHIJ]
function _init() {
// init creates the last page [FGHIJ] and remembers
it
data.pages = [];
data.lastPage = [];
data.pages[0] = [];
// init last page
for ( var i = _pathsLen - 1; i >= _pathsLen - _visible;
i-- ) {
data.lastPage.unshift( data.paths[i]
);
}
// and first page
for ( var i = 0; i < _visible; i++ ) {
data.pages[0][data.pages[0].length] = data.paths[i];
}
}
function _islastPage( page ) {
var _isLast = false;
for ( var i = 0; i < data.lastPage.length; i++ ) {
if ( data.lastPage[i].get(0) === page[i].get(0) ) {
_isLast = true;
} else {
_isLast = false;
break;
}
}
return _isLast;
}
function _append( start, end, atIndex ) {
var _index = atIndex || data.pages.length;
if ( !atIndex
) {
data.pages[_index] = [];
}
for ( var i = start; i < end; i++ ) {
data.pages[_index].push( data.paths[i]
);
}
return _index;
}
function _paginate() {
var _isBeginning = true,
_complement = false,
_start = options.step,
_end, _index, _oldFirstEl, _oldLastEl;
// continue until you reach the last page
// we start from the 2nd page (1st page has been
already initiated)
while ( !_islastPage(data.pages[data.pages.length
- 1]) || _isBeginning ) {
_isBeginning = false;
_end = _start + _visible;
// we cannot exceed _pathsLen
if ( _end >
_pathsLen ) {
_end = _pathsLen;
}
// when we run ouf of elements (_end - _start <
_visible) we must add the difference at the begining
// in our example the 3rd page is [FGHIJ] and J
element is added in the second step
// first we add [FGHI] as old elements
// we must assure that we have always visible (5 in
our example) elements
if ( _end -
_start < _visible ) {
_complement = true;
} else {
_complement = false;
}
if ( _complement
) {
// first add old elemets; for 3rd page it adds
[FGHI]
// remember the page we add to (_index)
_oldFirstEl = _start - ( _visible
- (_end - _start) );
_oldLastEl = _oldFirstEl + ( _visible
- (_end - _start) );
_index = _append( _oldFirstEl,
_oldLastEl );
// then add new elements; for 3th page it is J
element:
// [fghiJ]
_append( _start, _end, _index );
} else {
// normal pages like [ABCDE], [EFGHI]
_append( _start, _end );
// next step
_start += options.step;
}
}
}
// go!
_init();
_paginate();
},
getCurrentPage: function() {
var data = $( this.element ).data( "data" );
return data.pageIndex + 1;
},
getTotalPages: function() {
var data = $( this.element ).data( "data" );
return data.pages.length;
},
goToPage: function( page ) {
var _by,
data = $( this.element ).data(
"data" );
if ( !data.animated
&& page !== data.pageIndex ) {
data.animated = true;
if ( page >
data.pages.length - 1 ) {
page = data.pages.length - 1;
} else if ( page <
0 ) {
page = 0;
}
data.pageIndex = page;
_by = page - data.oldPageIndex;
if ( _by >=
0 ) {
//move by n elements from current index
this._goToNextPage( _by );
} else {
this._goToPrevPage( _by );
}
data.oldPageIndex = page;
}
},
_loadElements: function(elements, direction) {
var options = this.options,
data = $( this.element ).data(
"data" ),
_dir = direction || "next",
_elem = elements || data.pages[options.startAtPage],
_start = 0,
_end = _elem.length;
if ( _dir ===
"next" ) {
for ( var i = _start; i < _end; i++ )
{
this._addElement( _elem[i], _dir
);
}
} else {
for ( var i = _end - 1; i >= _start; i-- ) {
this._addElement( _elem[i], _dir
);
}
}
},
_goToPrevPage: function( by ) {
var _page, _oldPage, _dist, _index, _animOpts,
$lastEl, _unique, _pos, _theSame,
$root = $( this.element ),
self = this,
options = this.options,
data = $( this.element ).data(
"data" );
// pick pages
if ( data.appended
) {
_oldPage = data.oldPage;
} else {
_oldPage = data.pages[data.oldPageIndex];
}
_index = data.oldPageIndex + by;
_page = data.pages[_index].slice(
0 );
// For example, the first time widget was initiated
there were 5
// elements: A, B, C, D, E and 3 pages for visible
2 and step 2:
// AB, CD, DE. Then a user loaded next 5 elements
so there were
// 10 already: A, B, C, D, E, F, G, H, I, J and 5
pages:
// AB, CD, EF, GH and IJ. If the other elemets were
loaded when
// CD page was shown (from 5 elements) _theSame is
true because
// we compare the same
// pages, that is, the 2nd page from 5 elements and
the 2nd from
// 10 elements. Thus what we do next is to
decrement the index and
// loads the first page from 10 elements.
$( _page ).each(
function( i, el ) {
if ( el.get(0) === $(_oldPage[i]).get(0) ) {
_theSame = true;
} else {
_theSame = false;
}
}
);
if ( data.appended
&& _theSame ) {
if ( data.pageIndex
=== 0 ) {
_index = data.pageIndex = data.pages.length
- 1;
} else {
_index = --data.pageIndex;
}
_page = data.pages[_index].slice(
0 );
}
// check if last element from _page appears in
_oldPage
// for [ABCDFGHIJ] elements there are 3 pages for
visible = 6 and
// step = 2: [ABCDEF], [CDEFGH] and [EFGHIJ]; going
from the 3rd
// to the 2nd page we only loads 2 elements: [CD]
because all
// remaining were loaded already
$lastEl = _page[_page.length -
1].get( 0 );
for ( var i = _oldPage.length - 1; i >= 0; i-- ) {
if ( $lastEl ===
$(_oldPage[i]).get(0) ) {
_unique = false;
_pos = i;
break;
} else {
_unique = true;
}
}
if ( !_unique
) {
while ( _pos >= 0 ) {
if ( _page[_page.length
- 1].get(0) === _oldPage[_pos].get(0) ) {
// this element is unique
_page.pop();
}
--_pos;
}
}
// load new elements
self._loadElements( _page, "prev" );
// calculate the distance
_dist = options.width * _page.length +
( options.margin * _page.length );
if (options.orientation
=== "horizontal") {
_animOpts = {scrollLeft: 0};
$root.scrollLeft( _dist );
} else {
_animOpts = {scrollTop: 0};
$root.scrollTop( _dist );
}
$root
.animate(_animOpts,
options.speed, function () {
self._removeOldElements( "last", _page.length );
data.animated = false;
if ( !data.hoveredOver
&& options.auto.enabled ) {
// if autoMode is on and you change page manually
clearInterval( data.interval );
self._autoMode( options.auto.direction );
}
// scrolling is finished, send an event
self._trigger("pageLoaded", null, {page: _index});
});
// reset to deafult
data.appended = false;
},
_goToNextPage: function( by ) {
var _page, _oldPage, _dist, _index, _animOpts,
$firstEl, _unique, _pos, _theSame,
$root = $( this.element ),
options = this.options,
data = $root.data( "data" ),
self = this;
// pick pages
if ( data.appended
) {
_oldPage = data.oldPage;
} else {
_oldPage = data.pages[data.oldPageIndex];
}
_index = data.oldPageIndex + by;
_page = data.pages[_index].slice(
0 );
// For example, the first time widget was initiated
there were 5
// elements: A, B, C, D, E and 2 pages for visible
4 and step 3:
// ABCD and BCDE. Then a user loaded next 5
elements so there were
// 10 already: A, B, C, D, E, F, G, H, I, J and 3
pages:
// ABCD, DEFG and GHIJ. If the other elemets were
loaded when
// ABCD page was shown (from 5 elements) _theSame
is true because
// we compare the same
// pages, that is, the first pages from 5 elements
and the first from
// 10 elements. Thus what we do next is to
increment the index and
// loads the second page from 10 elements.
$( _page ).each(
function( i, el ) {
if ( el.get(0) === $(_oldPage[i]).get(0) ) {
_theSame = true;
} else {
_theSame = false;
}
}
);
if ( data.appended
&& _theSame ) {
_page = data.pages[++data.pageIndex].slice(
0 );
}
// check if 1st element from _page appears in
_oldPage
// for [ABCDFGHIJ] elements there are 3 pages for
visible = 6 and
// step = 2: [ABCDEF], [CDEFGH] and [EFGHIJ]; going
from the 2nd
// to the 3rd page we only loads 2 elements: [IJ]
because all
// remaining were loaded already
$firstEl = _page[0].get( 0 );
for ( var i = 0; i < _page.length; i++) {
if ( $firstEl ===
$(_oldPage[i]).get(0) ) {
_unique = false;
_pos = i;
break;
} else {
_unique = true;
}
}
if ( !_unique
) {
while ( _pos < _oldPage.length ) {
if ( _page[0].get(0) === _oldPage[_pos].get(0) ) {
_page.shift();
}
++_pos;
}
}
// load new elements
this._loadElements( _page, "next" );
// calculate the distance
_dist = options.width * _page.length +
( options.margin * _page.length );
if ( options.orientation
=== "horizontal" ) {
_animOpts = {scrollLeft: "+=" + _dist};
} else {
_animOpts = {scrollTop: "+=" + _dist};
}
$root
.animate(_animOpts,
options.speed, function() {
self._removeOldElements( "first", _page.length );
if ( options.orientation
=== "horizontal" ) {
$root.scrollLeft( 0 );
} else {
$root.scrollTop( 0 );
}
data.animated = false;
if ( !data.hoveredOver
&& options.auto.enabled ) {
// if autoMode is on and you change page manually
clearInterval( data.interval );
self._autoMode( options.auto.direction );
}
// scrolling is finished, send an event
self._trigger( "pageLoaded", null, {page: _index});
});
// reset to deafult
data.appended = false;
},
next: function() {
var options = this.options,
data = $( this.element ).data(
"data" );
if ( !data.animated
) {
data.animated = true;
if ( !data.appended ) {
++data.pageIndex;
}
if ( data.pageIndex
> data.pages.length - 1 ) {
data.pageIndex = 0;
}
// move by one element from current index
this._goToNextPage( data.pageIndex - data.oldPageIndex
);
data.oldPageIndex = data.pageIndex;
}
},
prev: function() {
var options = this.options,
data = $( this.element ).data(
"data" );
if ( !data.animated
) {
data.animated = true;
if ( !data.appended
) {
--data.pageIndex;
}
if ( data.pageIndex
< 0 ) {
data.pageIndex = data.pages.length - 1;
}
// move left by one element from current index
this._goToPrevPage( data.pageIndex - data.oldPageIndex
);
data.oldPageIndex = data.pageIndex;
}
},
_removeOldElements: function(position, length) {
// remove 'step' elements
var $root = $( this.element );
for ( var i = 0; i < length; i++ ) {
if ( position ===
"first" ) {
$root
.find( "div.wrapper" )
.children()
.first()
.remove();
} else {
$root
.find( "div.wrapper" )
.children()
.last()
.remove();
}
}
},
_saveElements: function() {
var $el,
$root = $( this.element ),
$elements = $root.find( "div.wrapper" ).children(),
data = $root.data( "data" );
$elements.each(
function( i, el ) {
$el = $( el );
// keep elements data and events
data.paths.push( $el.clone(true, true) );
$el.remove();
}
);
},
_setOption: function( key, value ) {
var _newOptions,
options = this.options,
data = $( this.element ).data(
"data" );
switch (key) {
case "speed":
this._checkOptionsValidity({speed: value});
options.speed = value;
$.Widget.prototype._setOption.apply( this, arguments );
break;
case "auto":
_newOptions = $.extend( options.auto,
value );
this._checkOptionsValidity({auto: _newOptions});
if ( options.auto.enabled
) {
this._autoMode( options.auto.direction );
}
}
},
_setStep: function(s) {
// calculate a step
var _step,
options = this.options,
data = $( this.element ).data(
"data" );
_step = s || options.step;
options.step = _step;
data.step = options.width * _step;
},
_setCarouselHeight: function() {
var _newHeight,
$root = $( this.element ),
data = $( this.element ).data(
"data" ),
options = this.options;
if ( options.orientation
=== "vertical" ) {
_newHeight = options.visible * options.height
+ options.margin * (options.visible - 1);
} else {
_newHeight = options.height;
}
$root.height(_newHeight);
},
_setCarouselWidth: function() {
var _newWidth,
$root = $( this.element ),
options = this.options,
data = $( this.element ).data(
"data" );
if ( options.orientation
=== "horizontal" ) {
_newWidth = options.visible * options.width
+ options.margin * (options.visible - 1);
} else {
_newWidth = options.width;
}
// set carousel width and disable overflow: auto
$root.css({
width: _newWidth,
overflow: "hidden"
});
},
options: {
visible: 3,
step: 3,
width: 100,
height: 100,
speed: 1000,
margin: 0,
orientation: "horizontal",
auto: {
enabled: false,
direction: "next",
interval: 5000
},
startAtPage: 0,
navigation: {
next: "#ui-carousel-next",
prev: "#ui-carousel-prev"
}
}
});
}(jQuery));
</script>
<script type="text/javascript">
jQuery(function($) {
$("#carousel").rcarousel({
auto: {enabled: true}
});
});
</script>
</body>
</html>
AUTO OWL CAROUSEL SLIDER CODE
----------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Owl Carousel - Images
Demo</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="jQuery Responsive Carousel - Owl Carusel">
<meta name="author" content="Bartosz Wojciechowski">
<!-- Owl Carousel Assets -->
<link href="https://cdnjs.cloudflare.com/ajax/libs/owl-carousel/1.3.3/owl.carousel.css" rel="stylesheet">
<link href="https://cdnjs.cloudflare.com/ajax/libs/owl-carousel/1.3.3/owl.theme.css" rel="stylesheet">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/owl-carousel/1.3.3/owl.carousel.js"></script>
<!-- Demo -->
<style>
#owl-demo .item{
margin: 3px;
}
#owl-demo .item img{
display: block;
width: 100%;
height: auto;
}
</style>
<script>
$(document).ready(function() {
$("#owl-demo").owlCarousel({
autoPlay: 3000,
items : 4,
itemsDesktop : [1199,3],
itemsDesktopSmall : [979,3]
});
});
</script>
<!-- Prettify -->
</head>
<body>
<div id="owl-demo" class="owl-carousel">
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl1.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl2.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl3.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl4.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl5.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl6.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl7.jpg" alt="Owl
Image"></div>
<div class="item"><img src="https://raw.githubusercontent.com/OwlFonk/OwlCarousel/master/demos/assets/owl8.jpg" alt="Owl
Image"></div>
</div>
</body>
</html>
-----------------------------------------------------------------------------------------------------------JATINDER CSS SLIDER CODE YOUTUBE
-----------------------------------------------------------------------------------------------------------
<!DOCTYPE html>
<!-- https://www.youtube.com/watch?v=xVaW-e_eOPs&t=115s -->
<!-- http://stackoverflow.com/questions/40204345/moving-a-slide-show-to-the-left-in-html -->
<html>
<head>
<style>
#outerbox{
}
#sliderbox{
position:relative;
width:2800px;
animation-name:jatinder;
animation-duration: 2s;
}
#sliderbox img{
float:left;
border-color:#0000FF;
border-style:solid;
}
@keyframes jatinder{
0%{
left:0px;
}
20%{
left:0px;
}
25%{
left:-700px;
}
45%{
left:-700px;
}
50%{
left:-1400px;
}
70%{
left:-1400px;
}
75%{
left:-2100px;
}
100%{
left:-2800px;
}
}
</style>
</head>
<body>
<div id="outerbox">
<div id="sliderbox">
<img src="http://fo.demo.prestashop.com/1-home_default/faded-short-sleeves-tshirt.jpg"/>
<img src="http://fo.demo.prestashop.com/7-home_default/blouse.jpg"/>
<img src="http://fo.demo.prestashop.com/8-home_default/printed-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/10-home_default/printed-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/12-home_default/printed-summer-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/16-home_default/printed-summer-dress.jpg"/>
<img src="http://fo.demo.prestashop.com/20-home_default/printed-chiffon-dress.jpg"/>
</body>
</html>
WORDPRESS OWL CAROUSEL
<!DOCTYPE html>
<!-- https://www.magentocommerce.com/magento-connect/new-products-2.html -->
<!-- http://demo.magehit.com/demo01/ -->
<html>
<head>
<body>
<link rel="stylesheet" type="text/css" href="http://demo.magehit.com/demo01/skin/frontend/base/default/magehit_newproducts/css/owl.carousel.css" media="all" />
<link rel="stylesheet" type="text/css" href="http://demo.magehit.com/demo01/skin/frontend/base/default/magehit_newproducts/css/owl.theme.css" media="all" />
<script type="text/javascript" src="http://demo.magehit.com/demo01/skin/frontend/base/default/magehit_newproducts/js/jquery-1.10.2.min.js"></script>
<script type="text/javascript" src="http://demo.magehit.com/demo01/skin/frontend/base/default/magehit_newproducts/js/noconflict.js"></script>
<script type="text/javascript" src="http://demo.magehit.com/demo01/skin/frontend/base/default/magehit_newproducts/js/owl.carousel.js"></script>
<div id="owl-newproducts" class="owl-carousel">
<img class="lazyOwl" data-src="http://demo.magehit.com/demo01/media/catalog/product/cache/1/small_image/260x/9df78eab33525d08d6e5fb8d27136e95/m/s/msj012t_2.jpg" alt="Linen Blazer" title="Linen Blazer" />
<img class="lazyOwl" data-src="http://demo.magehit.com/demo01/media/catalog/product/cache/1/small_image/260x/9df78eab33525d08d6e5fb8d27136e95/w/b/wbk012t.jpg" alt="Elizabeth Knit Top" title="Elizabeth Knit Top" />
<img class="lazyOwl" data-src="http://demo.magehit.com/demo01/media/catalog/product/cache/1/small_image/260x/9df78eab33525d08d6e5fb8d27136e95/m/t/mtk004t.jpg" alt="Chelsea Tee" title="Chelsea Tee" />
<img class="lazyOwl" data-src="http://demo.magehit.com/demo01/media/catalog/product/cache/1/small_image/260x/9df78eab33525d08d6e5fb8d27136e95/w/s/wsd013t.jpg" alt="Lafayette Convertible Dress" title="Lafayette Convertible Dress" />
<img class="lazyOwl" data-src="http://demo.magehit.com/demo01/media/catalog/product/cache/1/small_image/260x/9df78eab33525d08d6e5fb8d27136e95/w/b/wbk003t.jpg" alt="Tori Tank" title="Tori Tank" />
<script type="text/javascript">
var $fp = jQuery.noConflict();
$fp(document).ready(function() {
$fp("#owl-newproducts").owlCarousel({
items : 4,
lazyLoad : true,
autoPlay : true,
navigation : true });
});
</script>
</div>
</body>
</html>
--------------------------------------------------------------------------------------------------------------------
<script src='http://bxslider.com/lib/jquery.bxslider.js'></script>
<script src='http://bxslider.com/lib/jquery.bxslider.js'></script>
--------------------------------------------------------------------------------------------------------------------
/**
* BxSlider v4.1.2 - Fully loaded, responsive content slider
* http://bxslider.com
*
* Copyright 2014, Steven Wanderski - http://stevenwanderski.com - http://bxcreative.com
* Written while drinking Belgian ales and listening to jazz
*
* Released under the MIT license - http://opensource.org/licenses/MIT
*/
;(function($){
var plugin = {};
var defaults = {
// GENERAL
mode: 'horizontal',
slideSelector: '',
infiniteLoop: true,
hideControlOnEnd: false,
speed: 500,
easing: null,
slideMargin: 0,
startSlide: 0,
randomStart: false,
captions: false,
ticker: false,
tickerHover: false,
adaptiveHeight: false,
adaptiveHeightSpeed: 500,
video: false,
useCSS: true,
preloadImages: 'visible',
responsive: true,
slideZIndex: 50,
wrapperClass: 'bx-wrapper',
// TOUCH
touchEnabled: true,
swipeThreshold: 50,
oneToOneTouch: true,
preventDefaultSwipeX: true,
preventDefaultSwipeY: false,
// PAGER
pager: true,
pagerType: 'full',
pagerShortSeparator: ' / ',
pagerSelector: null,
buildPager: null,
pagerCustom: null,
// CONTROLS
controls: true,
nextText: 'Next',
prevText: 'Prev',
nextSelector: null,
prevSelector: null,
autoControls: false,
startText: 'Start',
stopText: 'Stop',
autoControlsCombine: false,
autoControlsSelector: null,
// AUTO
auto: false,
pause: 4000,
autoStart: true,
autoDirection: 'next',
autoHover: false,
autoDelay: 0,
autoSlideForOnePage: false,
// CAROUSEL
minSlides: 1,
maxSlides: 1,
moveSlides: 0,
slideWidth: 0,
// CALLBACKS
onSliderLoad: function() {},
onSlideBefore: function() {},
onSlideAfter: function() {},
onSlideNext: function() {},
onSlidePrev: function() {},
onSliderResize: function() {}
}
$.fn.bxSlider = function(options){
if(this.length == 0) return this;
// support mutltiple elements
if(this.length > 1){
this.each(function(){$(this).bxSlider(options)});
return this;
}
// create a namespace to be used throughout the plugin
var slider = {};
// set a reference to our slider element
var el = this;
plugin.el = this;
/**
* Makes slideshow responsive
*/
// first get the original window dimens (thanks alot IE)
var windowWidth = $(window).width();
var windowHeight = $(window).height();
/**
* ===================================================================================
* = PRIVATE FUNCTIONS
* ===================================================================================
*/
/**
* Initializes namespace settings to be used throughout plugin
*/
var init = function(){
// merge user-supplied options with the defaults
slider.settings = $.extend({}, defaults, options);
// parse slideWidth setting
slider.settings.slideWidth = parseInt(slider.settings.slideWidth);
// store the original children
slider.children = el.children(slider.settings.slideSelector);
// check if actual number of slides is less than minSlides / maxSlides
if(slider.children.length < slider.settings.minSlides) slider.settings.minSlides = slider.children.length;
if(slider.children.length < slider.settings.maxSlides) slider.settings.maxSlides = slider.children.length;
// if random start, set the startSlide setting to random number
if(slider.settings.randomStart) slider.settings.startSlide = Math.floor(Math.random() * slider.children.length);
// store active slide information
slider.active = { index: slider.settings.startSlide }
// store if the slider is in carousel mode (displaying / moving multiple slides)
slider.carousel = slider.settings.minSlides > 1 || slider.settings.maxSlides > 1;
// if carousel, force preloadImages = 'all'
if(slider.carousel) slider.settings.preloadImages = 'all';
// calculate the min / max width thresholds based on min / max number of slides
// used to setup and update carousel slides dimensions
slider.minThreshold = (slider.settings.minSlides * slider.settings.slideWidth) + ((slider.settings.minSlides - 1) * slider.settings.slideMargin);
slider.maxThreshold = (slider.settings.maxSlides * slider.settings.slideWidth) + ((slider.settings.maxSlides - 1) * slider.settings.slideMargin);
// store the current state of the slider (if currently animating, working is true)
slider.working = false;
// initialize the controls object
slider.controls = {};
// initialize an auto interval
slider.interval = null;
// determine which property to use for transitions
slider.animProp = slider.settings.mode == 'vertical' ? 'top' : 'left';
// determine if hardware acceleration can be used
slider.usingCSS = slider.settings.useCSS && slider.settings.mode != 'fade' && (function(){
// create our test div element
var div = document.createElement('div');
// css transition properties
var props = ['WebkitPerspective', 'MozPerspective', 'OPerspective', 'msPerspective'];
// test for each property
for(var i in props){
if(div.style[props[i]] !== undefined){
slider.cssPrefix = props[i].replace('Perspective', '').toLowerCase();
slider.animProp = '-' + slider.cssPrefix + '-transform';
return true;
}
}
return false;
}());
// if vertical mode always make maxSlides and minSlides equal
if(slider.settings.mode == 'vertical') slider.settings.maxSlides = slider.settings.minSlides;
// save original style data
el.data("origStyle", el.attr("style"));
el.children(slider.settings.slideSelector).each(function() {
$(this).data("origStyle", $(this).attr("style"));
});
// perform all DOM / CSS modifications
setup();
}
/**
* Performs all DOM and CSS modifications
*/
var setup = function(){
// wrap el in a wrapper
el.wrap('
');
// store a namspace reference to .bx-viewport
slider.viewport = el.parent();
// add a loading div to display while images are loading
slider.loader = $('
');
slider.viewport.prepend(slider.loader);
// set el to a massive width, to hold any needed slides
// also strip any margin and padding from el
el.css({
width: slider.settings.mode == 'horizontal' ? (slider.children.length * 100 + 215) + '%' : 'auto',
position: 'relative'
});
// if using CSS, add the easing property
if(slider.usingCSS && slider.settings.easing){
el.css('-' + slider.cssPrefix + '-transition-timing-function', slider.settings.easing);
// if not using CSS and no easing value was supplied, use the default JS animation easing (swing)
}else if(!slider.settings.easing){
slider.settings.easing = 'swing';
}
var slidesShowing = getNumberSlidesShowing();
// make modifications to the viewport (.bx-viewport)
slider.viewport.css({
width: '100%',
overflow: 'hidden',
position: 'relative'
});
slider.viewport.parent().css({
maxWidth: getViewportMaxWidth()
});
// make modification to the wrapper (.bx-wrapper)
if(!slider.settings.pager) {
slider.viewport.parent().css({
margin: '0 auto 0px'
});
}
// apply css to all slider children
slider.children.css({
'float': slider.settings.mode == 'horizontal' ? 'left' : 'none',
listStyle: 'none',
position: 'relative'
});
// apply the calculated width after the float is applied to prevent scrollbar interference
slider.children.css('width', getSlideWidth());
// if slideMargin is supplied, add the css
if(slider.settings.mode == 'horizontal' && slider.settings.slideMargin > 0) slider.children.css('marginRight', slider.settings.slideMargin);
if(slider.settings.mode == 'vertical' && slider.settings.slideMargin > 0) slider.children.css('marginBottom', slider.settings.slideMargin);
// if "fade" mode, add positioning and z-index CSS
if(slider.settings.mode == 'fade'){
slider.children.css({
position: 'absolute',
zIndex: 0,
display: 'none'
});
// prepare the z-index on the showing element
slider.children.eq(slider.settings.startSlide).css({zIndex: slider.settings.slideZIndex, display: 'block'});
}
// create an element to contain all slider controls (pager, start / stop, etc)
slider.controls.el = $('
');
// if captions are requested, add them
if(slider.settings.captions) appendCaptions();
// check if startSlide is last slide
slider.active.last = slider.settings.startSlide == getPagerQty() - 1;
// if video is true, set up the fitVids plugin
if(slider.settings.video) el.fitVids();
// set the default preload selector (visible)
var preloadSelector = slider.children.eq(slider.settings.startSlide);
if (slider.settings.preloadImages == "all") preloadSelector = slider.children;
// only check for control addition if not in "ticker" mode
if(!slider.settings.ticker){
// if pager is requested, add it
if(slider.settings.pager) appendPager();
// if controls are requested, add them
if(slider.settings.controls) appendControls();
// if auto is true, and auto controls are requested, add them
if(slider.settings.auto && slider.settings.autoControls) appendControlsAuto();
// if any control option is requested, add the controls wrapper
if(slider.settings.controls || slider.settings.autoControls || slider.settings.pager) slider.viewport.after(slider.controls.el);
// if ticker mode, do not allow a pager
}else{
slider.settings.pager = false;
}
// preload all images, then perform final DOM / CSS modifications that depend on images being loaded
loadElements(preloadSelector, start);
}
var loadElements = function(selector, callback){
var total = selector.find('img, iframe').length;
if (total == 0){
callback();
return;
}
var count = 0;
selector.find('img, iframe').each(function(){
$(this).one('load', function() {
if(++count == total) callback();
}).each(function() {
if(this.complete) $(this).load();
});
});
}
/**
* Start the slider
*/
var start = function(){
// if infinite loop, prepare additional slides
if(slider.settings.infiniteLoop && slider.settings.mode != 'fade' && !slider.settings.ticker){
var slice = slider.settings.mode == 'vertical' ? slider.settings.minSlides : slider.settings.maxSlides;
var sliceAppend = slider.children.slice(0, slice).clone().addClass('bx-clone');
var slicePrepend = slider.children.slice(-slice).clone().addClass('bx-clone');
el.append(sliceAppend).prepend(slicePrepend);
}
// remove the loading DOM element
slider.loader.remove();
// set the left / top position of "el"
setSlidePosition();
// if "vertical" mode, always use adaptiveHeight to prevent odd behavior
if (slider.settings.mode == 'vertical') slider.settings.adaptiveHeight = true;
// set the viewport height
slider.viewport.height(getViewportHeight());
// make sure everything is positioned just right (same as a window resize)
el.redrawSlider();
// onSliderLoad callback
slider.settings.onSliderLoad(slider.active.index);
// slider has been fully initialized
slider.initialized = true;
// bind the resize call to the window
if (slider.settings.responsive) $(window).bind('resize', resizeWindow);
// if auto is true and has more than 1 page, start the show
if (slider.settings.auto && slider.settings.autoStart && (getPagerQty() > 1 || slider.settings.autoSlideForOnePage)) initAuto();
// if ticker is true, start the ticker
if (slider.settings.ticker) initTicker();
// if pager is requested, make the appropriate pager link active
if (slider.settings.pager) updatePagerActive(slider.settings.startSlide);
// check for any updates to the controls (like hideControlOnEnd updates)
if (slider.settings.controls) updateDirectionControls();
// if touchEnabled is true, setup the touch events
if (slider.settings.touchEnabled && !slider.settings.ticker) initTouch();
}
/**
* Returns the calculated height of the viewport, used to determine either adaptiveHeight or the maxHeight value
*/
var getViewportHeight = function(){
var height = 0;
// first determine which children (slides) should be used in our height calculation
var children = $();
// if mode is not "vertical" and adaptiveHeight is false, include all children
if(slider.settings.mode != 'vertical' && !slider.settings.adaptiveHeight){
children = slider.children;
}else{
// if not carousel, return the single active child
if(!slider.carousel){
children = slider.children.eq(slider.active.index);
// if carousel, return a slice of children
}else{
// get the individual slide index
var currentIndex = slider.settings.moveSlides == 1 ? slider.active.index : slider.active.index * getMoveBy();
// add the current slide to the children
children = slider.children.eq(currentIndex);
// cycle through the remaining "showing" slides
for (i = 1; i <= slider.settings.maxSlides - 1; i++){
// if looped back to the start
if(currentIndex + i >= slider.children.length){
children = children.add(slider.children.eq(i - 1));
}else{
children = children.add(slider.children.eq(currentIndex + i));
}
}
}
}
// if "vertical" mode, calculate the sum of the heights of the children
if(slider.settings.mode == 'vertical'){
children.each(function(index) {
height += $(this).outerHeight();
});
// add user-supplied margins
if(slider.settings.slideMargin > 0){
height += slider.settings.slideMargin * (slider.settings.minSlides - 1);
}
// if not "vertical" mode, calculate the max height of the children
}else{
height = Math.max.apply(Math, children.map(function(){
return $(this).outerHeight(false);
}).get());
}
if(slider.viewport.css('box-sizing') == 'border-box'){
height += parseFloat(slider.viewport.css('padding-top')) + parseFloat(slider.viewport.css('padding-bottom')) +
parseFloat(slider.viewport.css('border-top-width')) + parseFloat(slider.viewport.css('border-bottom-width'));
}else if(slider.viewport.css('box-sizing') == 'padding-box'){
height += parseFloat(slider.viewport.css('padding-top')) + parseFloat(slider.viewport.css('padding-bottom'));
}
return height;
}
/**
* Returns the calculated width to be used for the outer wrapper / viewport
*/
var getViewportMaxWidth = function(){
var width = '100%';
if(slider.settings.slideWidth > 0){
if(slider.settings.mode == 'horizontal'){
width = (slider.settings.maxSlides * slider.settings.slideWidth) + ((slider.settings.maxSlides - 1) * slider.settings.slideMargin);
}else{
width = slider.settings.slideWidth;
}
}
return width;
}
/**
* Returns the calculated width to be applied to each slide
*/
var getSlideWidth = function(){
// start with any user-supplied slide width
var newElWidth = slider.settings.slideWidth;
// get the current viewport width
var wrapWidth = slider.viewport.width();
// if slide width was not supplied, or is larger than the viewport use the viewport width
if(slider.settings.slideWidth == 0 ||
(slider.settings.slideWidth > wrapWidth && !slider.carousel) ||
slider.settings.mode == 'vertical'){
newElWidth = wrapWidth;
// if carousel, use the thresholds to determine the width
}else if(slider.settings.maxSlides > 1 && slider.settings.mode == 'horizontal'){
if(wrapWidth > slider.maxThreshold){
// newElWidth = (wrapWidth - (slider.settings.slideMargin * (slider.settings.maxSlides - 1))) / slider.settings.maxSlides;
}else if(wrapWidth < slider.minThreshold){
newElWidth = (wrapWidth - (slider.settings.slideMargin * (slider.settings.minSlides - 1))) / slider.settings.minSlides;
}
}
return newElWidth;
}
/**
* Returns the number of slides currently visible in the viewport (includes partially visible slides)
*/
var getNumberSlidesShowing = function(){
var slidesShowing = 1;
if(slider.settings.mode == 'horizontal' && slider.settings.slideWidth > 0){
// if viewport is smaller than minThreshold, return minSlides
if(slider.viewport.width() < slider.minThreshold){
slidesShowing = slider.settings.minSlides;
// if viewport is larger than minThreshold, return maxSlides
}else if(slider.viewport.width() > slider.maxThreshold){
slidesShowing = slider.settings.maxSlides;
// if viewport is between min / max thresholds, divide viewport width by first child width
}else{
var childWidth = slider.children.first().width() + slider.settings.slideMargin;
slidesShowing = Math.floor((slider.viewport.width() +
slider.settings.slideMargin) / childWidth);
}
// if "vertical" mode, slides showing will always be minSlides
}else if(slider.settings.mode == 'vertical'){
slidesShowing = slider.settings.minSlides;
}
return slidesShowing;
}
/**
* Returns the number of pages (one full viewport of slides is one "page")
*/
var getPagerQty = function(){
var pagerQty = 0;
// if moveSlides is specified by the user
if(slider.settings.moveSlides > 0){
if(slider.settings.infiniteLoop){
pagerQty = Math.ceil(slider.children.length / getMoveBy());
}else{
// use a while loop to determine pages
var breakPoint = 0;
var counter = 0
// when breakpoint goes above children length, counter is the number of pages
while (breakPoint < slider.children.length){
++pagerQty;
breakPoint = counter + getNumberSlidesShowing();
counter += slider.settings.moveSlides <= getNumberSlidesShowing() ? slider.settings.moveSlides : getNumberSlidesShowing();
}
}
// if moveSlides is 0 (auto) divide children length by sides showing, then round up
}else{
pagerQty = Math.ceil(slider.children.length / getNumberSlidesShowing());
}
return pagerQty;
}
/**
* Returns the number of indivual slides by which to shift the slider
*/
var getMoveBy = function(){
// if moveSlides was set by the user and moveSlides is less than number of slides showing
if(slider.settings.moveSlides > 0 && slider.settings.moveSlides <= getNumberSlidesShowing()){
return slider.settings.moveSlides;
}
// if moveSlides is 0 (auto)
return getNumberSlidesShowing();
}
/**
* Sets the slider's (el) left or top position
*/
var setSlidePosition = function(){
// if last slide, not infinite loop, and number of children is larger than specified maxSlides
if(slider.children.length > slider.settings.maxSlides && slider.active.last && !slider.settings.infiniteLoop){
if (slider.settings.mode == 'horizontal'){
// get the last child's position
var lastChild = slider.children.last();
var position = lastChild.position();
// set the left position
setPositionProperty(-(position.left - (slider.viewport.width() - lastChild.outerWidth())), 'reset', 0);
}else if(slider.settings.mode == 'vertical'){
// get the last showing index's position
var lastShowingIndex = slider.children.length - slider.settings.minSlides;
var position = slider.children.eq(lastShowingIndex).position();
// set the top position
setPositionProperty(-position.top, 'reset', 0);
}
// if not last slide
}else{
// get the position of the first showing slide
var position = slider.children.eq(slider.active.index * getMoveBy()).position();
// check for last slide
if (slider.active.index == getPagerQty() - 1) slider.active.last = true;
// set the repective position
if (position != undefined){
if (slider.settings.mode == 'horizontal') setPositionProperty(-position.left, 'reset', 0);
else if (slider.settings.mode == 'vertical') setPositionProperty(-position.top, 'reset', 0);
}
}
}
/**
* Sets the el's animating property position (which in turn will sometimes animate el).
* If using CSS, sets the transform property. If not using CSS, sets the top / left property.
*
* @param value (int)
* - the animating property's value
*
* @param type (string) 'slider', 'reset', 'ticker'
* - the type of instance for which the function is being
*
* @param duration (int)
* - the amount of time (in ms) the transition should occupy
*
* @param params (array) optional
* - an optional parameter containing any variables that need to be passed in
*/
var setPositionProperty = function(value, type, duration, params){
// use CSS transform
if(slider.usingCSS){
// determine the translate3d value
var propValue = slider.settings.mode == 'vertical' ? 'translate3d(0, ' + value + 'px, 0)' : 'translate3d(' + value + 'px, 0, 0)';
// add the CSS transition-duration
el.css('-' + slider.cssPrefix + '-transition-duration', duration / 1000 + 's');
if(type == 'slide'){
// set the property value
el.css(slider.animProp, propValue);
// bind a callback method - executes when CSS transition completes
el.bind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', function(){
// unbind the callback
el.unbind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd');
updateAfterSlideTransition();
});
}else if(type == 'reset'){
el.css(slider.animProp, propValue);
}else if(type == 'ticker'){
// make the transition use 'linear'
el.css('-' + slider.cssPrefix + '-transition-timing-function', 'linear');
el.css(slider.animProp, propValue);
// bind a callback method - executes when CSS transition completes
el.bind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', function(){
// unbind the callback
el.unbind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd');
// reset the position
setPositionProperty(params['resetValue'], 'reset', 0);
// start the loop again
tickerLoop();
});
}
// use JS animate
}else{
var animateObj = {};
animateObj[slider.animProp] = value;
if(type == 'slide'){
el.animate(animateObj, duration, slider.settings.easing, function(){
updateAfterSlideTransition();
});
}else if(type == 'reset'){
el.css(slider.animProp, value)
}else if(type == 'ticker'){
el.animate(animateObj, speed, 'linear', function(){
setPositionProperty(params['resetValue'], 'reset', 0);
// run the recursive loop after animation
tickerLoop();
});
}
}
}
/**
* Populates the pager with proper amount of pages
*/
var populatePager = function(){
var pagerHtml = '';
var pagerQty = getPagerQty();
// loop through each pager item
for(var i=0; i < pagerQty; i++){
var linkContent = '';
// if a buildPager function is supplied, use it to get pager link value, else use index + 1
if(slider.settings.buildPager && $.isFunction(slider.settings.buildPager)){
linkContent = slider.settings.buildPager(i);
slider.pagerEl.addClass('bx-custom-pager');
}else{
linkContent = i + 1;
slider.pagerEl.addClass('bx-default-pager');
}
// var linkContent = slider.settings.buildPager && $.isFunction(slider.settings.buildPager) ? slider.settings.buildPager(i) : i + 1;
// add the markup to the string
pagerHtml += '
'; }; // populate the pager element with pager links slider.pagerEl.html(pagerHtml); } /** * Appends the pager to the controls element */ var appendPager = function(){ if(!slider.settings.pagerCustom){ // create the pager DOM element slider.pagerEl = $('
'; }; // populate the pager element with pager links slider.pagerEl.html(pagerHtml); } /** * Appends the pager to the controls element */ var appendPager = function(){ if(!slider.settings.pagerCustom){ // create the pager DOM element slider.pagerEl = $('
');
// if a pager selector was supplied, populate it with the pager
if(slider.settings.pagerSelector){
$(slider.settings.pagerSelector).html(slider.pagerEl);
// if no pager selector was supplied, add it after the wrapper
}else{
slider.controls.el.addClass('bx-has-pager').append(slider.pagerEl);
}
// populate the pager
populatePager();
}else{
slider.pagerEl = $(slider.settings.pagerCustom);
}
// assign the pager click binding
slider.pagerEl.on('click', 'a', clickPagerBind);
}
/**
* Appends prev / next controls to the controls element
*/
var appendControls = function(){
slider.controls.next = $('' + slider.settings.nextText + '');
slider.controls.prev = $('' + slider.settings.prevText + '');
// bind click actions to the controls
slider.controls.next.bind('click', clickNextBind);
slider.controls.prev.bind('click', clickPrevBind);
// if nextSlector was supplied, populate it
if(slider.settings.nextSelector){
$(slider.settings.nextSelector).append(slider.controls.next);
}
// if prevSlector was supplied, populate it
if(slider.settings.prevSelector){
$(slider.settings.prevSelector).append(slider.controls.prev);
}
// if no custom selectors were supplied
if(!slider.settings.nextSelector && !slider.settings.prevSelector){
// add the controls to the DOM
slider.controls.directionEl = $('
');
// add the control elements to the directionEl
slider.controls.directionEl.append(slider.controls.prev).append(slider.controls.next);
// slider.viewport.append(slider.controls.directionEl);
slider.controls.el.addClass('bx-has-controls-direction').append(slider.controls.directionEl);
}
}
/**
* Appends start / stop auto controls to the controls element
*/
var appendControlsAuto = function(){
slider.controls.start = $('
'); slider.controls.stop = $('
'); // add the controls to the DOM slider.controls.autoEl = $('
'); slider.controls.stop = $('
'); // add the controls to the DOM slider.controls.autoEl = $('
');
// bind click actions to the controls
slider.controls.autoEl.on('click', '.bx-start', clickStartBind);
slider.controls.autoEl.on('click', '.bx-stop', clickStopBind);
// if autoControlsCombine, insert only the "start" control
if(slider.settings.autoControlsCombine){
slider.controls.autoEl.append(slider.controls.start);
// if autoControlsCombine is false, insert both controls
}else{
slider.controls.autoEl.append(slider.controls.start).append(slider.controls.stop);
}
// if auto controls selector was supplied, populate it with the controls
if(slider.settings.autoControlsSelector){
$(slider.settings.autoControlsSelector).html(slider.controls.autoEl);
// if auto controls selector was not supplied, add it after the wrapper
}else{
slider.controls.el.addClass('bx-has-controls-auto').append(slider.controls.autoEl);
}
// update the auto controls
updateAutoControls(slider.settings.autoStart ? 'stop' : 'start');
}
/**
* Appends image captions to the DOM
*/
var appendCaptions = function(){
// cycle through each child
slider.children.each(function(index){
// get the image title attribute
var title = $(this).find('img:first').attr('title');
// append the caption
if (title != undefined && ('' + title).length) {
$(this).append('
'); } }); } /** * Click next binding * * @param e (event) * - DOM event object */ var clickNextBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); el.goToNextSlide(); e.preventDefault(); } /** * Click prev binding * * @param e (event) * - DOM event object */ var clickPrevBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); el.goToPrevSlide(); e.preventDefault(); } /** * Click start binding * * @param e (event) * - DOM event object */ var clickStartBind = function(e){ el.startAuto(); e.preventDefault(); } /** * Click stop binding * * @param e (event) * - DOM event object */ var clickStopBind = function(e){ el.stopAuto(); e.preventDefault(); } /** * Click pager binding * * @param e (event) * - DOM event object */ var clickPagerBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); var pagerLink = $(e.currentTarget); if(pagerLink.attr('data-slide-index') !== undefined){ var pagerIndex = parseInt(pagerLink.attr('data-slide-index')); // if clicked pager link is not active, continue with the goToSlide call if(pagerIndex != slider.active.index) el.goToSlide(pagerIndex); e.preventDefault(); } } /** * Updates the pager links with an active class * * @param slideIndex (int) * - index of slide to make active */ var updatePagerActive = function(slideIndex){ // if "short" pager type var len = slider.children.length; // nb of children if(slider.settings.pagerType == 'short'){ if(slider.settings.maxSlides > 1) { len = Math.ceil(slider.children.length/slider.settings.maxSlides); } slider.pagerEl.html( (slideIndex + 1) + slider.settings.pagerShortSeparator + len); return; } // remove all pager active classes slider.pagerEl.find('a').removeClass('active'); // apply the active class for all pagers slider.pagerEl.each(function(i, el) { $(el).find('a').eq(slideIndex).addClass('active'); }); } /** * Performs needed actions after a slide transition */ var updateAfterSlideTransition = function(){ // if infinte loop is true if(slider.settings.infiniteLoop){ var position = ''; // first slide if(slider.active.index == 0){ // set the new position position = slider.children.eq(0).position(); // carousel, last slide }else if(slider.active.index == getPagerQty() - 1 && slider.carousel){ position = slider.children.eq((getPagerQty() - 1) * getMoveBy()).position(); // last slide }else if(slider.active.index == slider.children.length - 1){ position = slider.children.eq(slider.children.length - 1).position(); } if(position){ if (slider.settings.mode == 'horizontal') { setPositionProperty(-position.left, 'reset', 0); } else if (slider.settings.mode == 'vertical') { setPositionProperty(-position.top, 'reset', 0); } } } // declare that the transition is complete slider.working = false; // onSlideAfter callback slider.settings.onSlideAfter(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); } /** * Updates the auto controls state (either active, or combined switch) * * @param state (string) "start", "stop" * - the new state of the auto show */ var updateAutoControls = function(state){ // if autoControlsCombine is true, replace the current control with the new state if(slider.settings.autoControlsCombine){ slider.controls.autoEl.html(slider.controls[state]); // if autoControlsCombine is false, apply the "active" class to the appropriate control }else{ slider.controls.autoEl.find('a').removeClass('active'); slider.controls.autoEl.find('a:not(.bx-' + state + ')').addClass('active'); } } /** * Updates the direction controls (checks if either should be hidden) */ var updateDirectionControls = function(){ if(getPagerQty() == 1){ slider.controls.prev.addClass('disabled'); slider.controls.next.addClass('disabled'); }else if(!slider.settings.infiniteLoop && slider.settings.hideControlOnEnd){ // if first slide if (slider.active.index == 0){ slider.controls.prev.addClass('disabled'); slider.controls.next.removeClass('disabled'); // if last slide }else if(slider.active.index == getPagerQty() - 1){ slider.controls.next.addClass('disabled'); slider.controls.prev.removeClass('disabled'); // if any slide in the middle }else{ slider.controls.prev.removeClass('disabled'); slider.controls.next.removeClass('disabled'); } } } /** * Initialzes the auto process */ var initAuto = function(){ // if autoDelay was supplied, launch the auto show using a setTimeout() call if(slider.settings.autoDelay > 0){ var timeout = setTimeout(el.startAuto, slider.settings.autoDelay); // if autoDelay was not supplied, start the auto show normally }else{ el.startAuto(); } // if autoHover is requested if(slider.settings.autoHover){ // on el hover el.hover(function(){ // if the auto show is currently playing (has an active interval) if(slider.interval){ // stop the auto show and pass true agument which will prevent control update el.stopAuto(true); // create a new autoPaused value which will be used by the relative "mouseout" event slider.autoPaused = true; } }, function(){ // if the autoPaused value was created be the prior "mouseover" event if(slider.autoPaused){ // start the auto show and pass true agument which will prevent control update el.startAuto(true); // reset the autoPaused value slider.autoPaused = null; } }); } } /** * Initialzes the ticker process */ var initTicker = function(){ var startPosition = 0; // if autoDirection is "next", append a clone of the entire slider if(slider.settings.autoDirection == 'next'){ el.append(slider.children.clone().addClass('bx-clone')); // if autoDirection is "prev", prepend a clone of the entire slider, and set the left position }else{ el.prepend(slider.children.clone().addClass('bx-clone')); var position = slider.children.first().position(); startPosition = slider.settings.mode == 'horizontal' ? -position.left : -position.top; } setPositionProperty(startPosition, 'reset', 0); // do not allow controls in ticker mode slider.settings.pager = false; slider.settings.controls = false; slider.settings.autoControls = false; // if autoHover is requested if(slider.settings.tickerHover && !slider.usingCSS){ // on el hover slider.viewport.hover(function(){ el.stop(); }, function(){ // calculate the total width of children (used to calculate the speed ratio) var totalDimens = 0; slider.children.each(function(index){ totalDimens += slider.settings.mode == 'horizontal' ? $(this).outerWidth(true) : $(this).outerHeight(true); }); // calculate the speed ratio (used to determine the new speed to finish the paused animation) var ratio = slider.settings.speed / totalDimens; // determine which property to use var property = slider.settings.mode == 'horizontal' ? 'left' : 'top'; // calculate the new speed var newSpeed = ratio * (totalDimens - (Math.abs(parseInt(el.css(property))))); tickerLoop(newSpeed); }); } // start the ticker loop tickerLoop(); } /** * Runs a continuous loop, news ticker-style */ var tickerLoop = function(resumeSpeed){ speed = resumeSpeed ? resumeSpeed : slider.settings.speed; var position = {left: 0, top: 0}; var reset = {left: 0, top: 0}; // if "next" animate left position to last child, then reset left to 0 if(slider.settings.autoDirection == 'next'){ position = el.find('.bx-clone').first().position(); // if "prev" animate left position to 0, then reset left to first non-clone child }else{ reset = slider.children.first().position(); } var animateProperty = slider.settings.mode == 'horizontal' ? -position.left : -position.top; var resetValue = slider.settings.mode == 'horizontal' ? -reset.left : -reset.top; var params = {resetValue: resetValue}; setPositionProperty(animateProperty, 'ticker', speed, params); } /** * Initializes touch events */ var initTouch = function(){ // initialize object to contain all touch values slider.touch = { start: {x: 0, y: 0}, end: {x: 0, y: 0} } slider.viewport.bind('touchstart', onTouchStart); } /** * Event handler for "touchstart" * * @param e (event) * - DOM event object */ var onTouchStart = function(e){ if(slider.working){ e.preventDefault(); }else{ // record the original position when touch starts slider.touch.originalPos = el.position(); var orig = e.originalEvent; // record the starting touch x, y coordinates slider.touch.start.x = orig.changedTouches[0].pageX; slider.touch.start.y = orig.changedTouches[0].pageY; // bind a "touchmove" event to the viewport slider.viewport.bind('touchmove', onTouchMove); // bind a "touchend" event to the viewport slider.viewport.bind('touchend', onTouchEnd); } } /** * Event handler for "touchmove" * * @param e (event) * - DOM event object */ var onTouchMove = function(e){ var orig = e.originalEvent; // if scrolling on y axis, do not prevent default var xMovement = Math.abs(orig.changedTouches[0].pageX - slider.touch.start.x); var yMovement = Math.abs(orig.changedTouches[0].pageY - slider.touch.start.y); // x axis swipe if((xMovement * 3) > yMovement && slider.settings.preventDefaultSwipeX){ e.preventDefault(); // y axis swipe }else if((yMovement * 3) > xMovement && slider.settings.preventDefaultSwipeY){ e.preventDefault(); } if(slider.settings.mode != 'fade' && slider.settings.oneToOneTouch){ var value = 0; // if horizontal, drag along x axis if(slider.settings.mode == 'horizontal'){ var change = orig.changedTouches[0].pageX - slider.touch.start.x; value = slider.touch.originalPos.left + change; // if vertical, drag along y axis }else{ var change = orig.changedTouches[0].pageY - slider.touch.start.y; value = slider.touch.originalPos.top + change; } setPositionProperty(value, 'reset', 0); } } /** * Event handler for "touchend" * * @param e (event) * - DOM event object */ var onTouchEnd = function(e){ slider.viewport.unbind('touchmove', onTouchMove); var orig = e.originalEvent; var value = 0; // record end x, y positions slider.touch.end.x = orig.changedTouches[0].pageX; slider.touch.end.y = orig.changedTouches[0].pageY; // if fade mode, check if absolute x distance clears the threshold if(slider.settings.mode == 'fade'){ var distance = Math.abs(slider.touch.start.x - slider.touch.end.x); if(distance >= slider.settings.swipeThreshold){ slider.touch.start.x > slider.touch.end.x ? el.goToNextSlide() : el.goToPrevSlide(); el.stopAuto(); } // not fade mode }else{ var distance = 0; // calculate distance and el's animate property if(slider.settings.mode == 'horizontal'){ distance = slider.touch.end.x - slider.touch.start.x; value = slider.touch.originalPos.left; }else{ distance = slider.touch.end.y - slider.touch.start.y; value = slider.touch.originalPos.top; } // if not infinite loop and first / last slide, do not attempt a slide transition if(!slider.settings.infiniteLoop && ((slider.active.index == 0 && distance > 0) || (slider.active.last && distance < 0))){ setPositionProperty(value, 'reset', 200); }else{ // check if distance clears threshold if(Math.abs(distance) >= slider.settings.swipeThreshold){ distance < 0 ? el.goToNextSlide() : el.goToPrevSlide(); el.stopAuto(); }else{ // el.animate(property, 200); setPositionProperty(value, 'reset', 200); } } } slider.viewport.unbind('touchend', onTouchEnd); } /** * Window resize event callback */ var resizeWindow = function(e){ // don't do anything if slider isn't initialized. if(!slider.initialized) return; // get the new window dimens (again, thank you IE) var windowWidthNew = $(window).width(); var windowHeightNew = $(window).height(); // make sure that it is a true window resize // *we must check this because our dinosaur friend IE fires a window resize event when certain DOM elements // are resized. Can you just die already?* if(windowWidth != windowWidthNew || windowHeight != windowHeightNew){ // set the new window dimens windowWidth = windowWidthNew; windowHeight = windowHeightNew; // update all dynamic elements el.redrawSlider(); // Call user resize handler slider.settings.onSliderResize.call(el, slider.active.index); } } /** * =================================================================================== * = PUBLIC FUNCTIONS * =================================================================================== */ /** * Performs slide transition to the specified slide * * @param slideIndex (int) * - the destination slide's index (zero-based) * * @param direction (string) * - INTERNAL USE ONLY - the direction of travel ("prev" / "next") */ el.goToSlide = function(slideIndex, direction){ // if plugin is currently in motion, ignore request if(slider.working || slider.active.index == slideIndex) return; // declare that plugin is in motion slider.working = true; // store the old index slider.oldIndex = slider.active.index; // if slideIndex is less than zero, set active index to last child (this happens during infinite loop) if(slideIndex < 0){ slider.active.index = getPagerQty() - 1; // if slideIndex is greater than children length, set active index to 0 (this happens during infinite loop) }else if(slideIndex >= getPagerQty()){ slider.active.index = 0; // set active index to requested slide }else{ slider.active.index = slideIndex; } // onSlideBefore, onSlideNext, onSlidePrev callbacks slider.settings.onSlideBefore(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); if(direction == 'next'){ slider.settings.onSlideNext(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); }else if(direction == 'prev'){ slider.settings.onSlidePrev(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); } // check if last slide slider.active.last = slider.active.index >= getPagerQty() - 1; // update the pager with active class if(slider.settings.pager) updatePagerActive(slider.active.index); // // check for direction control update if(slider.settings.controls) updateDirectionControls(); // if slider is set to mode: "fade" if(slider.settings.mode == 'fade'){ // if adaptiveHeight is true and next height is different from current height, animate to the new height if(slider.settings.adaptiveHeight && slider.viewport.height() != getViewportHeight()){ slider.viewport.animate({height: getViewportHeight()}, slider.settings.adaptiveHeightSpeed); } // fade out the visible child and reset its z-index value slider.children.filter(':visible').fadeOut(slider.settings.speed).css({zIndex: 0}); // fade in the newly requested slide slider.children.eq(slider.active.index).css('zIndex', slider.settings.slideZIndex+1).fadeIn(slider.settings.speed, function(){ $(this).css('zIndex', slider.settings.slideZIndex); updateAfterSlideTransition(); }); // slider mode is not "fade" }else{ // if adaptiveHeight is true and next height is different from current height, animate to the new height if(slider.settings.adaptiveHeight && slider.viewport.height() != getViewportHeight()){ slider.viewport.animate({height: getViewportHeight()}, slider.settings.adaptiveHeightSpeed); } var moveBy = 0; var position = {left: 0, top: 0}; // if carousel and not infinite loop if(!slider.settings.infiniteLoop && slider.carousel && slider.active.last){ if(slider.settings.mode == 'horizontal'){ // get the last child position var lastChild = slider.children.eq(slider.children.length - 1); position = lastChild.position(); // calculate the position of the last slide moveBy = slider.viewport.width() - lastChild.outerWidth(); }else{ // get last showing index position var lastShowingIndex = slider.children.length - slider.settings.minSlides; position = slider.children.eq(lastShowingIndex).position(); } // horizontal carousel, going previous while on first slide (infiniteLoop mode) }else if(slider.carousel && slider.active.last && direction == 'prev'){ // get the last child position var eq = slider.settings.moveSlides == 1 ? slider.settings.maxSlides - getMoveBy() : ((getPagerQty() - 1) * getMoveBy()) - (slider.children.length - slider.settings.maxSlides); var lastChild = el.children('.bx-clone').eq(eq); position = lastChild.position(); // if infinite loop and "Next" is clicked on the last slide }else if(direction == 'next' && slider.active.index == 0){ // get the last clone position position = el.find('> .bx-clone').eq(slider.settings.maxSlides).position(); slider.active.last = false; // normal non-zero requests }else if(slideIndex >= 0){ var requestEl = slideIndex * getMoveBy(); position = slider.children.eq(requestEl).position(); } /* If the position doesn't exist * (e.g. if you destroy the slider on a next click), * it doesn't throw an error. */ if ("undefined" !== typeof(position)) { var value = slider.settings.mode == 'horizontal' ? -(position.left - moveBy) : -position.top; // plugin values to be animated setPositionProperty(value, 'slide', slider.settings.speed); } } } /** * Transitions to the next slide in the show */ el.goToNextSlide = function(){ // if infiniteLoop is false and last page is showing, disregard call if (!slider.settings.infiniteLoop && slider.active.last) return; var pagerIndex = parseInt(slider.active.index) + 1; el.goToSlide(pagerIndex, 'next'); } /** * Transitions to the prev slide in the show */ el.goToPrevSlide = function(){ // if infiniteLoop is false and last page is showing, disregard call if (!slider.settings.infiniteLoop && slider.active.index == 0) return; var pagerIndex = parseInt(slider.active.index) - 1; el.goToSlide(pagerIndex, 'prev'); } /** * Starts the auto show * * @param preventControlUpdate (boolean) * - if true, auto controls state will not be updated */ el.startAuto = function(preventControlUpdate){ // if an interval already exists, disregard call if(slider.interval) return; // create an interval slider.interval = setInterval(function(){ slider.settings.autoDirection == 'next' ? el.goToNextSlide() : el.goToPrevSlide(); }, slider.settings.pause); // if auto controls are displayed and preventControlUpdate is not true if (slider.settings.autoControls && preventControlUpdate != true) updateAutoControls('stop'); } /** * Stops the auto show * * @param preventControlUpdate (boolean) * - if true, auto controls state will not be updated */ el.stopAuto = function(preventControlUpdate){ // if no interval exists, disregard call if(!slider.interval) return; // clear the interval clearInterval(slider.interval); slider.interval = null; // if auto controls are displayed and preventControlUpdate is not true if (slider.settings.autoControls && preventControlUpdate != true) updateAutoControls('start'); } /** * Returns current slide index (zero-based) */ el.getCurrentSlide = function(){ return slider.active.index; } /** * Returns current slide element */ el.getCurrentSlideElement = function(){ return slider.children.eq(slider.active.index); } /** * Returns number of slides in show */ el.getSlideCount = function(){ return slider.children.length; } /** * Update all dynamic slider elements */ el.redrawSlider = function(){ // resize all children in ratio to new screen size slider.children.add(el.find('.bx-clone')).width(getSlideWidth()); // adjust the height slider.viewport.css('height', getViewportHeight()); // update the slide position if(!slider.settings.ticker) setSlidePosition(); // if active.last was true before the screen resize, we want // to keep it last no matter what screen size we end on if (slider.active.last) slider.active.index = getPagerQty() - 1; // if the active index (page) no longer exists due to the resize, simply set the index as last if (slider.active.index >= getPagerQty()) slider.active.last = true; // if a pager is being displayed and a custom pager is not being used, update it if(slider.settings.pager && !slider.settings.pagerCustom){ populatePager(); updatePagerActive(slider.active.index); } } /** * Destroy the current instance of the slider (revert everything back to original state) */ el.destroySlider = function(){ // don't do anything if slider has already been destroyed if(!slider.initialized) return; slider.initialized = false; $('.bx-clone', this).remove(); slider.children.each(function() { $(this).data("origStyle") != undefined ? $(this).attr("style", $(this).data("origStyle")) : $(this).removeAttr('style'); }); $(this).data("origStyle") != undefined ? this.attr("style", $(this).data("origStyle")) : $(this).removeAttr('style'); $(this).unwrap().unwrap(); if(slider.controls.el) slider.controls.el.remove(); if(slider.controls.next) slider.controls.next.remove(); if(slider.controls.prev) slider.controls.prev.remove(); if(slider.pagerEl && slider.settings.controls) slider.pagerEl.remove(); $('.bx-caption', this).remove(); if(slider.controls.autoEl) slider.controls.autoEl.remove(); clearInterval(slider.interval); if(slider.settings.responsive) $(window).unbind('resize', resizeWindow); } /** * Reload the slider (revert all DOM changes, and re-initialize) */ el.reloadSlider = function(settings){ if (settings != undefined) options = settings; el.destroySlider(); init(); } init(); // returns the current jQuery object return this; } })(jQuery);
'); } }); } /** * Click next binding * * @param e (event) * - DOM event object */ var clickNextBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); el.goToNextSlide(); e.preventDefault(); } /** * Click prev binding * * @param e (event) * - DOM event object */ var clickPrevBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); el.goToPrevSlide(); e.preventDefault(); } /** * Click start binding * * @param e (event) * - DOM event object */ var clickStartBind = function(e){ el.startAuto(); e.preventDefault(); } /** * Click stop binding * * @param e (event) * - DOM event object */ var clickStopBind = function(e){ el.stopAuto(); e.preventDefault(); } /** * Click pager binding * * @param e (event) * - DOM event object */ var clickPagerBind = function(e){ // if auto show is running, stop it if (slider.settings.auto) el.stopAuto(); var pagerLink = $(e.currentTarget); if(pagerLink.attr('data-slide-index') !== undefined){ var pagerIndex = parseInt(pagerLink.attr('data-slide-index')); // if clicked pager link is not active, continue with the goToSlide call if(pagerIndex != slider.active.index) el.goToSlide(pagerIndex); e.preventDefault(); } } /** * Updates the pager links with an active class * * @param slideIndex (int) * - index of slide to make active */ var updatePagerActive = function(slideIndex){ // if "short" pager type var len = slider.children.length; // nb of children if(slider.settings.pagerType == 'short'){ if(slider.settings.maxSlides > 1) { len = Math.ceil(slider.children.length/slider.settings.maxSlides); } slider.pagerEl.html( (slideIndex + 1) + slider.settings.pagerShortSeparator + len); return; } // remove all pager active classes slider.pagerEl.find('a').removeClass('active'); // apply the active class for all pagers slider.pagerEl.each(function(i, el) { $(el).find('a').eq(slideIndex).addClass('active'); }); } /** * Performs needed actions after a slide transition */ var updateAfterSlideTransition = function(){ // if infinte loop is true if(slider.settings.infiniteLoop){ var position = ''; // first slide if(slider.active.index == 0){ // set the new position position = slider.children.eq(0).position(); // carousel, last slide }else if(slider.active.index == getPagerQty() - 1 && slider.carousel){ position = slider.children.eq((getPagerQty() - 1) * getMoveBy()).position(); // last slide }else if(slider.active.index == slider.children.length - 1){ position = slider.children.eq(slider.children.length - 1).position(); } if(position){ if (slider.settings.mode == 'horizontal') { setPositionProperty(-position.left, 'reset', 0); } else if (slider.settings.mode == 'vertical') { setPositionProperty(-position.top, 'reset', 0); } } } // declare that the transition is complete slider.working = false; // onSlideAfter callback slider.settings.onSlideAfter(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); } /** * Updates the auto controls state (either active, or combined switch) * * @param state (string) "start", "stop" * - the new state of the auto show */ var updateAutoControls = function(state){ // if autoControlsCombine is true, replace the current control with the new state if(slider.settings.autoControlsCombine){ slider.controls.autoEl.html(slider.controls[state]); // if autoControlsCombine is false, apply the "active" class to the appropriate control }else{ slider.controls.autoEl.find('a').removeClass('active'); slider.controls.autoEl.find('a:not(.bx-' + state + ')').addClass('active'); } } /** * Updates the direction controls (checks if either should be hidden) */ var updateDirectionControls = function(){ if(getPagerQty() == 1){ slider.controls.prev.addClass('disabled'); slider.controls.next.addClass('disabled'); }else if(!slider.settings.infiniteLoop && slider.settings.hideControlOnEnd){ // if first slide if (slider.active.index == 0){ slider.controls.prev.addClass('disabled'); slider.controls.next.removeClass('disabled'); // if last slide }else if(slider.active.index == getPagerQty() - 1){ slider.controls.next.addClass('disabled'); slider.controls.prev.removeClass('disabled'); // if any slide in the middle }else{ slider.controls.prev.removeClass('disabled'); slider.controls.next.removeClass('disabled'); } } } /** * Initialzes the auto process */ var initAuto = function(){ // if autoDelay was supplied, launch the auto show using a setTimeout() call if(slider.settings.autoDelay > 0){ var timeout = setTimeout(el.startAuto, slider.settings.autoDelay); // if autoDelay was not supplied, start the auto show normally }else{ el.startAuto(); } // if autoHover is requested if(slider.settings.autoHover){ // on el hover el.hover(function(){ // if the auto show is currently playing (has an active interval) if(slider.interval){ // stop the auto show and pass true agument which will prevent control update el.stopAuto(true); // create a new autoPaused value which will be used by the relative "mouseout" event slider.autoPaused = true; } }, function(){ // if the autoPaused value was created be the prior "mouseover" event if(slider.autoPaused){ // start the auto show and pass true agument which will prevent control update el.startAuto(true); // reset the autoPaused value slider.autoPaused = null; } }); } } /** * Initialzes the ticker process */ var initTicker = function(){ var startPosition = 0; // if autoDirection is "next", append a clone of the entire slider if(slider.settings.autoDirection == 'next'){ el.append(slider.children.clone().addClass('bx-clone')); // if autoDirection is "prev", prepend a clone of the entire slider, and set the left position }else{ el.prepend(slider.children.clone().addClass('bx-clone')); var position = slider.children.first().position(); startPosition = slider.settings.mode == 'horizontal' ? -position.left : -position.top; } setPositionProperty(startPosition, 'reset', 0); // do not allow controls in ticker mode slider.settings.pager = false; slider.settings.controls = false; slider.settings.autoControls = false; // if autoHover is requested if(slider.settings.tickerHover && !slider.usingCSS){ // on el hover slider.viewport.hover(function(){ el.stop(); }, function(){ // calculate the total width of children (used to calculate the speed ratio) var totalDimens = 0; slider.children.each(function(index){ totalDimens += slider.settings.mode == 'horizontal' ? $(this).outerWidth(true) : $(this).outerHeight(true); }); // calculate the speed ratio (used to determine the new speed to finish the paused animation) var ratio = slider.settings.speed / totalDimens; // determine which property to use var property = slider.settings.mode == 'horizontal' ? 'left' : 'top'; // calculate the new speed var newSpeed = ratio * (totalDimens - (Math.abs(parseInt(el.css(property))))); tickerLoop(newSpeed); }); } // start the ticker loop tickerLoop(); } /** * Runs a continuous loop, news ticker-style */ var tickerLoop = function(resumeSpeed){ speed = resumeSpeed ? resumeSpeed : slider.settings.speed; var position = {left: 0, top: 0}; var reset = {left: 0, top: 0}; // if "next" animate left position to last child, then reset left to 0 if(slider.settings.autoDirection == 'next'){ position = el.find('.bx-clone').first().position(); // if "prev" animate left position to 0, then reset left to first non-clone child }else{ reset = slider.children.first().position(); } var animateProperty = slider.settings.mode == 'horizontal' ? -position.left : -position.top; var resetValue = slider.settings.mode == 'horizontal' ? -reset.left : -reset.top; var params = {resetValue: resetValue}; setPositionProperty(animateProperty, 'ticker', speed, params); } /** * Initializes touch events */ var initTouch = function(){ // initialize object to contain all touch values slider.touch = { start: {x: 0, y: 0}, end: {x: 0, y: 0} } slider.viewport.bind('touchstart', onTouchStart); } /** * Event handler for "touchstart" * * @param e (event) * - DOM event object */ var onTouchStart = function(e){ if(slider.working){ e.preventDefault(); }else{ // record the original position when touch starts slider.touch.originalPos = el.position(); var orig = e.originalEvent; // record the starting touch x, y coordinates slider.touch.start.x = orig.changedTouches[0].pageX; slider.touch.start.y = orig.changedTouches[0].pageY; // bind a "touchmove" event to the viewport slider.viewport.bind('touchmove', onTouchMove); // bind a "touchend" event to the viewport slider.viewport.bind('touchend', onTouchEnd); } } /** * Event handler for "touchmove" * * @param e (event) * - DOM event object */ var onTouchMove = function(e){ var orig = e.originalEvent; // if scrolling on y axis, do not prevent default var xMovement = Math.abs(orig.changedTouches[0].pageX - slider.touch.start.x); var yMovement = Math.abs(orig.changedTouches[0].pageY - slider.touch.start.y); // x axis swipe if((xMovement * 3) > yMovement && slider.settings.preventDefaultSwipeX){ e.preventDefault(); // y axis swipe }else if((yMovement * 3) > xMovement && slider.settings.preventDefaultSwipeY){ e.preventDefault(); } if(slider.settings.mode != 'fade' && slider.settings.oneToOneTouch){ var value = 0; // if horizontal, drag along x axis if(slider.settings.mode == 'horizontal'){ var change = orig.changedTouches[0].pageX - slider.touch.start.x; value = slider.touch.originalPos.left + change; // if vertical, drag along y axis }else{ var change = orig.changedTouches[0].pageY - slider.touch.start.y; value = slider.touch.originalPos.top + change; } setPositionProperty(value, 'reset', 0); } } /** * Event handler for "touchend" * * @param e (event) * - DOM event object */ var onTouchEnd = function(e){ slider.viewport.unbind('touchmove', onTouchMove); var orig = e.originalEvent; var value = 0; // record end x, y positions slider.touch.end.x = orig.changedTouches[0].pageX; slider.touch.end.y = orig.changedTouches[0].pageY; // if fade mode, check if absolute x distance clears the threshold if(slider.settings.mode == 'fade'){ var distance = Math.abs(slider.touch.start.x - slider.touch.end.x); if(distance >= slider.settings.swipeThreshold){ slider.touch.start.x > slider.touch.end.x ? el.goToNextSlide() : el.goToPrevSlide(); el.stopAuto(); } // not fade mode }else{ var distance = 0; // calculate distance and el's animate property if(slider.settings.mode == 'horizontal'){ distance = slider.touch.end.x - slider.touch.start.x; value = slider.touch.originalPos.left; }else{ distance = slider.touch.end.y - slider.touch.start.y; value = slider.touch.originalPos.top; } // if not infinite loop and first / last slide, do not attempt a slide transition if(!slider.settings.infiniteLoop && ((slider.active.index == 0 && distance > 0) || (slider.active.last && distance < 0))){ setPositionProperty(value, 'reset', 200); }else{ // check if distance clears threshold if(Math.abs(distance) >= slider.settings.swipeThreshold){ distance < 0 ? el.goToNextSlide() : el.goToPrevSlide(); el.stopAuto(); }else{ // el.animate(property, 200); setPositionProperty(value, 'reset', 200); } } } slider.viewport.unbind('touchend', onTouchEnd); } /** * Window resize event callback */ var resizeWindow = function(e){ // don't do anything if slider isn't initialized. if(!slider.initialized) return; // get the new window dimens (again, thank you IE) var windowWidthNew = $(window).width(); var windowHeightNew = $(window).height(); // make sure that it is a true window resize // *we must check this because our dinosaur friend IE fires a window resize event when certain DOM elements // are resized. Can you just die already?* if(windowWidth != windowWidthNew || windowHeight != windowHeightNew){ // set the new window dimens windowWidth = windowWidthNew; windowHeight = windowHeightNew; // update all dynamic elements el.redrawSlider(); // Call user resize handler slider.settings.onSliderResize.call(el, slider.active.index); } } /** * =================================================================================== * = PUBLIC FUNCTIONS * =================================================================================== */ /** * Performs slide transition to the specified slide * * @param slideIndex (int) * - the destination slide's index (zero-based) * * @param direction (string) * - INTERNAL USE ONLY - the direction of travel ("prev" / "next") */ el.goToSlide = function(slideIndex, direction){ // if plugin is currently in motion, ignore request if(slider.working || slider.active.index == slideIndex) return; // declare that plugin is in motion slider.working = true; // store the old index slider.oldIndex = slider.active.index; // if slideIndex is less than zero, set active index to last child (this happens during infinite loop) if(slideIndex < 0){ slider.active.index = getPagerQty() - 1; // if slideIndex is greater than children length, set active index to 0 (this happens during infinite loop) }else if(slideIndex >= getPagerQty()){ slider.active.index = 0; // set active index to requested slide }else{ slider.active.index = slideIndex; } // onSlideBefore, onSlideNext, onSlidePrev callbacks slider.settings.onSlideBefore(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); if(direction == 'next'){ slider.settings.onSlideNext(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); }else if(direction == 'prev'){ slider.settings.onSlidePrev(slider.children.eq(slider.active.index), slider.oldIndex, slider.active.index); } // check if last slide slider.active.last = slider.active.index >= getPagerQty() - 1; // update the pager with active class if(slider.settings.pager) updatePagerActive(slider.active.index); // // check for direction control update if(slider.settings.controls) updateDirectionControls(); // if slider is set to mode: "fade" if(slider.settings.mode == 'fade'){ // if adaptiveHeight is true and next height is different from current height, animate to the new height if(slider.settings.adaptiveHeight && slider.viewport.height() != getViewportHeight()){ slider.viewport.animate({height: getViewportHeight()}, slider.settings.adaptiveHeightSpeed); } // fade out the visible child and reset its z-index value slider.children.filter(':visible').fadeOut(slider.settings.speed).css({zIndex: 0}); // fade in the newly requested slide slider.children.eq(slider.active.index).css('zIndex', slider.settings.slideZIndex+1).fadeIn(slider.settings.speed, function(){ $(this).css('zIndex', slider.settings.slideZIndex); updateAfterSlideTransition(); }); // slider mode is not "fade" }else{ // if adaptiveHeight is true and next height is different from current height, animate to the new height if(slider.settings.adaptiveHeight && slider.viewport.height() != getViewportHeight()){ slider.viewport.animate({height: getViewportHeight()}, slider.settings.adaptiveHeightSpeed); } var moveBy = 0; var position = {left: 0, top: 0}; // if carousel and not infinite loop if(!slider.settings.infiniteLoop && slider.carousel && slider.active.last){ if(slider.settings.mode == 'horizontal'){ // get the last child position var lastChild = slider.children.eq(slider.children.length - 1); position = lastChild.position(); // calculate the position of the last slide moveBy = slider.viewport.width() - lastChild.outerWidth(); }else{ // get last showing index position var lastShowingIndex = slider.children.length - slider.settings.minSlides; position = slider.children.eq(lastShowingIndex).position(); } // horizontal carousel, going previous while on first slide (infiniteLoop mode) }else if(slider.carousel && slider.active.last && direction == 'prev'){ // get the last child position var eq = slider.settings.moveSlides == 1 ? slider.settings.maxSlides - getMoveBy() : ((getPagerQty() - 1) * getMoveBy()) - (slider.children.length - slider.settings.maxSlides); var lastChild = el.children('.bx-clone').eq(eq); position = lastChild.position(); // if infinite loop and "Next" is clicked on the last slide }else if(direction == 'next' && slider.active.index == 0){ // get the last clone position position = el.find('> .bx-clone').eq(slider.settings.maxSlides).position(); slider.active.last = false; // normal non-zero requests }else if(slideIndex >= 0){ var requestEl = slideIndex * getMoveBy(); position = slider.children.eq(requestEl).position(); } /* If the position doesn't exist * (e.g. if you destroy the slider on a next click), * it doesn't throw an error. */ if ("undefined" !== typeof(position)) { var value = slider.settings.mode == 'horizontal' ? -(position.left - moveBy) : -position.top; // plugin values to be animated setPositionProperty(value, 'slide', slider.settings.speed); } } } /** * Transitions to the next slide in the show */ el.goToNextSlide = function(){ // if infiniteLoop is false and last page is showing, disregard call if (!slider.settings.infiniteLoop && slider.active.last) return; var pagerIndex = parseInt(slider.active.index) + 1; el.goToSlide(pagerIndex, 'next'); } /** * Transitions to the prev slide in the show */ el.goToPrevSlide = function(){ // if infiniteLoop is false and last page is showing, disregard call if (!slider.settings.infiniteLoop && slider.active.index == 0) return; var pagerIndex = parseInt(slider.active.index) - 1; el.goToSlide(pagerIndex, 'prev'); } /** * Starts the auto show * * @param preventControlUpdate (boolean) * - if true, auto controls state will not be updated */ el.startAuto = function(preventControlUpdate){ // if an interval already exists, disregard call if(slider.interval) return; // create an interval slider.interval = setInterval(function(){ slider.settings.autoDirection == 'next' ? el.goToNextSlide() : el.goToPrevSlide(); }, slider.settings.pause); // if auto controls are displayed and preventControlUpdate is not true if (slider.settings.autoControls && preventControlUpdate != true) updateAutoControls('stop'); } /** * Stops the auto show * * @param preventControlUpdate (boolean) * - if true, auto controls state will not be updated */ el.stopAuto = function(preventControlUpdate){ // if no interval exists, disregard call if(!slider.interval) return; // clear the interval clearInterval(slider.interval); slider.interval = null; // if auto controls are displayed and preventControlUpdate is not true if (slider.settings.autoControls && preventControlUpdate != true) updateAutoControls('start'); } /** * Returns current slide index (zero-based) */ el.getCurrentSlide = function(){ return slider.active.index; } /** * Returns current slide element */ el.getCurrentSlideElement = function(){ return slider.children.eq(slider.active.index); } /** * Returns number of slides in show */ el.getSlideCount = function(){ return slider.children.length; } /** * Update all dynamic slider elements */ el.redrawSlider = function(){ // resize all children in ratio to new screen size slider.children.add(el.find('.bx-clone')).width(getSlideWidth()); // adjust the height slider.viewport.css('height', getViewportHeight()); // update the slide position if(!slider.settings.ticker) setSlidePosition(); // if active.last was true before the screen resize, we want // to keep it last no matter what screen size we end on if (slider.active.last) slider.active.index = getPagerQty() - 1; // if the active index (page) no longer exists due to the resize, simply set the index as last if (slider.active.index >= getPagerQty()) slider.active.last = true; // if a pager is being displayed and a custom pager is not being used, update it if(slider.settings.pager && !slider.settings.pagerCustom){ populatePager(); updatePagerActive(slider.active.index); } } /** * Destroy the current instance of the slider (revert everything back to original state) */ el.destroySlider = function(){ // don't do anything if slider has already been destroyed if(!slider.initialized) return; slider.initialized = false; $('.bx-clone', this).remove(); slider.children.each(function() { $(this).data("origStyle") != undefined ? $(this).attr("style", $(this).data("origStyle")) : $(this).removeAttr('style'); }); $(this).data("origStyle") != undefined ? this.attr("style", $(this).data("origStyle")) : $(this).removeAttr('style'); $(this).unwrap().unwrap(); if(slider.controls.el) slider.controls.el.remove(); if(slider.controls.next) slider.controls.next.remove(); if(slider.controls.prev) slider.controls.prev.remove(); if(slider.pagerEl && slider.settings.controls) slider.pagerEl.remove(); $('.bx-caption', this).remove(); if(slider.controls.autoEl) slider.controls.autoEl.remove(); clearInterval(slider.interval); if(slider.settings.responsive) $(window).unbind('resize', resizeWindow); } /** * Reload the slider (revert all DOM changes, and re-initialize) */ el.reloadSlider = function(settings){ if (settings != undefined) options = settings; el.destroySlider(); init(); } init(); // returns the current jQuery object return this; } })(jQuery);
Subscribe to:
Post Comments (Atom)
0 comments:
Post a Comment