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>
|
2013-12-02 18:36:12 +00:00
|
|
|
<link rel="stylesheet" href="../../themes/base/all.css">
|
2014-03-03 21:52:54 +00:00
|
|
|
<script src="../../jquery.js"></script>
|
2013-12-02 18:36:12 +00:00
|
|
|
<script src="../../ui/core.js"></script>
|
|
|
|
<script src="../../ui/widget.js"></script>
|
|
|
|
<script src="../../ui/position.js"></script>
|
2010-09-10 14:24:33 +00:00
|
|
|
<link rel="stylesheet" href="../demos.css">
|
2012-09-10 15:33:46 +00:00
|
|
|
<style>
|
2012-10-24 15:40:06 +00:00
|
|
|
body {
|
|
|
|
margin: 0;
|
|
|
|
}
|
2012-09-10 15:33:46 +00:00
|
|
|
#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 );
|
2013-08-11 21:45:33 +00:00
|
|
|
$( "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">
|
2012-10-24 15:40:06 +00:00
|
|
|
<p>A photoviewer prototype 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.
|
|
|
|
</div>
|
2009-07-24 18:24:13 +00:00
|
|
|
</body>
|
|
|
|
</html>
|