2012-08-26 22:21:15 +00:00
<!doctype html>
2009-07-24 18:24:13 +00:00
< html lang = "en" >
< head >
2010-09-10 14:24:33 +00:00
< meta charset = "utf-8" >
2012-10-08 21:42:56 +00:00
< title > jQuery UI Position - Image Cycler< / title >
2010-09-10 14:24:33 +00:00
< link rel = "stylesheet" href = "../../themes/base/jquery.ui.all.css" >
2012-09-21 01:41:47 +00:00
< script src = "../../jquery-1.8.2.js" > < / script >
2010-09-10 14:24:33 +00:00
< script src = "../../ui/jquery.ui.core.js" > < / script >
< script src = "../../ui/jquery.ui.widget.js" > < / script >
< script src = "../../ui/jquery.ui.position.js" > < / script >
< link rel = "stylesheet" href = "../demos.css" >
2012-09-10 15:33:46 +00:00
< style >
#container {
overflow: hidden;
position: relative;
height: 400px;
}
img {
position: absolute;
}
< / style >
2010-09-10 14:24:33 +00:00
< script >
2009-07-24 18:24:13 +00:00
$(function() {
2012-02-23 13:26:47 +00:00
// TODO refactor into a widget and get rid of these plugin methods
2010-09-10 14:24:33 +00:00
$.fn.left = function( using ) {
2012-08-26 22:21:15 +00:00
return this.position({
2009-07-24 18:24:13 +00:00
my: "right middle",
2011-03-22 16:25:25 +00:00
at: "left+25 middle",
2012-09-10 15:33:46 +00:00
of: "#container",
2012-08-26 22:21:15 +00:00
collision: "none",
2010-01-07 03:19:50 +00:00
using: using
2009-07-24 18:24:13 +00:00
});
2012-08-26 22:21:15 +00:00
};
2010-09-10 14:24:33 +00:00
$.fn.right = function( using ) {
2012-08-26 22:21:15 +00:00
return this.position({
2009-07-24 18:24:13 +00:00
my: "left middle",
2011-03-22 16:25:25 +00:00
at: "right-25 middle",
2012-09-10 15:33:46 +00:00
of: "#container",
2012-08-26 22:21:15 +00:00
collision: "none",
2010-01-07 03:19:50 +00:00
using: using
2009-07-24 18:24:13 +00:00
});
2012-08-26 22:21:15 +00:00
};
2010-09-10 14:24:33 +00:00
$.fn.center = function( using ) {
2012-08-26 22:21:15 +00:00
return this.position({
2009-07-24 18:24:13 +00:00
my: "center middle",
at: "center middle",
2012-09-10 15:33:46 +00:00
of: "#container",
2010-01-07 03:19:50 +00:00
using: using
2009-07-24 18:24:13 +00:00
});
};
2010-09-10 14:24:33 +00:00
2012-02-23 13:26:47 +00:00
$( "img:eq(0)" ).left();
$( "img:eq(1)" ).center();
$( "img:eq(2)" ).right();
2010-09-10 14:24:33 +00:00
function animate( to ) {
2012-08-26 22:21:15 +00:00
$( this ).stop( true, false ).animate( to );
2009-07-24 18:24:13 +00:00
}
2012-02-23 13:26:47 +00:00
function next( event ) {
event.preventDefault();
2010-09-10 14:24:33 +00:00
$( "img:eq(2)" ).center( animate );
$( "img:eq(1)" ).left( animate )
2012-09-10 15:33:46 +00:00
$( "img:eq(0)" ).right().appendTo( "#container" );
2009-07-24 18:24:13 +00:00
}
2012-02-23 13:26:47 +00:00
function previous( event ) {
event.preventDefault();
2010-09-10 14:24:33 +00:00
$( "img:eq(0)" ).center( animate );
$( "img:eq(1)" ).right( animate );
2012-09-10 15:33:46 +00:00
$( "img:eq(2)" ).left().prependTo( "#container" );
2009-07-24 18:24:13 +00:00
}
2010-09-10 14:24:33 +00:00
$( "#previous" ).click( previous );
$( "#next" ).click( next );
2012-09-10 15:33:46 +00:00
$( "img" ).click(function( event ) {
$( "img" ).index( this ) === 0 ? previous( event ) : next( event );
2010-09-10 14:24:33 +00:00
});
$( window ).resize(function() {
$( "img:eq(0)" ).left( animate );
$( "img:eq(1)" ).center( animate );
$( "img:eq(2)" ).right( animate );
2009-07-24 18:24:13 +00:00
});
});
< / script >
< / head >
< body >
2012-09-10 15:33:46 +00:00
< div id = "container" >
< img src = "images/earth.jpg" width = "458" height = "308" alt = "earth" >
< img src = "images/flight.jpg" width = "512" height = "307" alt = "flight" >
< img src = "images/rocket.jpg" width = "300" height = "353" alt = "rocket" >
2009-07-24 18:24:13 +00:00
2012-09-10 15:33:46 +00:00
< a id = "previous" href = "#" > Previous< / a >
< a id = "next" href = "#" > Next< / a >
< / div >
2010-09-10 14:24:33 +00:00
< div class = "demo-description" >
2009-07-24 18:24:13 +00:00
< p > A prototype for the < a href = "http://wiki.jqueryui.com/Photoviewer" > Photoviewer< / a > using Position to place images at the center, left and right and cycle them.
2012-09-10 15:33:46 +00:00
< br > Use the links at the top to cycle, or click on the images on the left and right.
< br > Note how the images are repositioned when resizing the window.
< br > Warning: Doesn't currently work inside the demo viewer; open in a new window instead!< / p >
< / div >
2009-07-24 18:24:13 +00:00
< / body >
< / html >