jquery-ui/demos/position/cycler.html

107 lines
2.6 KiB
HTML
Raw Normal View History

2012-08-26 22:21:15 +00:00
<!doctype html>
<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>
<link rel="stylesheet" href="../../themes/base/all.css">
<script src="../../external/jquery/jquery.js"></script>
<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>
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>
$(function() {
function left( element, using ) {
element.position({
my: "right middle",
at: "left+25 middle",
2012-09-10 15:33:46 +00:00
of: "#container",
2012-08-26 22:21:15 +00:00
collision: "none",
using: using
});
}
function right( element, using ) {
element.position({
my: "left middle",
at: "right-25 middle",
2012-09-10 15:33:46 +00:00
of: "#container",
2012-08-26 22:21:15 +00:00
collision: "none",
using: using
});
}
function center( element, using ) {
element.position({
my: "center middle",
at: "center middle",
2012-09-10 15:33:46 +00:00
of: "#container",
using: using
});
}
2010-09-10 14:24:33 +00:00
left( $( "img:eq(0)" ) );
center( $( "img:eq(1)" ) );
right( $( "img:eq(2)" ) );
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 );
}
function next( event ) {
event.preventDefault();
center( $( "img:eq(2)" ), animate );
left( $( "img:eq(1)" ), animate );
right( $( "img:eq(0)" ).appendTo( "#container" ) );
}
function previous( event ) {
event.preventDefault();
center( $( "img:eq(0)" ), animate );
right( $( "img:eq(1)" ), animate );
left( $( "img:eq(2)" ).prependTo( "#container" ) );
}
$( "#previous" ).on( "click", previous );
$( "#next" ).on( "click", next );
2010-09-10 14:24:33 +00:00
$( "img" ).on( "click", function( event ) {
2012-09-10 15:33:46 +00:00
$( "img" ).index( this ) === 0 ? previous( event ) : next( event );
2010-09-10 14:24:33 +00:00
});
$( window ).on( "resize", function() {
left( $( "img:eq(0)" ), animate );
center( $( "img:eq(1)" ), animate );
right( $( "img:eq(2)" ), animate );
});
});
</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">
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">
<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>
</body>
</html>