Blame view

assets/plugins/flot/jquery.flot.symbol.js 2.45 KB
cf76164e6   Ting Chan   20190709
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
  /* 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);