| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | 
							- /* 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);
 
 
  |