aboutsummaryrefslogtreecommitdiffstats
path: root/demos/position/cycler.html
blob: 910b0050cfab2193cfe144edf03b8450ffab530d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<!doctype html>
<html lang="en">
<head>
	<meta charset="utf-8">
	<meta name="viewport" content="width=device-width, initial-scale=1">
	<title>jQuery UI Position - Image Cycler</title>
	<link rel="stylesheet" href="../../themes/base/all.css">
	<link rel="stylesheet" href="../demos.css">
	<style>
	body {
		margin: 0;
	}
	#container {
		overflow: hidden;
		position: relative;
		height: 400px;
	}

	img {
		position: absolute;
	}
	</style>
	<script src="../../external/requirejs/require.js"></script>
	<script src="../bootstrap.js">
		function left( element, using ) {
			element.position({
				my: "right middle",
				at: "left+25 middle",
				of: "#container",
				collision: "none",
				using: using
			});
		}
		function right( element, using ) {
			element.position({
				my: "left middle",
				at: "right-25 middle",
				of: "#container",
				collision: "none",
				using: using
			});
		}
		function center( element, using ) {
			element.position({
				my: "center middle",
				at: "center middle",
				of: "#container",
				using: using
			});
		}

		left( $( "img:eq(0)" ) );
		center( $( "img:eq(1)" ) );
		right( $( "img:eq(2)" ) );

		function animate( to ) {
			$( 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 );

		$( "img" ).on( "click", function( event ) {
			$( "img" ).index( this ) === 0 ? previous( event ) : next( event );
		});

		$( window ).on( "resize", function() {
			left( $( "img:eq(0)" ), animate );
			center( $( "img:eq(1)" ), animate );
			right( $( "img:eq(2)" ), animate );
		});
	</script>
</head>
<body>

<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">

	<a id="previous" href="#">Previous</a>
	<a id="next" href="#">Next</a>
</div>

<div class="demo-description">
<p>A photoviewer prototype 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.
</div>
</body>
</html>