src/cm/media/js/lib/yui/yui3-3.15.0/build/series-curve-util/series-curve-util-debug.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 602 e16a97fb364a
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('series-curve-util', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
 * Provides functionality for drawing curves in a series.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
 * @module charts
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
 * @submodule series-curve-util
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
 * Utility class used for calculating curve points.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
 * @class CurveUtil
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
 * @submodule series-curve-util
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
function CurveUtil()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
CurveUtil.prototype = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
     * Creates an array of start, end and control points for splines.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
     * @method getCurveControlPoints
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
     * @param {Array} xcoords Collection of x-coordinates used for calculate the curves
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
     * @param {Array} ycoords Collection of y-coordinates used for calculate the curves
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
     * @return Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
    getCurveControlPoints: function(xcoords, ycoords)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
		var outpoints = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
            i = 1,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
            l = xcoords.length - 1,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
            xvals = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
            yvals = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
		// Too few points, need at least two
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
		if (l < 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
			return null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
        outpoints[0] = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
            startx: xcoords[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
            starty: ycoords[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
            endx: xcoords[1],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
            endy: ycoords[1]
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
        };
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
		// Special case, the Bezier should be a straight line
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
        if (l === 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
			outpoints[0].ctrlx1 = (2.0*xcoords[0] + xcoords[1])/3.0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
			outpoints[0].ctrly2 = (2.0*ycoords[0] + ycoords[1])/3.0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
			outpoints[0].ctrlx2 = 2.0*outpoints[0].ctrlx1 - xcoords[0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
            outpoints[0].ctrly2 = 2.0*outpoints[0].ctrly1 - ycoords[0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
            return outpoints;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
		for (; i < l; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
			outpoints.push({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
                startx: Math.round(xcoords[i]),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
                starty: Math.round(ycoords[i]),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
                endx: Math.round(xcoords[i+1]),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
                endy: Math.round(ycoords[i+1])
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
            });
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
			xvals[i] = 4.0 * xcoords[i] + 2*xcoords[i+1];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
			yvals[i] = 4.0*ycoords[i] + 2*ycoords[i+1];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
		xvals[0] = xcoords[0] + (2.0 * xcoords[1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
		xvals[l-1] = (8.0 * xcoords[l-1] + xcoords[l]) / 2.0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
		xvals = this.getControlPoints(xvals.concat());
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
        yvals[0] = ycoords[0] + (2.0 * ycoords[1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
		yvals[l-1] = (8.0 * ycoords[l-1] + ycoords[l]) / 2.0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
		yvals = this.getControlPoints(yvals.concat());
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
        for (i = 0; i < l; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
			outpoints[i].ctrlx1 = Math.round(xvals[i]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
            outpoints[i].ctrly1 = Math.round(yvals[i]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
			if (i < l-1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
				outpoints[i].ctrlx2 = Math.round(2*xcoords[i+1] - xvals[i+1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
                outpoints[i].ctrly2 = Math.round(2*ycoords[i+1] - yvals[i+1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
			else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
				outpoints[i].ctrlx2 = Math.round((xcoords[l] + xvals[l-1])/2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
                outpoints[i].ctrly2 = Math.round((ycoords[l] + yvals[l-1])/2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
		return outpoints;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
     * Gets the control points for the curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
     * @method getControlPoints
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
     * @param {Array} vals Collection of values coords used to generate control points.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
     * @return Array
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
	getControlPoints: function(vals)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
		var l = vals.length,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
            x = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
            tmp = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
            b = 2.0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
            i = 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
		x[0] = vals[0] / b;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
		for (; i < l; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
			tmp[i] = 1/b;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
			b = (i < l-1 ? 4.0 : 3.5) - tmp[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
			x[i] = (vals[i] - x[i-1]) / b;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
		for (i = 1; i < l; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
			x[l-i-1] -= tmp[l-i] * x[l-i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
		return x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
Y.CurveUtil = CurveUtil;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
}, '@VERSION@');