HOME


Mini Shell 1.0
DIR: /home/islapiiu/sites/faithlinkint/control-panel/plugins/flot-charts/
Upload File :
Current File : /home/islapiiu/sites/faithlinkint/control-panel/plugins/flot-charts/jquery.flot.symbol.js
/* 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);