jquery-ui/demos/position/cycler.html

124 lines
3.1 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html lang="en">
<head>
2010-09-10 14:24:33 +00:00
<meta charset="utf-8">
<title>jQuery UI Position - Default functionality</title>
2010-09-10 14:24:33 +00:00
<link rel="stylesheet" href="../../themes/base/jquery.ui.all.css">
2012-08-13 13:19:09 +00:00
<script src="../../jquery-1.8.0.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">
<style>
html, body {
margin: 0;
padding: 0
}
</style>
2010-09-10 14:24:33 +00:00
<script>
$(function() {
// TODO refactor into a widget and get rid of these plugin methods
2010-09-10 14:24:33 +00:00
$.fn.position2 = function( options ) {
return this.position( $.extend({
of: window,
2010-09-10 14:24:33 +00:00
using: function( to ) {
$( this ).css({
top: to.top,
left: to.left
})
},
collision: "none"
}, options));
}
2010-09-10 14:24:33 +00:00
$.fn.left = function( using ) {
return this.position2({
my: "right middle",
at: "left+25 middle",
using: using
});
}
2010-09-10 14:24:33 +00:00
$.fn.right = function( using ) {
return this.position2({
my: "left middle",
at: "right-25 middle",
using: using
});
}
2010-09-10 14:24:33 +00:00
$.fn.center = function( using ) {
return this.position2({
my: "center middle",
at: "center middle",
using: using
});
};
2010-09-10 14:24:33 +00:00
$( "body" ).css({
overflow: "hidden"
})
2010-09-10 14:24:33 +00:00
$( ".demo" ).css({
position: "relative",
});
2010-09-10 14:24:33 +00:00
$( ".demo img" ).css({
position: "absolute",
});
2010-09-10 14:24:33 +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 ) {
$(this).stop( true, false ).animate( to );
}
function next( event ) {
event.preventDefault();
2010-09-10 14:24:33 +00:00
$( "img:eq(2)" ).center( animate );
$( "img:eq(1)" ).left( animate )
$( "img:eq(0)" ).right().appendTo( ".demo" );
}
function previous( event ) {
event.preventDefault();
2010-09-10 14:24:33 +00:00
$( "img:eq(0)" ).center( animate );
$( "img:eq(1)" ).right( animate );
$( "img:eq(2)" ).left().prependTo( ".demo" );
}
2010-09-10 14:24:33 +00:00
$( "#previous" ).click( previous );
$( "#next" ).click( next );
$( ".demo img" ).click(function( event ) {
$( ".demo 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 );
});
});
</script>
</head>
<body>
<div class="demo">
<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" />
2010-09-10 14:24:33 +00:00
<a id="previous" href="#">Previous</a>
<a id="next" href="#">Next</a>
</div><!-- End demo -->
2010-09-10 14:24:33 +00:00
<div class="demo-description">
<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.
<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><!-- End demo-description -->
</body>
</html>