toggleControls
is set to true).navigationFormatter
code, you should be able to create and link to your own thumbnail images.navigationFormatter
option as follows: navigationFormatter : function(i, panel){
return '<img src="images/th-slide-' + ['civil-1', 'env-1', 'civil-2', 'env-2'][i-1] + '.jpg">';
}
.attr('rel','group')
in the script. <!-- jQuery -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
<!-- Anything Slider optional plugins -->
<script src="js/jquery.easing.1.2.js" type="text/javascript"></script>
<!-- http://ajax.googleapis.com/ajax/libs/swfobject/2.2/swfobject.js -->
<script src="js/swfobject.js" type="text/javascript"></script>
<!-- Anything Slider -->
<link href="css/anythingslider.css" type="text/css" rel="stylesheet" />
<script src="js/jquery.anythingslider.min.js" type="text/javascript"></script>
<!-- ColorBox -->
<link href="colorbox/colorbox.css" type="text/css" rel="stylesheet" />
<script src="colorbox/jquery.colorbox-min.js" type="text/javascript"></script>
/* CSS to expand the image to fit inside colorbox */
#cboxPhoto { width: 100%; height: 100%; margin: 0 !important; }
/* Change metallic theme defaults to show thumbnails -
using #demo2 (page wrapper) to increase this CSS priority */
#demo2 div.anythingSlider-metallic .thumbNav a {
background-image: url();
height: 30px;
width: 30px;
border: #000 1px solid;
border-radius: 2px;
-moz-border-radius: 2px;
-webkit-border-radius: 2px;
text-indent: 0;
}
/* border around link (image) to show current panel */
#demo2 div.anythingSlider-metallic .thumbNav a:hover,
#demo2 div.anythingSlider-metallic .thumbNav a.cur {
border-color: #fff;
}
/* reposition the start/stop button */
#demo2 div.anythingSlider-metallic .start-stop {
margin-top: 15px;
}
<ul id="slider1">
<li><img src="images/slide-civil-1.jpg" /></li>
<li><img src="images/slide-env-1.jpg" /></li>
<li><img src="images/slide-civil-2.jpg" /></li>
<li><img src="images/slide-env-2.jpg" /></li>
</ul>
$(document).ready(function(){
$('#slider1')
.anythingSlider({
width : 400,
height : 300,
toggleControls : true,
startStopped : true,
theme : 'metallic',
navigationFormatter : function(i, panel){ // add thumbnails as navigation links
return '<img src="images/th-slide-' + ['civil-1', 'env-1', 'civil-2', 'env-2'][i - 1] + '.jpg">';
}
})
// target all images inside the current slider
// replace with 'img.someclass' to target specific images
.find('.panel:not(.cloned) img') // ignore the cloned panels
.attr('rel','group') // add all slider images to a colorbox group
.colorbox({
width: '90%',
height: '90%',
href: function(){ return $(this).attr('src'); },
// use $(this).attr('title') for specific image captions
title: 'Press escape to close',
rel: 'group'
});
});
In awe I watched the waxing moon ride across the zenith of the heavens like an ambered chariot towards the ebon void of infinite space wherein the tethered belts of Jupiter and Mars hang forever festooned in their orbital majesty. And as I looked at all this I thought... I must put a roof on this lavatory.~ Les Dawson
Life is conversational. Web design should be the same way. On the web, you’re talking to someone you’ve probably never met – so it’s important to be clear and precise. Thus, well structured navigation and content organization goes hand in hand with having a good conversation.
top
, bottom
, left
, right
, fade
, expand
, listLR
, listRL
, caption-Top
, caption-Right
, caption-Bottom
, caption-Left
. $('#slider2').anythingSliderFx({
'.selector1' : [ 'effect(s)', 'size', 'time', 'easing' ],
'.selector2' : [ 'effect(s)', 'size', 'time', 'easing' ]
});
'size', 'time' and 'easing' are optional, but they must remain in that order. So if you want to add an effect time, you must also set a size - [ 'effect(s)', 'size', 'time' ]
. To add an easing, all parameters must be included.top
, bottom
, left
, right
: Default 'inFx' position is zero, 'outFx' position is based on the initial slider height and width.fade
: Default 'inFx' has an opacity set to one, 'outFx' opacity is zero.expand
: Default 'inFx' sets the width to 100%, left and right positions to 0%; the 'outFx' width is set to 10%, left and right set to 50% to somewhat center the image. When changing this size option, use percentage values, but anything more than 20% the image position will noticeably be not centered.listLR
: Default 'inFx' left position is zero; 'outFx' position will make ':odd' elements move (L)eft and ':even' elements move (R)ight the width of the slider.listRL
: Default 'inFx' left position is zero; 'outFx' position will make ':odd' elements move (R)ight and ':even' elements move (L)eft the width of the slider.caption-{direction}
: This effect is opposite of the others. The default 'inFx' positions the element so it is in view while the 'outFx' positions the element out of view. See demo 3 for more details. $('#slider1').anythingSliderFx({
inFx : {
'.selector1' : { top : 0, time: 400, easing : 'easeOutBounce' },
'.selector2' : { left: 0, time: 400 }
},
// out = the animation that occurs when you slide "out" of a panel
// (it also occurs before the "in" animation)
outFx : {
'.selector1' : { top : '-100px', time: 350 },
'.selector2' : { left : '-200px' }
}
<!-- jQuery -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
<!-- Anything Slider optional plugins -->
<script src="js/jquery.easing.1.2.js" type="text/javascript"></script>
<!-- http://ajax.googleapis.com/ajax/libs/swfobject/2.2/swfobject.js -->
<script src="js/swfobject.js" type="text/javascript"></script>
<!-- Anything Slider -->
<link href="css/anythingslider.css" type="text/css" rel="stylesheet" />
<script src="js/jquery.anythingslider.min.js" type="text/javascript"></script>
<!-- Anything Slider optional FX extension -->
<script src="js/jquery.anythingslider.fx.min.js" type="text/javascript"></script>
<ul id="slider2">
<li class="panel1">
<div class="textSlide">
<img src="images/251356.jpg" alt="tomato sandwich" style="float: right;
margin: 0 0 2px 10px;" />
<h3>Queenie's Killer Tomato Bagel Sandwich</h3>
<h4>Ingredients</h4>
<ul>
<li>1 bagel, split and toasted</li>
<li>2 tablespoons cream cheese</li>
<li>1 roma (plum) tomatoes, thinly sliced</li>
<li>salt and pepper to taste</li>
<li>4 leaves fresh basil</li>
</ul>
</div>
</li>
<li class="panel2">
<div class="quoteSlide">
<blockquote>In awe I watched the waxing moon ride across the zenith of
the heavens like an ambered chariot towards the ebon void of infinite space
wherein the tethered belts of Jupiter and Mars hang forever festooned in
their orbital majesty. And as I looked at all this I thought... I must put
a roof on this lavatory.<br>-- Les Dawson</blockquote>
</div>
</li>
<li class="panel3">
<img class="expand" src="images/slide-tele-1.jpg" alt="" />
</li>
<li class="panel4">
<div class="quoteSlide">
<blockquote>Life is conversational. Web design should be the same way.
On the web, you’re talking to someone you’ve probably
never met – so it’s important to be clear and precise.
Thus, well structured navigation and content organization goes hand in hand
with having a good conversation.</blockquote>
<p>
- <a href='http://quotesondesign.com/chikezie-ejiasi/'>Chikezie Ejiasi</a>
</p>
</div>
</li>
<li class="panel5">
<img class="fade" src="images/slide-tele-2.jpg" alt="" />
</li>
</ul>
$(document).ready(function(){
$('#slider2') // Demo 2 code, using FX base effects
.anythingSlider({
width : 600,
height : 350,
startStopped : true,
resizeContents : false,
navigationFormatter : function(i, panel){
return ['Recipe', 'Quote', 'Image', 'Quote #2', 'Image #2', 'Test'][i - 1];
}
})
.anythingSliderFx({
// base FX definitions
// '.selector' : [ 'effect(s)', 'size', 'time', 'easing' ]
// 'size', 'time' and 'easing' are optional parameters, but must be kept in order if added
'.quoteSlide' : [ 'top', '500px', '1000', 'easeOutElastic' ],
'.expand' : [ 'expand', '10%', '400', 'easeOutBounce' ],
'.textSlide h3' : [ 'top fade', '200px', '500', 'easeOutBounce' ],
'.textSlide img,.fade': [ 'fade' ],
'.textSlide li' : [ 'listLR' ]
});
});
* Note: Each definition should end with a comma except for the last - see examples above.
$(document).ready(function(){
$('#slider2') // Demo 2 code, using FX full control
.anythingSlider({
width : 600,
height : 350,
startStopped : true,
resizeContents : false,
navigationFormatter : function(i, panel){
return ['Recipe', 'Quote', 'Image', 'Quote #2', 'Image #2', 'Test'][i - 1];
}
})
.anythingSliderFx({
// base FX definitions can be mixed and matched in here too.
'.fade' : [ 'fade' ],
// for more precise control, use the "inFx" and "outFx" definitions
// inFx = the animation that occurs when you slide "in" to a panel
inFx : {
'.textSlide h3' : { opacity: 1, top : 0, time: 400, easing : 'easeOutBounce' },
'.textSlide li' : { opacity: 1, left : 0, time: 400 },
'.textSlide img' : { opacity: 1, time: 400 },
'.quoteSlide' : { top : 0, time: 400, easing : 'easeOutElastic' },
'.expand' : { width: '100%', top: '0%', left: '0%', time: 400, easing : 'easeOutBounce' }
},
// out = the animation that occurs when you slide "out" of a panel
// (it also occurs before the "in" animation)
outFx : {
'.textSlide h3' : { opacity: 0, top : '-100px', time: 350 },
'.textSlide li:odd' : { opacity: 0, left : '-200px', time: 350 },
'.textSlide li:even' : { opacity: 0, left : '200px', time: 350 },
'.textSlide img' : { opacity: 0, time: 350 },
'.quoteSlide:first' : { top : '-500px', time: 350 },
'.quoteSlide:last' : { top : '500px', time: 350 },
'.expand' : { width: '10%', top: '50%', left: '50%', time: 350 }
}
});
});
* Note: Each definition should end with a comma except for the last - see examples above.
<!-- jQuery -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
<!-- Anything Slider optional plugins -->
<script src="js/jquery.easing.1.2.js" type="text/javascript"></script>
<!-- http://ajax.googleapis.com/ajax/libs/swfobject/2.2/swfobject.js -->
<script src="js/swfobject.js" type="text/javascript"></script>
<!-- Anything Slider -->
<link href="css/anythingslider.css" type="text/css" rel="stylesheet" />
<script src="js/jquery.anythingslider.min.js" type="text/javascript"></script>
<!-- Anything Slider optional FX extension -->
<script src="js/jquery.anythingslider.fx.min.js" type="text/javascript"></script>
/* images with caption */
#slider3 img { width: 100%; height: 100%; }
/* position the panels so the captions appear correctly */
#slider3 .panel { position: relative; }
/* captions */
#slider3 .caption-top, #slider3 .caption-right,
#slider3 .caption-bottom, #slider3 .caption-left {
background: #000;
color: #fff;
padding: 10px;
margin: 0;
position: relative;
z-index: 10;
opacity: .8;
filter: alpha(opacity=80);
}
/* Top caption - padding is included in the width (480px here, 500px in the script), same for height */
#slider3 .caption-top {
left: 0;
top: 0;
width: 480px;
height: 30px;
}
/* Right caption - padding is included in the width (130px here, 150px in the script), same for height */
#slider3 .caption-right {
right: 0;
bottom: 0;
width: 130px;
height: 180px;
}
/* Bottom caption - padding is included in the width (480px here, 500px in the script), same for height */
#slider3 .caption-bottom {
left: 0;
bottom: 0;
width: 480px;
height: 30px;
}
/* Left caption - padding is included in the width (130px here, 150px in the script), same for height */
#slider3 .caption-left {
left: 0;
bottom: 0;
width: 130px;
height: 180px;
}
/* Caption close button */
.caption-top .close, .caption-right .close,
.caption-bottom .close, .caption-left .close {
font-size: 80%;
cursor: pointer;
float: right;
display: inline-block;
}
<ul id="slider3">
<li>
<!-- Note this caption is before the image, all others it is after -->
<div class="caption-top">
In Soviet Russia, concrete pours you!
</div>
<img src="images/slide-civil-1.jpg" alt="" />
</li>
<li>
<img src="images/slide-env-1.jpg" alt="" />
<div class="caption-right">
How many supervisors are there? Wrong! 5, who is taking the picture?
</div>
</li>
<li>
<img src="images/slide-civil-2.jpg" alt="" />
<div class="caption-bottom">
Alas, the pylon would never make it to the hydrant, her true love.
</div>
</li>
<li>
<img src="images/slide-env-2.jpg" alt="" />
<div class="caption-left">
Take a left at the traffic circle.
</div>
</li>
</ul>
$(document).ready(function(){
$('#slider3')
.anythingSlider({
width : 500,
height : 400,
startStopped : true
})
/* this code will make the caption appear when you hover over the panel
remove the extra statements if you don't have captions in that location */
.find('.panel')
.find('div[class*=caption]').css({ position: 'absolute' }).end()
.hover(function(){ showCaptions( $(this) ) }, function(){ hideCaptions( $(this) ); });
showCaptions = function(el){
var $this = el;
if ($this.find('.caption-top').length) {
$this.find('.caption-top')
.show()
.animate({ top: 0, opacity: 1 }, 400);
}
if ($this.find('.caption-right').length) {
$this.find('.caption-right')
.show()
.animate({ right: 0, opacity: 1 }, 400);
}
if ($this.find('.caption-bottom').length) {
$this.find('.caption-bottom')
.show()
.animate({ bottom: 0, opacity: 1 }, 400);
}
if ($this.find('.caption-left').length) {
$this.find('.caption-left')
.show()
.animate({ left: 0, opacity: 1 }, 400);
}
};
hideCaptions = function(el){
var $this = el;
if ($this.find('.caption-top').length) {
$this.find('.caption-top')
.stop()
.animate({ top: -50, opacity: 0 }, 350, function(){
$this.find('.caption-top').hide(); });
}
if ($this.find('.caption-right').length) {
$this.find('.caption-right')
.stop()
.animate({ right: -150, opacity: 0 }, 350, function(){
$this.find('.caption-right').hide(); });
}
if ($this.find('.caption-bottom').length) {
$this.find('.caption-bottom')
.stop()
.animate({ bottom: -50, opacity: 0 }, 350, function(){
$this.find('.caption-bottom').hide(); });
}
if ($this.find('.caption-left').length) {
$this.find('.caption-left')
.stop()
.animate({ left: -150, opacity: 0 }, 350, function(){
$this.find('.caption-left').hide(); });
}
};
// hide all captions initially
hideCaptions( $('#slider3 .panel') );
});
$(document).ready(function(){
$('#slider3')
.anythingSlider({
width : 500,
height : 400,
startStopped : true
})
.anythingSliderFx({
// '.selector' : [ 'caption', 'distance/size', 'time', 'easing' ]
// 'distance/size', 'time' and 'easing' are optional parameters
'.caption-top' : [ 'caption-Top', '50px' ],
'.caption-right' : [ 'caption-Right', '130px' ],
'.caption-bottom' : [ 'caption-Bottom', '50px' ],
'.caption-left' : [ 'caption-Left', '130px' ]
})
/* add a close button (x) to the caption */
.find('div[class*=caption]')
.css({ position: 'absolute' })
.prepend('<span class="close">x</span>')
.find('.close').click(function(){
var cap = $(this).parent(),
ani = { bottom : -50 }; // bottom
if (cap.is('.caption-top')) { ani = { top: -50 }; }
if (cap.is('.caption-left')) { ani = { left: -150 }; }
if (cap.is('.caption-right')) { ani = { right: -150 }; }
cap.animate(ani, 400, function(){ cap.hide(); } );
});
});
$(document).ready(function(){
$('#slider3')
.anythingSlider({
width : 500,
height : 400,
startStopped : true
})
/* this "custom" code is the equivalent of the base caption functions */
.anythingSliderFx({
inFx: {
'.caption-top' : { top: 0, opacity: 0.8, time: 400 },
'.caption-right' : { right: 0, opacity: 0.8, time: 400 },
'.caption-bottom' : { bottom: 0, opacity: 0.8, time: 400 },
'.caption-left' : { left: 0, opacity: 0.8, time: 400 }
},
outFx: {
'.caption-top' : { top: -50, opacity: 0, time: 350 },
'.caption-right' : { right: -150, opacity: 0, time: 350 },
'.caption-bottom' : { bottom: -50, opacity: 0, time: 350 },
'.caption-left' : { left: -150, opacity: 0, time: 350 }
}
})
/* add a close button (x) to the caption */
.find('div[class*=caption]')
.css({ position: 'absolute' })
.prepend('<span class="close">x</span>')
.find('.close').click(function(){
var cap = $(this).parent(),
ani = { bottom : -50 }; // bottom
if (cap.is('.caption-top')) { ani = { top: -50 }; }
if (cap.is('.caption-left')) { ani = { left: -150 }; }
if (cap.is('.caption-right')) { ani = { right: -150 }; }
cap.animate(ani, 400, function(){ cap.hide(); } );
});
});