You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
		
		
			
		
	
	
			72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
| 
											11 years ago
										 | /* Flot plugin that adds some extra symbols for plotting points. | ||
|  | 
 | ||
|  | Copyright (c) 2007-2014 IOLA and Ole Laursen. | ||
|  | Licensed under the MIT license. | ||
|  | 
 | ||
|  | The symbols are accessed as strings through the standard symbol options: | ||
|  | 
 | ||
|  | 	series: { | ||
|  | 		points: { | ||
|  | 			symbol: "square" // or "diamond", "triangle", "cross"
 | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | */ | ||
|  | 
 | ||
|  | (function ($) { | ||
|  |     function processRawData(plot, series, datapoints) { | ||
|  |         // we normalize the area of each symbol so it is approximately the
 | ||
|  |         // same as a circle of the given radius
 | ||
|  | 
 | ||
|  |         var handlers = { | ||
|  |             square: function (ctx, x, y, radius, shadow) { | ||
|  |                 // pi * r^2 = (2s)^2  =>  s = r * sqrt(pi)/2
 | ||
|  |                 var size = radius * Math.sqrt(Math.PI) / 2; | ||
|  |                 ctx.rect(x - size, y - size, size + size, size + size); | ||
|  |             }, | ||
|  |             diamond: function (ctx, x, y, radius, shadow) { | ||
|  |                 // pi * r^2 = 2s^2  =>  s = r * sqrt(pi/2)
 | ||
|  |                 var size = radius * Math.sqrt(Math.PI / 2); | ||
|  |                 ctx.moveTo(x - size, y); | ||
|  |                 ctx.lineTo(x, y - size); | ||
|  |                 ctx.lineTo(x + size, y); | ||
|  |                 ctx.lineTo(x, y + size); | ||
|  |                 ctx.lineTo(x - size, y); | ||
|  |             }, | ||
|  |             triangle: function (ctx, x, y, radius, shadow) { | ||
|  |                 // pi * r^2 = 1/2 * s^2 * sin (pi / 3)  =>  s = r * sqrt(2 * pi / sin(pi / 3))
 | ||
|  |                 var size = radius * Math.sqrt(2 * Math.PI / Math.sin(Math.PI / 3)); | ||
|  |                 var height = size * Math.sin(Math.PI / 3); | ||
|  |                 ctx.moveTo(x - size/2, y + height/2); | ||
|  |                 ctx.lineTo(x + size/2, y + height/2); | ||
|  |                 if (!shadow) { | ||
|  |                     ctx.lineTo(x, y - height/2); | ||
|  |                     ctx.lineTo(x - size/2, y + height/2); | ||
|  |                 } | ||
|  |             }, | ||
|  |             cross: function (ctx, x, y, radius, shadow) { | ||
|  |                 // pi * r^2 = (2s)^2  =>  s = r * sqrt(pi)/2
 | ||
|  |                 var size = radius * Math.sqrt(Math.PI) / 2; | ||
|  |                 ctx.moveTo(x - size, y - size); | ||
|  |                 ctx.lineTo(x + size, y + size); | ||
|  |                 ctx.moveTo(x - size, y + size); | ||
|  |                 ctx.lineTo(x + size, y - size); | ||
|  |             } | ||
|  |         }; | ||
|  | 
 | ||
|  |         var s = series.points.symbol; | ||
|  |         if (handlers[s]) | ||
|  |             series.points.symbol = handlers[s]; | ||
|  |     } | ||
|  |      | ||
|  |     function init(plot) { | ||
|  |         plot.hooks.processDatapoints.push(processRawData); | ||
|  |     } | ||
|  |      | ||
|  |     $.plot.plugins.push({ | ||
|  |         init: init, | ||
|  |         name: 'symbols', | ||
|  |         version: '1.0' | ||
|  |     }); | ||
|  | })(jQuery); |