mirror of
				https://github.com/dawidolko/Website-Templates.git
				synced 2025-10-31 08:23:12 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			154 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
 | |
| <html>
 | |
| <head>
 | |
| 	<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 | |
| 	<title>Flot Examples: Navigation</title>
 | |
| 	<link href="../examples.css" rel="stylesheet" type="text/css">
 | |
| 	<style type="text/css">
 | |
| 
 | |
| 	#placeholder .button {
 | |
| 		position: absolute;
 | |
| 		cursor: pointer;
 | |
| 	}
 | |
| 
 | |
| 	#placeholder div.button {
 | |
| 		font-size: smaller;
 | |
| 		color: #999;
 | |
| 		background-color: #eee;
 | |
| 		padding: 2px;
 | |
| 	}
 | |
| 	.message {
 | |
| 		padding-left: 50px;
 | |
| 		font-size: smaller;
 | |
| 	}
 | |
| 
 | |
| 	</style>
 | |
| 	<!--[if lte IE 8]><script language="javascript" type="text/javascript" src="../../excanvas.min.js"></script><![endif]-->
 | |
| 	<script language="javascript" type="text/javascript" src="../../jquery.js"></script>
 | |
| 	<script language="javascript" type="text/javascript" src="../../jquery.flot.js"></script>
 | |
| 	<script language="javascript" type="text/javascript" src="../../jquery.flot.navigate.js"></script>
 | |
| 	<script type="text/javascript">
 | |
| 
 | |
| 	$(function() {
 | |
| 
 | |
| 		// generate data set from a parametric function with a fractal look
 | |
| 
 | |
| 		function sumf(f, t, m) {
 | |
| 			var res = 0;
 | |
| 			for (var i = 1; i < m; ++i) {
 | |
| 				res += f(i * i * t) / (i * i);
 | |
| 			}
 | |
| 			return res;
 | |
| 		}
 | |
| 
 | |
| 		var d1 = [];
 | |
| 		for (var t = 0; t <= 2 * Math.PI; t += 0.01) {
 | |
| 			d1.push([sumf(Math.cos, t, 10), sumf(Math.sin, t, 10)]);
 | |
| 		}
 | |
| 
 | |
| 		var data = [ d1 ],
 | |
| 			placeholder = $("#placeholder");
 | |
| 
 | |
| 		var plot = $.plot(placeholder, data, {
 | |
| 			series: {
 | |
| 				lines: {
 | |
| 					show: true
 | |
| 				},
 | |
| 				shadowSize: 0
 | |
| 			},
 | |
| 			xaxis: {
 | |
| 				zoomRange: [0.1, 10],
 | |
| 				panRange: [-10, 10]
 | |
| 			},
 | |
| 			yaxis: {
 | |
| 				zoomRange: [0.1, 10],
 | |
| 				panRange: [-10, 10]
 | |
| 			},
 | |
| 			zoom: {
 | |
| 				interactive: true
 | |
| 			},
 | |
| 			pan: {
 | |
| 				interactive: true
 | |
| 			}
 | |
| 		});
 | |
| 
 | |
| 		// show pan/zoom messages to illustrate events 
 | |
| 
 | |
| 		placeholder.bind("plotpan", function (event, plot) {
 | |
| 			var axes = plot.getAxes();
 | |
| 			$(".message").html("Panning to x: "  + axes.xaxis.min.toFixed(2)
 | |
| 			+ " – " + axes.xaxis.max.toFixed(2)
 | |
| 			+ " and y: " + axes.yaxis.min.toFixed(2)
 | |
| 			+ " – " + axes.yaxis.max.toFixed(2));
 | |
| 		});
 | |
| 
 | |
| 		placeholder.bind("plotzoom", function (event, plot) {
 | |
| 			var axes = plot.getAxes();
 | |
| 			$(".message").html("Zooming to x: "  + axes.xaxis.min.toFixed(2)
 | |
| 			+ " – " + axes.xaxis.max.toFixed(2)
 | |
| 			+ " and y: " + axes.yaxis.min.toFixed(2)
 | |
| 			+ " – " + axes.yaxis.max.toFixed(2));
 | |
| 		});
 | |
| 
 | |
| 		// add zoom out button 
 | |
| 
 | |
| 		$("<div class='button' style='right:20px;top:20px'>zoom out</div>")
 | |
| 			.appendTo(placeholder)
 | |
| 			.click(function (event) {
 | |
| 				event.preventDefault();
 | |
| 				plot.zoomOut();
 | |
| 			});
 | |
| 
 | |
| 		// and add panning buttons
 | |
| 
 | |
| 		// little helper for taking the repetitive work out of placing
 | |
| 		// panning arrows
 | |
| 
 | |
| 		function addArrow(dir, right, top, offset) {
 | |
| 			$("<img class='button' src='arrow-" + dir + ".gif' style='right:" + right + "px;top:" + top + "px'>")
 | |
| 				.appendTo(placeholder)
 | |
| 				.click(function (e) {
 | |
| 					e.preventDefault();
 | |
| 					plot.pan(offset);
 | |
| 				});
 | |
| 		}
 | |
| 
 | |
| 		addArrow("left", 55, 60, { left: -100 });
 | |
| 		addArrow("right", 25, 60, { left: 100 });
 | |
| 		addArrow("up", 40, 45, { top: -100 });
 | |
| 		addArrow("down", 40, 75, { top: 100 });
 | |
| 
 | |
| 		// Add the Flot version string to the footer
 | |
| 
 | |
| 		$("#footer").prepend("Flot " + $.plot.version + " – ");
 | |
| 	});
 | |
| 
 | |
| 	</script>
 | |
| </head>
 | |
| <body>
 | |
| 
 | |
| 	<div id="header">
 | |
| 		<h2>Navigation</h2>
 | |
| 	</div>
 | |
| 
 | |
| 	<div id="content">
 | |
| 
 | |
| 		<div class="demo-container">
 | |
| 			<div id="placeholder" class="demo-placeholder"></div>
 | |
| 		</div>
 | |
| 
 | |
| 		<p class="message"></p>
 | |
| 
 | |
| 		<p>With the navigate plugin it is easy to add panning and zooming. Drag to pan, double click to zoom (or use the mouse scrollwheel).</p>
 | |
| 
 | |
| 		<p>The plugin fires events (useful for synchronizing several plots) and adds a couple of public methods so you can easily build a little user interface around it, like the little buttons at the top right in the plot.</p>
 | |
| 
 | |
| 	</div>
 | |
| 
 | |
| 	<div id="footer">
 | |
| 		Copyright © 2007 - 2014 IOLA and Ole Laursen
 | |
| 	</div>
 | |
| 
 | |
| </body>
 | |
| </html>
 |