src/cm/media/js/lib/yui/yui3-3.15.0/build/graphics-canvas/graphics-canvas-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('graphics-canvas', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
var IMPLEMENTATION = "canvas",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
    SHAPE = "shape",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
	SPLITPATHPATTERN = /[a-z][^a-z]*/ig,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
    SPLITARGSPATTERN = /[\-]?[0-9]*[0-9|\.][0-9]*/g,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
    DOCUMENT = Y.config.doc,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
    Y_LANG = Y.Lang,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
    AttributeLite = Y.AttributeLite,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
	CanvasShape,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
	CanvasPath,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
	CanvasRect,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
    CanvasEllipse,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
	CanvasCircle,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
    CanvasPieSlice,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
    Y_DOM = Y.DOM,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
    Y_Color = Y.Color,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
    PARSE_INT = parseInt,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
    PARSE_FLOAT = parseFloat,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
    IS_NUMBER = Y_LANG.isNumber,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
    RE = RegExp,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
    TORGB = Y_Color.toRGB,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
    TOHEX = Y_Color.toHex,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
    _getClassName = Y.ClassNameManager.getClassName;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Drawing.html">`Drawing`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
 * `CanvasDrawing` is not intended to be used directly. Instead, use the <a href="Drawing.html">`Drawing`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Drawing.html">`Drawing`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
 * class will point to the `CanvasDrawing` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
 * @class CanvasDrawing
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
function CanvasDrawing()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
CanvasDrawing.prototype = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
     * Maps path to methods
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
     * @property _pathSymbolToMethod
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
     * @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
    _pathSymbolToMethod: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
        M: "moveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
        m: "relativeMoveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
        L: "lineTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
        l: "relativeLineTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
        C: "curveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
        c: "relativeCurveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
        Q: "quadraticCurveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
        q: "relativeQuadraticCurveTo",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
        z: "closePath",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
        Z: "closePath"
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
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
     * Current x position of the drawing.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
     * @property _currentX
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
    _currentX: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
     * Current y position of the drqwing.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
     * @property _currentY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
    _currentY: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
     * Parses hex color string and alpha value to rgba
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
     * @method _toRGBA
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
     * @param {Object} val Color value to parse. Can be hex string, rgb or name.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
     * @param {Number} alpha Numeric value between 0 and 1 representing the alpha level.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
    _toRGBA: function(val, alpha) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
        alpha = (alpha !== undefined) ? alpha : 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
        if (!Y_Color.re_RGB.test(val)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
            val = TOHEX(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
        if(Y_Color.re_hex.exec(val)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
            val = 'rgba(' + [
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
                PARSE_INT(RE.$1, 16),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
                PARSE_INT(RE.$2, 16),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
                PARSE_INT(RE.$3, 16)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
            ].join(',') + ',' + alpha + ')';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
        return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
     * Converts color to rgb format
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
     * @method _toRGB
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
     * @param val Color value to convert.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
    _toRGB: function(val) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
        return TORGB(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
     * Sets the size of the graphics object.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
     * @method setSize
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
     * @param w {Number} width to set for the instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
     * @param h {Number} height to set for the instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
	setSize: function(w, h) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
        if(this.get("autoSize"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
            if(w > this.node.getAttribute("width"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
                this.node.style.width = w + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
                this.node.setAttribute("width", w);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
            if(h > this.node.getAttribute("height"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
                this.node.style.height = h + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
                this.node.setAttribute("height", h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   136
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   137
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   138
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   139
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   140
     * Tracks coordinates. Used to calculate the start point of dashed lines.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   141
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   142
     * @method _updateCoords
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   143
     * @param {Number} x x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   144
     * @param {Number} y y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   145
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   146
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   147
    _updateCoords: function(x, y)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   148
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   149
        this._xcoords.push(x);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   150
        this._ycoords.push(y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   151
        this._currentX = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   152
        this._currentY = y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   153
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   154
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   155
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   156
     * Clears the coordinate arrays. Called at the end of a drawing operation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   157
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   158
     * @method _clearAndUpdateCoords
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   159
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   160
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   161
    _clearAndUpdateCoords: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   162
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   163
        var x = this._xcoords.pop() || 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   164
            y = this._ycoords.pop() || 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   165
        this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   166
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   167
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   168
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   169
     * Moves the shape's dom node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   170
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   171
     * @method _updateNodePosition
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   172
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   173
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   174
    _updateNodePosition: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   175
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   176
        var node = this.get("node"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   177
            x = this.get("x"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   178
            y = this.get("y");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   179
        node.style.position = "absolute";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   180
        node.style.left = (x + this._left) + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   181
        node.style.top = (y + this._top) + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   182
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   183
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   184
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   185
     * Queues up a method to be executed when a shape redraws.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   186
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   187
     * @method _updateDrawingQueue
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   188
     * @param {Array} val An array containing data that can be parsed into a method and arguments. The value at zero-index
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   189
     * of the array is a string reference of the drawing method that will be called. All subsequent indices are argument for
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   190
     * that method. For example, `lineTo(10, 100)` would be structured as:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   191
     * `["lineTo", 10, 100]`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   192
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   193
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   194
    _updateDrawingQueue: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   195
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   196
        this._methods.push(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   197
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   198
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   199
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   200
     * Draws a line segment from the current drawing position to the specified x and y coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   201
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   202
     * @method lineTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   203
     * @param {Number} point1 x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   204
     * @param {Number} point2 y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   205
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   206
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   207
    lineTo: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   208
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   209
        this._lineTo.apply(this, [Y.Array(arguments), false]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   210
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   211
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   212
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   213
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   214
     * Draws a line segment from the current drawing position to the relative x and y coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   215
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   216
     * @method relativeLineTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   217
     * @param {Number} point1 x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   218
     * @param {Number} point2 y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   219
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   220
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   221
    relativeLineTo: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   222
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   223
        this._lineTo.apply(this, [Y.Array(arguments), true]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   224
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   225
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   226
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   227
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   228
     * Implements lineTo methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   229
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   230
     * @method _lineTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   231
     * @param {Array} args The arguments to be used.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   232
     * @param {Boolean} relative Indicates whether or not to use relative coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   233
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   234
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   235
    _lineTo: function(args, relative)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   236
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   237
        var point1 = args[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   238
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   239
            len,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   240
            x,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   241
            y,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   242
            wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   243
            relativeX = relative ? parseFloat(this._currentX) : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   244
            relativeY = relative ? parseFloat(this._currentY) : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   245
        if(!this._lineToMethods)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   246
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   247
            this._lineToMethods = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   248
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   249
        len = args.length - 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   250
        if (typeof point1 === 'string' || typeof point1 === 'number') {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   251
            for (i = 0; i < len; i = i + 2) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   252
                x = parseFloat(args[i]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   253
                y = parseFloat(args[i + 1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   254
                x = x + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   255
                y = y + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   256
                this._updateDrawingQueue(["lineTo", x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   257
                this._trackSize(x - wt, y - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   258
                this._trackSize(x + wt, y + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   259
                this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   260
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   261
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   262
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   263
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   264
            for (i = 0; i < len; i = i + 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   265
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   266
                x = parseFloat(args[i][0]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   267
                y = parseFloat(args[i][1]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   268
                this._updateDrawingQueue(["lineTo", x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   269
                this._lineToMethods[this._lineToMethods.length] = this._methods[this._methods.length - 1];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   270
                this._trackSize(x - wt, y - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   271
                this._trackSize(x + wt, y + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   272
                this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   273
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   274
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   275
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   276
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   277
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   278
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   279
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   280
     * Moves the current drawing position to specified x and y coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   281
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   282
     * @method moveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   283
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   284
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   285
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   286
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   287
    moveTo: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   288
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   289
        this._moveTo.apply(this, [Y.Array(arguments), false]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   290
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   291
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   292
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   293
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   294
     * Moves the current drawing position relative to specified x and y coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   295
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   296
     * @method relativeMoveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   297
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   298
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   299
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   300
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   301
    relativeMoveTo: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   302
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   303
        this._moveTo.apply(this, [Y.Array(arguments), true]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   304
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   305
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   306
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   307
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   308
     * Implements moveTo methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   309
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   310
     * @method _moveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   311
     * @param {Array} args The arguments to be used.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   312
     * @param {Boolean} relative Indicates whether or not to use relative coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   313
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   314
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   315
    _moveTo: function(args, relative) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   316
        var wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   317
            relativeX = relative ? parseFloat(this._currentX) : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   318
            relativeY = relative ? parseFloat(this._currentY) : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   319
            x = parseFloat(args[0]) + relativeX,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   320
            y = parseFloat(args[1]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   321
        this._updateDrawingQueue(["moveTo", x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   322
        this._trackSize(x - wt, y - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   323
        this._trackSize(x + wt, y + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   324
        this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   325
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   326
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   327
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   328
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   329
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   330
     * Draws a bezier curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   331
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   332
     * @method curveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   333
     * @param {Number} cp1x x-coordinate for the first control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   334
     * @param {Number} cp1y y-coordinate for the first control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   335
     * @param {Number} cp2x x-coordinate for the second control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   336
     * @param {Number} cp2y y-coordinate for the second control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   337
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   338
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   339
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   340
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   341
    curveTo: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   342
        this._curveTo.apply(this, [Y.Array(arguments), false]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   343
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   344
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   345
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   346
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   347
     * Draws a bezier curve relative to the current coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   348
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   349
     * @method relativeCurveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   350
     * @param {Number} cp1x x-coordinate for the first control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   351
     * @param {Number} cp1y y-coordinate for the first control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   352
     * @param {Number} cp2x x-coordinate for the second control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   353
     * @param {Number} cp2y y-coordinate for the second control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   354
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   355
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   356
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   357
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   358
    relativeCurveTo: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   359
        this._curveTo.apply(this, [Y.Array(arguments), true]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   360
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   361
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   362
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   363
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   364
     * Implements curveTo methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   365
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   366
     * @method _curveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   367
     * @param {Array} args The arguments to be used.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   368
     * @param {Boolean} relative Indicates whether or not to use relative coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   369
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   370
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   371
    _curveTo: function(args, relative) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   372
        var w,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   373
            h,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   374
            cp1x,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   375
            cp1y,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   376
            cp2x,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   377
            cp2y,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   378
            x,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   379
            y,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   380
            pts,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   381
            right,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   382
            left,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   383
            bottom,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   384
            top,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   385
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   386
            len,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   387
            relativeX = relative ? parseFloat(this._currentX) : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   388
            relativeY = relative ? parseFloat(this._currentY) : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   389
        len = args.length - 5;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   390
        for(i = 0; i < len; i = i + 6)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   391
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   392
            cp1x = parseFloat(args[i]) + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   393
            cp1y = parseFloat(args[i + 1]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   394
            cp2x = parseFloat(args[i + 2]) + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   395
            cp2y = parseFloat(args[i + 3]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   396
            x = parseFloat(args[i + 4]) + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   397
            y = parseFloat(args[i + 5]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   398
            this._updateDrawingQueue(["bezierCurveTo", cp1x, cp1y, cp2x, cp2y, x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   399
            this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   400
            right = Math.max(x, Math.max(cp1x, cp2x));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   401
            bottom = Math.max(y, Math.max(cp1y, cp2y));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   402
            left = Math.min(x, Math.min(cp1x, cp2x));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   403
            top = Math.min(y, Math.min(cp1y, cp2y));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   404
            w = Math.abs(right - left);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   405
            h = Math.abs(bottom - top);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   406
            pts = [[this._currentX, this._currentY] , [cp1x, cp1y], [cp2x, cp2y], [x, y]];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   407
            this._setCurveBoundingBox(pts, w, h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   408
            this._currentX = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   409
            this._currentY = y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   410
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   411
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   412
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   413
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   414
     * Draws a quadratic bezier curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   415
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   416
     * @method quadraticCurveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   417
     * @param {Number} cpx x-coordinate for the control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   418
     * @param {Number} cpy y-coordinate for the control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   419
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   420
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   421
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   422
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   423
    quadraticCurveTo: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   424
        this._quadraticCurveTo.apply(this, [Y.Array(arguments), false]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   425
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   426
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   427
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   428
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   429
     * Draws a quadratic bezier curve relative to the current position.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   430
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   431
     * @method relativeQuadraticCurveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   432
     * @param {Number} cpx x-coordinate for the control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   433
     * @param {Number} cpy y-coordinate for the control point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   434
     * @param {Number} x x-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   435
     * @param {Number} y y-coordinate for the end point.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   436
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   437
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   438
    relativeQuadraticCurveTo: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   439
        this._quadraticCurveTo.apply(this, [Y.Array(arguments), true]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   440
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   441
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   442
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   443
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   444
     * Implements quadraticCurveTo methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   445
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   446
     * @method _quadraticCurveTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   447
     * @param {Array} args The arguments to be used.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   448
     * @param {Boolean} relative Indicates whether or not to use relative coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   449
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   450
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   451
    _quadraticCurveTo: function(args, relative) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   452
        var cpx,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   453
            cpy,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   454
            x,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   455
            y,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   456
            w,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   457
            h,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   458
            pts,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   459
            right,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   460
            left,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   461
            bottom,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   462
            top,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   463
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   464
            len = args.length - 3,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   465
            relativeX = relative ? parseFloat(this._currentX) : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   466
            relativeY = relative ? parseFloat(this._currentY) : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   467
        for(i = 0; i < len; i = i + 4)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   468
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   469
            cpx = parseFloat(args[i]) + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   470
            cpy = parseFloat(args[i + 1]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   471
            x = parseFloat(args[i + 2]) + relativeX;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   472
            y = parseFloat(args[i + 3]) + relativeY;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   473
            this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   474
            right = Math.max(x, cpx);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   475
            bottom = Math.max(y, cpy);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   476
            left = Math.min(x, cpx);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   477
            top = Math.min(y, cpy);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   478
            w = Math.abs(right - left);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   479
            h = Math.abs(bottom - top);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   480
            pts = [[this._currentX, this._currentY] , [cpx, cpy], [x, y]];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   481
            this._setCurveBoundingBox(pts, w, h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   482
            this._updateDrawingQueue(["quadraticCurveTo", cpx, cpy, x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   483
            this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   484
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   485
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   486
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   487
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   488
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   489
     * Draws a circle. Used internally by `CanvasCircle` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   490
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   491
     * @method drawCircle
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   492
     * @param {Number} x y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   493
     * @param {Number} y x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   494
     * @param {Number} r radius
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   495
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   496
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   497
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   498
	drawCircle: function(x, y, radius) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   499
        var startAngle = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   500
            endAngle = 2 * Math.PI,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   501
            wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   502
            circum = radius * 2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   503
            circum += wt;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   504
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   505
        this._trackSize(x + circum, y + circum);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   506
        this._trackSize(x - wt, y - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   507
        this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   508
        this._updateDrawingQueue(["arc", x + radius, y + radius, radius, startAngle, endAngle, false]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   509
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   510
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   511
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   512
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   513
     * Draws a diamond.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   514
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   515
     * @method drawDiamond
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   516
     * @param {Number} x y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   517
     * @param {Number} y x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   518
     * @param {Number} width width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   519
     * @param {Number} height height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   520
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   521
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   522
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   523
    drawDiamond: function(x, y, width, height)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   524
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   525
        var midWidth = width * 0.5,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   526
            midHeight = height * 0.5;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   527
        this.moveTo(x + midWidth, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   528
        this.lineTo(x + width, y + midHeight);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   529
        this.lineTo(x + midWidth, y + height);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   530
        this.lineTo(x, y + midHeight);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   531
        this.lineTo(x + midWidth, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   532
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   533
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   534
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   535
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   536
     * Draws an ellipse. Used internally by `CanvasEllipse` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   537
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   538
     * @method drawEllipse
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   539
     * @param {Number} x x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   540
     * @param {Number} y y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   541
     * @param {Number} w width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   542
     * @param {Number} h height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   543
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   544
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   545
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   546
	drawEllipse: function(x, y, w, h) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   547
        var l = 8,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   548
            theta = -(45/180) * Math.PI,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   549
            angle = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   550
            angleMid,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   551
            radius = w/2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   552
            yRadius = h/2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   553
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   554
            centerX = x + radius,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   555
            centerY = y + yRadius,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   556
            ax, ay, bx, by, cx, cy,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   557
            wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   558
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   559
        ax = centerX + Math.cos(0) * radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   560
        ay = centerY + Math.sin(0) * yRadius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   561
        this.moveTo(ax, ay);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   562
        for(i = 0; i < l; i++)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   563
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   564
            angle += theta;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   565
            angleMid = angle - (theta / 2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   566
            bx = centerX + Math.cos(angle) * radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   567
            by = centerY + Math.sin(angle) * yRadius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   568
            cx = centerX + Math.cos(angleMid) * (radius / Math.cos(theta / 2));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   569
            cy = centerY + Math.sin(angleMid) * (yRadius / Math.cos(theta / 2));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   570
            this._updateDrawingQueue(["quadraticCurveTo", cx, cy, bx, by]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   571
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   572
        this._trackSize(x + w + wt, y + h + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   573
        this._trackSize(x - wt, y - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   574
        this._updateCoords(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   575
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   576
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   577
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   578
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   579
     * Draws a rectangle.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   580
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   581
     * @method drawRect
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   582
     * @param {Number} x x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   583
     * @param {Number} y y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   584
     * @param {Number} w width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   585
     * @param {Number} h height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   586
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   587
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   588
    drawRect: function(x, y, w, h) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   589
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   590
        this.moveTo(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   591
        this.lineTo(x + w, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   592
        this.lineTo(x + w, y + h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   593
        this.lineTo(x, y + h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   594
        this.lineTo(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   595
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   596
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   597
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   598
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   599
     * Draws a rectangle with rounded corners.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   600
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   601
     * @method drawRect
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   602
     * @param {Number} x x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   603
     * @param {Number} y y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   604
     * @param {Number} w width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   605
     * @param {Number} h height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   606
     * @param {Number} ew width of the ellipse used to draw the rounded corners
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   607
     * @param {Number} eh height of the ellipse used to draw the rounded corners
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   608
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   609
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   610
    drawRoundRect: function(x, y, w, h, ew, eh) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   611
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   612
        this.moveTo( x, y + eh);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   613
        this.lineTo(x, y + h - eh);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   614
        this.quadraticCurveTo(x, y + h, x + ew, y + h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   615
        this.lineTo(x + w - ew, y + h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   616
        this.quadraticCurveTo(x + w, y + h, x + w, y + h - eh);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   617
        this.lineTo(x + w, y + eh);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   618
        this.quadraticCurveTo(x + w, y, x + w - ew, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   619
        this.lineTo(x + ew, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   620
        this.quadraticCurveTo(x, y, x, y + eh);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   621
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   622
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   623
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   624
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   625
     * Draws a wedge.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   626
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   627
     * @method drawWedge
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   628
     * @param {Number} x x-coordinate of the wedge's center point
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   629
     * @param {Number} y y-coordinate of the wedge's center point
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   630
     * @param {Number} startAngle starting angle in degrees
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   631
     * @param {Number} arc sweep of the wedge. Negative values draw clockwise.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   632
     * @param {Number} radius radius of wedge. If [optional] yRadius is defined, then radius is the x radius.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   633
     * @param {Number} yRadius [optional] y radius for wedge.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   634
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   635
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   636
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   637
    drawWedge: function(x, y, startAngle, arc, radius, yRadius)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   638
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   639
        var wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   640
            segs,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   641
            segAngle,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   642
            theta,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   643
            angle,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   644
            angleMid,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   645
            ax,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   646
            ay,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   647
            bx,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   648
            by,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   649
            cx,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   650
            cy,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   651
            i = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   652
        yRadius = yRadius || radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   653
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   654
        this._drawingComplete = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   655
        // move to x,y position
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   656
        this._updateDrawingQueue(["moveTo", x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   657
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   658
        yRadius = yRadius || radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   659
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   660
        // limit sweep to reasonable numbers
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   661
        if(Math.abs(arc) > 360)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   662
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   663
            arc = 360;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   664
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   665
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   666
        // First we calculate how many segments are needed
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   667
        // for a smooth arc.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   668
        segs = Math.ceil(Math.abs(arc) / 45);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   669
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   670
        // Now calculate the sweep of each segment.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   671
        segAngle = arc / segs;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   672
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   673
        // The math requires radians rather than degrees. To convert from degrees
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   674
        // use the formula (degrees/180)*Math.PI to get radians.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   675
        theta = -(segAngle / 180) * Math.PI;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   676
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   677
        // convert angle startAngle to radians
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   678
        angle = (startAngle / 180) * Math.PI;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   679
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   680
        // draw the curve in segments no larger than 45 degrees.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   681
        if(segs > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   682
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   683
            // draw a line from the center to the start of the curve
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   684
            ax = x + Math.cos(startAngle / 180 * Math.PI) * radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   685
            ay = y + Math.sin(startAngle / 180 * Math.PI) * yRadius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   686
            this.lineTo(ax, ay);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   687
            // Loop for drawing curve segments
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   688
            for(i = 0; i < segs; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   689
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   690
                angle += theta;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   691
                angleMid = angle - (theta / 2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   692
                bx = x + Math.cos(angle) * radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   693
                by = y + Math.sin(angle) * yRadius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   694
                cx = x + Math.cos(angleMid) * (radius / Math.cos(theta / 2));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   695
                cy = y + Math.sin(angleMid) * (yRadius / Math.cos(theta / 2));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   696
                this._updateDrawingQueue(["quadraticCurveTo", cx, cy, bx, by]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   697
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   698
            // close the wedge by drawing a line to the center
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   699
            this._updateDrawingQueue(["lineTo", x, y]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   700
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   701
        this._trackSize(-wt , -wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   702
        this._trackSize((radius * 2) + wt, (radius * 2) + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   703
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   704
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   705
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   706
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   707
     * Completes a drawing operation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   708
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   709
     * @method end
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   710
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   711
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   712
    end: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   713
        this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   714
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   715
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   716
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   717
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   718
     * Ends a fill and stroke
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   719
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   720
     * @method closePath
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   721
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   722
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   723
    closePath: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   724
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   725
        this._updateDrawingQueue(["closePath"]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   726
        this._updateDrawingQueue(["beginPath"]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   727
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   728
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   729
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   730
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   731
	 * Clears the graphics object.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   732
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   733
	 * @method clear
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   734
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   735
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   736
    clear: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   737
		this._initProps();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   738
        if(this.node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   739
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   740
            this._context.clearRect(0, 0, this.node.width, this.node.height);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   741
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   742
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   743
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   744
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   745
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   746
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   747
     * Returns a linear gradient fill
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   748
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   749
     * @method _getLinearGradient
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   750
     * @return CanvasGradient
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   751
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   752
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   753
    _getLinearGradient: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   754
        var isNumber = Y.Lang.isNumber,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   755
            fill = this.get("fill"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   756
            stops = fill.stops,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   757
            opacity,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   758
            color,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   759
            stop,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   760
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   761
            len = stops.length,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   762
            gradient,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   763
            x = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   764
            y = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   765
            w = this.get("width"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   766
            h = this.get("height"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   767
            r = fill.rotation || 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   768
            x1, x2, y1, y2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   769
            cx = x + w/2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   770
            cy = y + h/2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   771
            offset,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   772
            radCon = Math.PI/180,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   773
            tanRadians = parseFloat(parseFloat(Math.tan(r * radCon)).toFixed(8));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   774
        if(Math.abs(tanRadians) * w/2 >= h/2)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   775
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   776
            if(r < 180)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   777
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   778
                y1 = y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   779
                y2 = y + h;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   780
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   781
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   782
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   783
                y1 = y + h;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   784
                y2 = y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   785
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   786
            x1 = cx - ((cy - y1)/tanRadians);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   787
            x2 = cx - ((cy - y2)/tanRadians);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   788
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   789
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   790
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   791
            if(r > 90 && r < 270)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   792
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   793
                x1 = x + w;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   794
                x2 = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   795
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   796
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   797
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   798
                x1 = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   799
                x2 = x + w;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   800
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   801
            y1 = ((tanRadians * (cx - x1)) - cy) * -1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   802
            y2 = ((tanRadians * (cx - x2)) - cy) * -1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   803
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   804
        gradient = this._context.createLinearGradient(x1, y1, x2, y2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   805
        for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   806
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   807
            stop = stops[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   808
            opacity = stop.opacity;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   809
            color = stop.color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   810
            offset = stop.offset;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   811
            if(isNumber(opacity))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   812
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   813
                opacity = Math.max(0, Math.min(1, opacity));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   814
                color = this._toRGBA(color, opacity);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   815
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   816
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   817
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   818
                color = TORGB(color);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   819
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   820
            offset = stop.offset || i/(len - 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   821
            gradient.addColorStop(offset, color);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   822
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   823
        return gradient;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   824
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   825
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   826
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   827
     * Returns a radial gradient fill
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   828
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   829
     * @method _getRadialGradient
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   830
     * @return CanvasGradient
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   831
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   832
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   833
    _getRadialGradient: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   834
        var isNumber = Y.Lang.isNumber,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   835
            fill = this.get("fill"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   836
            r = fill.r,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   837
            fx = fill.fx,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   838
            fy = fill.fy,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   839
            stops = fill.stops,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   840
            opacity,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   841
            color,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   842
            stop,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   843
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   844
            len = stops.length,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   845
            gradient,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   846
            x = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   847
            y = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   848
            w = this.get("width"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   849
            h = this.get("height"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   850
            x1, x2, y1, y2, r2,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   851
            xc, yc, xn, yn, d,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   852
            offset,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   853
            ratio,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   854
            stopMultiplier;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   855
        xc = x + w/2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   856
        yc = y + h/2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   857
        x1 = w * fx;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   858
        y1 = h * fy;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   859
        x2 = x + w/2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   860
        y2 = y + h/2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   861
        r2 = w * r;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   862
        d = Math.sqrt( Math.pow(Math.abs(xc - x1), 2) + Math.pow(Math.abs(yc - y1), 2) );
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   863
        if(d >= r2)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   864
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   865
            ratio = d/r2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   866
            //hack. gradient won't show if it is exactly on the edge of the arc
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   867
            if(ratio === 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   868
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   869
                ratio = 1.01;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   870
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   871
            xn = (x1 - xc)/ratio;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   872
            yn = (y1 - yc)/ratio;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   873
            xn = xn > 0 ? Math.floor(xn) : Math.ceil(xn);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   874
            yn = yn > 0 ? Math.floor(yn) : Math.ceil(yn);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   875
            x1 = xc + xn;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   876
            y1 = yc + yn;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   877
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   878
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   879
        //If the gradient radius is greater than the circle's, adjusting the radius stretches the gradient properly.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   880
        //If the gradient radius is less than the circle's, adjusting the radius of the gradient will not work.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   881
        //Instead, adjust the color stops to reflect the smaller radius.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   882
        if(r >= 0.5)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   883
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   884
            gradient = this._context.createRadialGradient(x1, y1, r, x2, y2, r * w);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   885
            stopMultiplier = 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   886
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   887
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   888
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   889
            gradient = this._context.createRadialGradient(x1, y1, r, x2, y2, w/2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   890
            stopMultiplier = r * 2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   891
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   892
        for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   893
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   894
            stop = stops[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   895
            opacity = stop.opacity;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   896
            color = stop.color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   897
            offset = stop.offset;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   898
            if(isNumber(opacity))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   899
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   900
                opacity = Math.max(0, Math.min(1, opacity));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   901
                color = this._toRGBA(color, opacity);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   902
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   903
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   904
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   905
                color = TORGB(color);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   906
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   907
            offset = stop.offset || i/(len - 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   908
            offset *= stopMultiplier;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   909
            if(offset <= 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   910
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   911
                gradient.addColorStop(offset, color);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   912
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   913
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   914
        return gradient;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   915
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   916
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   917
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   918
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   919
     * Clears all values
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   920
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   921
     * @method _initProps
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   922
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   923
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   924
    _initProps: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   925
        this._methods = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   926
        this._lineToMethods = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   927
        this._xcoords = [0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   928
		this._ycoords = [0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   929
		this._width = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   930
        this._height = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   931
        this._left = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   932
        this._top = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   933
        this._right = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   934
        this._bottom = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   935
        this._currentX = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   936
        this._currentY = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   937
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   938
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   939
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   940
     * Indicates a drawing has completed.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   941
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   942
     * @property _drawingComplete
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   943
     * @type Boolean
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   944
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   945
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   946
    _drawingComplete: false,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   947
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   948
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   949
     * Creates canvas element
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   950
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   951
     * @method _createGraphic
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   952
     * @return HTMLCanvasElement
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   953
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   954
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   955
    _createGraphic: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   956
        var graphic = Y.config.doc.createElement('canvas');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   957
        return graphic;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   958
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   959
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   960
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   961
     * Returns the points on a curve
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   962
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   963
     * @method getBezierData
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   964
     * @param Array points Array containing the begin, end and control points of a curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   965
     * @param Number t The value for incrementing the next set of points.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   966
     * @return Array
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   967
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   968
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   969
    getBezierData: function(points, t) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   970
        var n = points.length,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   971
            tmp = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   972
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   973
            j;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   974
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   975
        for (i = 0; i < n; ++i){
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   976
            tmp[i] = [points[i][0], points[i][1]]; // save input
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   977
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   978
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   979
        for (j = 1; j < n; ++j) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   980
            for (i = 0; i < n - j; ++i) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   981
                tmp[i][0] = (1 - t) * tmp[i][0] + t * tmp[parseInt(i + 1, 10)][0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   982
                tmp[i][1] = (1 - t) * tmp[i][1] + t * tmp[parseInt(i + 1, 10)][1];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   983
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   984
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   985
        return [ tmp[0][0], tmp[0][1] ];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   986
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   987
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   988
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   989
     * Calculates the bounding box for a curve
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   990
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   991
     * @method _setCurveBoundingBox
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   992
     * @param Array pts Array containing points for start, end and control points of a curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   993
     * @param Number w Width used to calculate the number of points to describe the curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   994
     * @param Number h Height used to calculate the number of points to describe the curve.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   995
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   996
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   997
    _setCurveBoundingBox: function(pts, w, h)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   998
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   999
        var i = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1000
            left = this._currentX,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1001
            right = left,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1002
            top = this._currentY,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1003
            bottom = top,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1004
            len = Math.round(Math.sqrt((w * w) + (h * h))),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1005
            t = 1/len,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1006
            wt = this._stroke && this._strokeWeight ? this._strokeWeight : 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1007
            xy;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1008
        for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1009
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1010
            xy = this.getBezierData(pts, t * i);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1011
            left = isNaN(left) ? xy[0] : Math.min(xy[0], left);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1012
            right = isNaN(right) ? xy[0] : Math.max(xy[0], right);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1013
            top = isNaN(top) ? xy[1] : Math.min(xy[1], top);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1014
            bottom = isNaN(bottom) ? xy[1] : Math.max(xy[1], bottom);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1015
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1016
        left = Math.round(left * 10)/10;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1017
        right = Math.round(right * 10)/10;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1018
        top = Math.round(top * 10)/10;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1019
        bottom = Math.round(bottom * 10)/10;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1020
        this._trackSize(right + wt, bottom + wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1021
        this._trackSize(left - wt, top - wt);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1022
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1023
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1024
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1025
     * Updates the size of the graphics object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1026
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1027
     * @method _trackSize
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1028
     * @param {Number} w width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1029
     * @param {Number} h height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1030
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1031
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1032
    _trackSize: function(w, h) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1033
        if (w > this._right) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1034
            this._right = w;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1035
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1036
        if(w < this._left)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1037
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1038
            this._left = w;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1039
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1040
        if (h < this._top)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1041
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1042
            this._top = h;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1043
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1044
        if (h > this._bottom)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1045
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1046
            this._bottom = h;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1047
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1048
        this._width = this._right - this._left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1049
        this._height = this._bottom - this._top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1050
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1051
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1052
Y.CanvasDrawing = CanvasDrawing;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1053
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1054
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Shape.html">`Shape`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1055
 * `CanvasShape` is not intended to be used directly. Instead, use the <a href="Shape.html">`Shape`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1056
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1057
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Shape.html">`Shape`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1058
 * class will point to the `CanvasShape` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1059
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1060
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1061
 * @class CanvasShape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1062
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1063
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1064
CanvasShape = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1065
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1066
    this._transforms = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1067
    this.matrix = new Y.Matrix();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1068
    CanvasShape.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1069
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1070
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1071
CanvasShape.NAME = "shape";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1072
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1073
Y.extend(CanvasShape, Y.GraphicBase, Y.mix({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1074
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1075
     * Init method, invoked during construction.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1076
     * Calls `initializer` method.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1077
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1078
     * @method init
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1079
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1080
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1081
    init: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1082
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1083
		this.initializer.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1084
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1085
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1086
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1087
	 * Initializes the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1088
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1089
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1090
	 * @method _initialize
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1091
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1092
	initializer: function(cfg)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1093
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1094
		var host = this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1095
            graphic = cfg.graphic,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1096
            data = this.get("data");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1097
        host._initProps();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1098
		host.createNode();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1099
		host._xcoords = [0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1100
		host._ycoords = [0];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1101
        if(graphic)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1102
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1103
            this._setGraphic(graphic);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1104
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1105
        if(data)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1106
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1107
            host._parsePathData(data);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1108
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1109
		host._updateHandler();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1110
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1111
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1112
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1113
     * Set the Graphic instance for the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1114
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1115
     * @method _setGraphic
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1116
     * @param {Graphic | Node | HTMLElement | String} render This param is used to determine the graphic instance. If it is a
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1117
     * `Graphic` instance, it will be assigned to the `graphic` attribute. Otherwise, a new Graphic instance will be created
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1118
     * and rendered into the dom element that the render represents.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1119
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1120
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1121
    _setGraphic: function(render)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1122
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1123
        var graphic;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1124
        if(render instanceof Y.CanvasGraphic)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1125
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1126
            this._graphic = render;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1127
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1128
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1129
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1130
            graphic = new Y.CanvasGraphic({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1131
                render: render
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1132
            });
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1133
            graphic._appendShape(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1134
            this._graphic = graphic;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1135
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1136
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1137
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1138
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1139
	 * Add a class name to each node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1140
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1141
	 * @method addClass
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1142
	 * @param {String} className the class name to add to the node's class attribute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1143
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1144
	addClass: function(className)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1145
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1146
		var node = this.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1147
		Y.DOM.addClass(node, className);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1148
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1149
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1150
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1151
	 * Removes a class name from each node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1152
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1153
	 * @method removeClass
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1154
	 * @param {String} className the class name to remove from the node's class attribute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1155
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1156
	removeClass: function(className)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1157
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1158
		var node = this.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1159
		Y.DOM.removeClass(node, className);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1160
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1161
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1162
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1163
	 * Gets the current position of the node in page coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1164
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1165
	 * @method getXY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1166
	 * @return Array The XY position of the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1167
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1168
	getXY: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1169
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1170
		var graphic = this.get("graphic"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1171
			parentXY = graphic.getXY(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1172
			x = this.get("x"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1173
			y = this.get("y");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1174
		return [parentXY[0] + x, parentXY[1] + y];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1175
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1176
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1177
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1178
	 * Set the position of the shape in page coordinates, regardless of how the node is positioned.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1179
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1180
	 * @method setXY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1181
	 * @param {Array} Contains X & Y values for new position (coordinates are page-based)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1182
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1183
	setXY: function(xy)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1184
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1185
		var graphic = this.get("graphic"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1186
			parentXY = graphic.getXY(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1187
			x = xy[0] - parentXY[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1188
			y = xy[1] - parentXY[1];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1189
		this._set("x", x);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1190
		this._set("y", y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1191
		this._updateNodePosition(x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1192
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1193
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1194
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1195
	 * Determines whether the node is an ancestor of another HTML element in the DOM hierarchy.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1196
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1197
	 * @method contains
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1198
	 * @param {CanvasShape | HTMLElement} needle The possible node or descendent
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1199
	 * @return Boolean Whether or not this shape is the needle or its ancestor.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1200
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1201
	contains: function(needle)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1202
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1203
		var node = needle instanceof Y.Node ? needle._node : needle;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1204
        return node === this.node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1205
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1206
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1207
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1208
	 * Test if the supplied node matches the supplied selector.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1209
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1210
	 * @method test
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1211
	 * @param {String} selector The CSS selector to test against.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1212
	 * @return Boolean Wheter or not the shape matches the selector.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1213
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1214
	test: function(selector)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1215
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1216
		return Y.Selector.test(this.node, selector);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1217
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1218
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1219
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1220
	 * Compares nodes to determine if they match.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1221
	 * Node instances can be compared to each other and/or HTMLElements.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1222
	 * @method compareTo
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1223
	 * @param {HTMLElement | Node} refNode The reference node to compare to the node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1224
	 * @return {Boolean} True if the nodes match, false if they do not.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1225
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1226
	compareTo: function(refNode) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1227
		var node = this.node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1228
		return node === refNode;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1229
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1230
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1231
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1232
	 * Value function for fill attribute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1233
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1234
	 * @method _getDefaultFill
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1235
	 * @return Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1236
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1237
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1238
	_getDefaultFill: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1239
		return {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1240
			type: "solid",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1241
			opacity: 1,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1242
			cx: 0.5,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1243
			cy: 0.5,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1244
			fx: 0.5,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1245
			fy: 0.5,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1246
			r: 0.5
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1247
		};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1248
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1249
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1250
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1251
	 * Value function for stroke attribute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1252
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1253
	 * @method _getDefaultStroke
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1254
	 * @return Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1255
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1256
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1257
	_getDefaultStroke: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1258
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1259
		return {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1260
			weight: 1,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1261
			dashstyle: "none",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1262
			color: "#000",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1263
			opacity: 1.0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1264
		};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1265
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1266
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1267
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1268
	 * Left edge of the path
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1269
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1270
     * @property _left
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1271
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1272
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1273
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1274
	_left: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1275
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1276
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1277
	 * Right edge of the path
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1278
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1279
     * @property _right
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1280
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1281
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1282
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1283
	_right: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1284
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1285
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1286
	 * Top edge of the path
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1287
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1288
     * @property _top
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1289
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1290
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1291
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1292
	_top: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1293
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1294
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1295
	 * Bottom edge of the path
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1296
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1297
     * @property _bottom
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1298
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1299
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1300
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1301
	_bottom: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1302
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1303
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1304
	 * Creates the dom node for the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1305
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1306
     * @method createNode
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1307
	 * @return HTMLElement
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1308
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1309
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1310
	createNode: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1311
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1312
		var host = this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1313
            node = Y.config.doc.createElement('canvas'),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1314
			id = host.get("id"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1315
            concat = host._camelCaseConcat,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1316
            name = host.name;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1317
		host._context = node.getContext('2d');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1318
		node.setAttribute("overflow", "visible");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1319
        node.style.overflow = "visible";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1320
        if(!host.get("visible"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1321
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1322
            node.style.visibility = "hidden";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1323
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1324
		node.setAttribute("id", id);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1325
		id = "#" + id;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1326
        host.node = node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1327
		host.addClass(
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1328
            _getClassName(SHAPE) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1329
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1330
            _getClassName(concat(IMPLEMENTATION, SHAPE)) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1331
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1332
            _getClassName(name) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1333
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1334
            _getClassName(concat(IMPLEMENTATION, name))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1335
        );
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1336
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1337
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1338
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1339
     * Overrides default `on` method. Checks to see if its a dom interaction event. If so,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1340
     * return an event attached to the `node` element. If not, return the normal functionality.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1341
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1342
     * @method on
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1343
     * @param {String} type event type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1344
     * @param {Object} callback function
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1345
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1346
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1347
	on: function(type, fn)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1348
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1349
		if(Y.Node.DOM_EVENTS[type])
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1350
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1351
            return Y.on(type, fn, "#" + this.get("id"));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1352
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1353
		return Y.on.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1354
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1355
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1356
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1357
	 * Adds a stroke to the shape node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1358
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1359
	 * @method _strokeChangeHandler
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1360
     * @param {Object} stroke Properties of the `stroke` attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1361
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1362
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1363
	_setStrokeProps: function(stroke)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1364
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1365
		var color,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1366
			weight,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1367
			opacity,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1368
			linejoin,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1369
			linecap,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1370
			dashstyle;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1371
        if(stroke)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1372
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1373
            color = stroke.color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1374
            weight = PARSE_FLOAT(stroke.weight);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1375
            opacity = PARSE_FLOAT(stroke.opacity);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1376
            linejoin = stroke.linejoin || "round";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1377
            linecap = stroke.linecap || "butt";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1378
            dashstyle = stroke.dashstyle;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1379
            this._miterlimit = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1380
            this._dashstyle = (dashstyle && Y.Lang.isArray(dashstyle) && dashstyle.length > 1) ? dashstyle : null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1381
            this._strokeWeight = weight;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1382
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1383
            if (IS_NUMBER(weight) && weight > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1384
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1385
                this._stroke = 1;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1386
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1387
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1388
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1389
                this._stroke = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1390
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1391
            if (IS_NUMBER(opacity)) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1392
                this._strokeStyle = this._toRGBA(color, opacity);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1393
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1394
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1395
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1396
                this._strokeStyle = color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1397
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1398
            this._linecap = linecap;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1399
            if(linejoin === "round" || linejoin === "bevel")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1400
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1401
                this._linejoin = linejoin;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1402
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1403
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1404
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1405
                linejoin = parseInt(linejoin, 10);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1406
                if(IS_NUMBER(linejoin))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1407
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1408
                    this._miterlimit =  Math.max(linejoin, 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1409
                    this._linejoin = "miter";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1410
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1411
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1412
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1413
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1414
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1415
            this._stroke = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1416
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1417
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1418
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1419
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1420
     * Sets the value of an attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1421
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1422
     * @method set
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1423
     * @param {String|Object} name The name of the attribute. Alternatively, an object of key value pairs can
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1424
     * be passed in to set multiple attributes at once.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1425
     * @param {Any} value The value to set the attribute to. This value is ignored if an object is received as
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1426
     * the name param.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1427
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1428
	set: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1429
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1430
		var host = this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1431
		AttributeLite.prototype.set.apply(host, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1432
		if(host.initialized)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1433
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1434
			host._updateHandler();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1435
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1436
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1437
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1438
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1439
	 * Adds a fill to the shape node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1440
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1441
	 * @method _setFillProps
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1442
     * @param {Object} fill Properties of the `fill` attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1443
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1444
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1445
	_setFillProps: function(fill)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1446
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1447
		var isNumber = IS_NUMBER,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1448
			color,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1449
			opacity,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1450
			type;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1451
        if(fill)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1452
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1453
            color = fill.color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1454
            type = fill.type;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1455
            if(type === "linear" || type === "radial")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1456
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1457
                this._fillType = type;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1458
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1459
            else if(color)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1460
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1461
                opacity = fill.opacity;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1462
                if (isNumber(opacity))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1463
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1464
                    opacity = Math.max(0, Math.min(1, opacity));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1465
                    color = this._toRGBA(color, opacity);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1466
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1467
                else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1468
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1469
                    color = TORGB(color);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1470
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1471
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1472
                this._fillColor = color;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1473
                this._fillType = 'solid';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1474
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1475
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1476
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1477
                this._fillColor = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1478
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1479
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1480
		else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1481
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1482
            this._fillType = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1483
			this._fillColor = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1484
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1485
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1486
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1487
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1488
	 * Specifies a 2d translation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1489
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1490
	 * @method translate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1491
	 * @param {Number} x The value to transate on the x-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1492
	 * @param {Number} y The value to translate on the y-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1493
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1494
	translate: function(x, y)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1495
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1496
		this._translateX += x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1497
		this._translateY += y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1498
		this._addTransform("translate", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1499
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1500
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1501
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1502
	 * Translates the shape along the x-axis. When translating x and y coordinates,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1503
	 * use the `translate` method.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1504
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1505
	 * @method translateX
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1506
	 * @param {Number} x The value to translate.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1507
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1508
	translateX: function(x)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1509
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1510
        this._translateX += x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1511
        this._addTransform("translateX", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1512
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1513
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1514
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1515
	 * Performs a translate on the y-coordinate. When translating x and y coordinates,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1516
	 * use the `translate` method.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1517
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1518
	 * @method translateY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1519
	 * @param {Number} y The value to translate.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1520
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1521
	translateY: function(y)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1522
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1523
        this._translateY += y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1524
        this._addTransform("translateY", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1525
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1526
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1527
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1528
     * Skews the shape around the x-axis and y-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1529
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1530
     * @method skew
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1531
     * @param {Number} x The value to skew on the x-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1532
     * @param {Number} y The value to skew on the y-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1533
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1534
    skew: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1535
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1536
        this._addTransform("skew", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1537
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1538
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1539
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1540
	 * Skews the shape around the x-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1541
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1542
	 * @method skewX
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1543
	 * @param {Number} x x-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1544
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1545
    skewX: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1546
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1547
        this._addTransform("skewX", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1548
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1549
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1550
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1551
	 * Skews the shape around the y-axis.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1552
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1553
	 * @method skewY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1554
	 * @param {Number} y y-coordinate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1555
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1556
    skewY: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1557
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1558
        this._addTransform("skewY", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1559
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1560
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1561
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1562
	 * Rotates the shape clockwise around it transformOrigin.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1563
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1564
	 * @method rotate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1565
	 * @param {Number} deg The degree of the rotation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1566
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1567
    rotate: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1568
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1569
        this._addTransform("rotate", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1570
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1571
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1572
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1573
	 * Specifies a 2d scaling operation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1574
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1575
	 * @method scale
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1576
	 * @param {Number} val
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1577
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1578
    scale: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1579
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1580
        this._addTransform("scale", arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1581
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1582
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1583
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1584
     * Storage for the transform attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1585
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1586
     * @property _transform
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1587
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1588
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1589
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1590
    _transform: "",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1591
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1592
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1593
     * Adds a transform to the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1594
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1595
     * @method _addTransform
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1596
     * @param {String} type The transform being applied.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1597
     * @param {Array} args The arguments for the transform.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1598
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1599
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1600
	_addTransform: function(type, args)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1601
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1602
        args = Y.Array(args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1603
        this._transform = Y_LANG.trim(this._transform + " " + type + "(" + args.join(", ") + ")");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1604
        args.unshift(type);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1605
        this._transforms.push(args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1606
        if(this.initialized)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1607
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1608
            this._updateTransform();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1609
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1610
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1611
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1612
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1613
     * Applies all transforms.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1614
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1615
     * @method _updateTransform
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1616
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1617
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1618
	_updateTransform: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1619
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1620
		var node = this.node,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1621
			key,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1622
			transform,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1623
			transformOrigin = this.get("transformOrigin"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1624
            matrix = this.matrix,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1625
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1626
            len = this._transforms.length;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1627
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1628
        if(this._transforms && this._transforms.length > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1629
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1630
            for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1631
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1632
                key = this._transforms[i].shift();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1633
                if(key)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1634
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1635
                    matrix[key].apply(matrix, this._transforms[i]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1636
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1637
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1638
            transform = matrix.toCSSText();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1639
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1640
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1641
        this._graphic.addToRedrawQueue(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1642
		transformOrigin = (100 * transformOrigin[0]) + "% " + (100 * transformOrigin[1]) + "%";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1643
        Y_DOM.setStyle(node, "transformOrigin", transformOrigin);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1644
        if(transform)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1645
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1646
            Y_DOM.setStyle(node, "transform", transform);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1647
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1648
        this._transforms = [];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1649
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1650
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1651
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1652
     * Updates `Shape` based on attribute changes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1653
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1654
     * @method _updateHandler
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1655
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1656
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1657
	_updateHandler: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1658
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1659
		this._draw();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1660
		this._updateTransform();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1661
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1662
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1663
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1664
	 * Updates the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1665
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1666
	 * @method _draw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1667
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1668
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1669
	_draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1670
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1671
        var node = this.node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1672
        this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1673
		this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1674
		node.style.left = this.get("x") + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1675
		node.style.top = this.get("y") + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1676
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1677
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1678
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1679
	 * Completes a shape or drawing
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1680
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1681
	 * @method _closePath
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1682
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1683
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1684
	_closePath: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1685
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1686
		if(!this._methods)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1687
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1688
			return;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1689
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1690
		var node = this.get("node"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1691
			w = this._right - this._left,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1692
			h = this._bottom - this._top,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1693
			context = this._context,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1694
			methods = [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1695
			cachedMethods = this._methods.concat(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1696
			i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1697
			j,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1698
			method,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1699
			args,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1700
            argsLen,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1701
			len = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1702
		this._context.clearRect(0, 0, node.width, node.height);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1703
        if(this._methods)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1704
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1705
			len = cachedMethods.length;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1706
			if(!len || len < 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1707
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1708
				return;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1709
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1710
			for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1711
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1712
				methods[i] = cachedMethods[i].concat();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1713
				args = methods[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1714
                argsLen = (args[0] === "quadraticCurveTo" || args[0] === "bezierCurveTo") ? args.length : 3;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1715
				for(j = 1; j < argsLen; ++j)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1716
				{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1717
					if(j % 2 === 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1718
					{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1719
						args[j] = args[j] - this._top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1720
					}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1721
					else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1722
					{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1723
						args[j] = args[j] - this._left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1724
					}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1725
				}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1726
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1727
            node.setAttribute("width", Math.min(w, 2000));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1728
            node.setAttribute("height", Math.min(2000, h));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1729
            context.beginPath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1730
			for(i = 0; i < len; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1731
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1732
				args = methods[i].concat();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1733
				if(args && args.length > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1734
				{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1735
					method = args.shift();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1736
					if(method)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1737
					{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1738
                        if(method === "closePath")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1739
                        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1740
                            context.closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1741
                            this._strokeAndFill(context);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1742
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1743
						else if(method && method === "lineTo" && this._dashstyle)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1744
						{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1745
							args.unshift(this._xcoords[i] - this._left, this._ycoords[i] - this._top);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1746
							this._drawDashedLine.apply(this, args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1747
						}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1748
						else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1749
						{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1750
                            context[method].apply(context, args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1751
						}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1752
					}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1753
				}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1754
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1755
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1756
            this._strokeAndFill(context);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1757
			this._drawingComplete = true;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1758
			this._clearAndUpdateCoords();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1759
			this._updateNodePosition();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1760
			this._methods = cachedMethods;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1761
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1762
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1763
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1764
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1765
     * Completes a stroke and/or fill operation on the context.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1766
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1767
     * @method _strokeAndFill
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1768
     * @param {Context} Reference to the context element of the canvas instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1769
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1770
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1771
    _strokeAndFill: function(context)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1772
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1773
        if (this._fillType)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1774
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1775
            if(this._fillType === "linear")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1776
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1777
                context.fillStyle = this._getLinearGradient();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1778
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1779
            else if(this._fillType === "radial")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1780
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1781
                context.fillStyle = this._getRadialGradient();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1782
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1783
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1784
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1785
                context.fillStyle = this._fillColor;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1786
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1787
            context.closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1788
            context.fill();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1789
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1790
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1791
        if (this._stroke) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1792
            if(this._strokeWeight)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1793
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1794
                context.lineWidth = this._strokeWeight;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1795
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1796
            context.lineCap = this._linecap;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1797
            context.lineJoin = this._linejoin;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1798
            if(this._miterlimit)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1799
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1800
                context.miterLimit = this._miterlimit;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1801
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1802
            context.strokeStyle = this._strokeStyle;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1803
            context.stroke();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1804
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1805
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1806
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1807
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1808
	 * Draws a dashed line between two points.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1809
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1810
	 * @method _drawDashedLine
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1811
	 * @param {Number} xStart	The x position of the start of the line
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1812
	 * @param {Number} yStart	The y position of the start of the line
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1813
	 * @param {Number} xEnd		The x position of the end of the line
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1814
	 * @param {Number} yEnd		The y position of the end of the line
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1815
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1816
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1817
	_drawDashedLine: function(xStart, yStart, xEnd, yEnd)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1818
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1819
		var context = this._context,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1820
			dashsize = this._dashstyle[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1821
			gapsize = this._dashstyle[1],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1822
			segmentLength = dashsize + gapsize,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1823
			xDelta = xEnd - xStart,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1824
			yDelta = yEnd - yStart,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1825
			delta = Math.sqrt(Math.pow(xDelta, 2) + Math.pow(yDelta, 2)),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1826
			segmentCount = Math.floor(Math.abs(delta / segmentLength)),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1827
			radians = Math.atan2(yDelta, xDelta),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1828
			xCurrent = xStart,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1829
			yCurrent = yStart,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1830
			i;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1831
		xDelta = Math.cos(radians) * segmentLength;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1832
		yDelta = Math.sin(radians) * segmentLength;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1833
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1834
		for(i = 0; i < segmentCount; ++i)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1835
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1836
			context.moveTo(xCurrent, yCurrent);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1837
			context.lineTo(xCurrent + Math.cos(radians) * dashsize, yCurrent + Math.sin(radians) * dashsize);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1838
			xCurrent += xDelta;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1839
			yCurrent += yDelta;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1840
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1841
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1842
		context.moveTo(xCurrent, yCurrent);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1843
		delta = Math.sqrt((xEnd - xCurrent) * (xEnd - xCurrent) + (yEnd - yCurrent) * (yEnd - yCurrent));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1844
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1845
		if(delta > dashsize)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1846
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1847
			context.lineTo(xCurrent + Math.cos(radians) * dashsize, yCurrent + Math.sin(radians) * dashsize);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1848
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1849
		else if(delta > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1850
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1851
			context.lineTo(xCurrent + Math.cos(radians) * delta, yCurrent + Math.sin(radians) * delta);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1852
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1853
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1854
		context.moveTo(xEnd, yEnd);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1855
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1856
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1857
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1858
	 * Returns the bounds for a shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1859
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1860
     * Calculates the a new bounding box from the original corner coordinates (base on size and position) and the transform matrix.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1861
     * The calculated bounding box is used by the graphic instance to calculate its viewBox.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1862
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1863
	 * @method getBounds
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1864
	 * @return Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1865
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1866
	getBounds: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1867
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1868
		var type = this._type,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1869
			w = this.get("width"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1870
			h = this.get("height"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1871
			x = this.get("x"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1872
			y = this.get("y");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1873
        if(type === "path")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1874
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1875
            x = x + this._left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1876
            y = y + this._top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1877
            w = this._right - this._left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1878
            h = this._bottom - this._top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1879
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1880
        return this._getContentRect(w, h, x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1881
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1882
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1883
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1884
     * Calculates the bounding box for the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1885
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1886
     * @method _getContentRect
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1887
     * @param {Number} w width of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1888
     * @param {Number} h height of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1889
     * @param {Number} x x-coordinate of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1890
     * @param {Number} y y-coordinate of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1891
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1892
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1893
    _getContentRect: function(w, h, x, y)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1894
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1895
        var transformOrigin = this.get("transformOrigin"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1896
            transformX = transformOrigin[0] * w,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1897
            transformY = transformOrigin[1] * h,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1898
            transforms = this.matrix.getTransformArray(this.get("transform")),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1899
            matrix = new Y.Matrix(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1900
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1901
            len = transforms.length,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1902
            transform,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1903
            key,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1904
            contentRect;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1905
        if(this._type === "path")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1906
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1907
            transformX = transformX + x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1908
            transformY = transformY + y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1909
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1910
        transformX = !isNaN(transformX) ? transformX : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1911
        transformY = !isNaN(transformY) ? transformY : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1912
        matrix.translate(transformX, transformY);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1913
        for(i = 0; i < len; i = i + 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1914
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1915
            transform = transforms[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1916
            key = transform.shift();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1917
            if(key)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1918
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1919
                matrix[key].apply(matrix, transform);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1920
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1921
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1922
        matrix.translate(-transformX, -transformY);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1923
        contentRect = matrix.getContentRect(w, h, x, y);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1924
        return contentRect;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1925
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1926
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1927
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1928
     * Places the shape above all other shapes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1929
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1930
     * @method toFront
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1931
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1932
    toFront: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1933
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1934
        var graphic = this.get("graphic");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1935
        if(graphic)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1936
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1937
            graphic._toFront(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1938
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1939
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1940
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1941
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1942
     * Places the shape underneath all other shapes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1943
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1944
     * @method toFront
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1945
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1946
    toBack: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1947
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1948
        var graphic = this.get("graphic");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1949
        if(graphic)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1950
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1951
            graphic._toBack(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1952
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1953
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1954
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1955
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1956
     * Parses path data string and call mapped methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1957
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1958
     * @method _parsePathData
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1959
     * @param {String} val The path data
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1960
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1961
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1962
    _parsePathData: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1963
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1964
        var method,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1965
            methodSymbol,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1966
            args,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1967
            commandArray = Y.Lang.trim(val.match(SPLITPATHPATTERN)),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1968
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1969
            len,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1970
            str,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1971
            symbolToMethod = this._pathSymbolToMethod;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1972
        if(commandArray)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1973
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1974
            this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1975
            len = commandArray.length || 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1976
            for(i = 0; i < len; i = i + 1)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1977
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1978
                str = commandArray[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1979
                methodSymbol = str.substr(0, 1);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1980
                args = str.substr(1).match(SPLITARGSPATTERN);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1981
                method = symbolToMethod[methodSymbol];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1982
                if(method)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1983
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1984
                    if(args)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1985
                    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1986
                        this[method].apply(this, args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1987
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1988
                    else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1989
                    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1990
                        this[method].apply(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1991
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1992
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1993
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1994
            this.end();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1995
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1996
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1997
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1998
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  1999
     * Destroys the shape instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2000
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2001
     * @method destroy
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2002
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2003
    destroy: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2004
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2005
        var graphic = this.get("graphic");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2006
        if(graphic)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2007
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2008
            graphic.removeShape(this);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2009
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2010
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2011
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2012
            this._destroy();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2013
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2014
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2015
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2016
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2017
     *  Implementation for shape destruction
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2018
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2019
     *  @method destroy
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2020
     *  @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2021
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2022
    _destroy: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2023
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2024
        if(this.node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2025
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2026
            Y.Event.purgeElement(this.node, true);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2027
            if(this.node.parentNode)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2028
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2029
                this.node.style.visibility = "";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2030
                this.node.parentNode.removeChild(this.node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2031
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2032
            this._context = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2033
            this.node = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2034
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2035
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2036
}, Y.CanvasDrawing.prototype));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2037
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2038
CanvasShape.ATTRS =  {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2039
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2040
	 * An array of x, y values which indicates the transformOrigin in which to rotate the shape. Valid values range between 0 and 1 representing a
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2041
	 * fraction of the shape's corresponding bounding box dimension. The default value is [0.5, 0.5].
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2042
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2043
	 * @config transformOrigin
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2044
	 * @type Array
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2045
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2046
	transformOrigin: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2047
		valueFn: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2048
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2049
			return [0.5, 0.5];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2050
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2051
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2052
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2053
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2054
     * <p>A string containing, in order, transform operations applied to the shape instance. The `transform` string can contain the following values:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2055
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2056
     *    <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2057
     *        <dt>rotate</dt><dd>Rotates the shape clockwise around it transformOrigin.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2058
     *        <dt>translate</dt><dd>Specifies a 2d translation.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2059
     *        <dt>skew</dt><dd>Skews the shape around the x-axis and y-axis.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2060
     *        <dt>scale</dt><dd>Specifies a 2d scaling operation.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2061
     *        <dt>translateX</dt><dd>Translates the shape along the x-axis.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2062
     *        <dt>translateY</dt><dd>Translates the shape along the y-axis.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2063
     *        <dt>skewX</dt><dd>Skews the shape around the x-axis.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2064
     *        <dt>skewY</dt><dd>Skews the shape around the y-axis.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2065
     *        <dt>matrix</dt><dd>Specifies a 2D transformation matrix comprised of the specified six values.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2066
     *    </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2067
     * </p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2068
     * <p>Applying transforms through the transform attribute will reset the transform matrix and apply a new transform. The shape class also contains
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2069
     * corresponding methods for each transform that will apply the transform to the current matrix. The below code illustrates how you might use the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2070
     * `transform` attribute to instantiate a recangle with a rotation of 45 degrees.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2071
            var myRect = new Y.Rect({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2072
                type:"rect",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2073
                width: 50,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2074
                height: 40,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2075
                transform: "rotate(45)"
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2076
            };
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2077
     * <p>The code below would apply `translate` and `rotate` to an existing shape.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2078
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2079
        myRect.set("transform", "translate(40, 50) rotate(45)");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2080
	 * @config transform
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2081
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2082
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2083
	transform: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2084
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2085
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2086
            this.matrix.init();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2087
            this._transforms = this.matrix.getTransformArray(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2088
            this._transform = val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2089
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2090
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2091
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2092
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2093
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2094
            return this._transform;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2095
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2096
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2097
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2098
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2099
	 * Dom node for the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2100
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2101
	 * @config node
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2102
	 * @type HTMLElement
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2103
	 * @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2104
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2105
	node: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2106
		readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2107
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2108
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2109
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2110
			return this.node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2111
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2112
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2113
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2114
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2115
	 * Unique id for class instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2116
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2117
	 * @config id
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2118
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2119
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2120
	id: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2121
		valueFn: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2122
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2123
			return Y.guid();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2124
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2125
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2126
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2127
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2128
			var node = this.node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2129
			if(node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2130
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2131
				node.setAttribute("id", val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2132
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2133
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2134
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2135
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2136
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2137
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2138
	 * Indicates the width of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2139
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2140
	 * @config width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2141
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2142
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2143
	width: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2144
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2145
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2146
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2147
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2148
	 * Indicates the height of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2149
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2150
	 * @config height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2151
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2152
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2153
	height: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2154
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2155
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2156
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2157
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2158
	 * Indicates the x position of shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2159
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2160
	 * @config x
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2161
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2162
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2163
	x: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2164
		value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2165
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2166
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2167
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2168
	 * Indicates the y position of shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2169
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2170
	 * @config y
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2171
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2172
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2173
	y: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2174
		value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2175
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2176
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2177
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2178
	 * Indicates whether the shape is visible.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2179
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2180
	 * @config visible
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2181
	 * @type Boolean
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2182
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2183
	visible: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2184
		value: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2185
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2186
		setter: function(val){
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2187
			var node = this.get("node"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2188
                visibility = val ? "visible" : "hidden";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2189
			if(node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2190
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2191
                node.style.visibility = visibility;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2192
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2193
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2194
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2195
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2196
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2197
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2198
	 * Contains information about the fill of the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2199
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2200
     *      <dt>color</dt><dd>The color of the fill.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2201
     *      <dt>opacity</dt><dd>Number between 0 and 1 that indicates the opacity of the fill. The default value is 1.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2202
     *      <dt>type</dt><dd>Type of fill.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2203
     *          <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2204
     *              <dt>solid</dt><dd>Solid single color fill. (default)</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2205
     *              <dt>linear</dt><dd>Linear gradient fill.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2206
     *              <dt>radial</dt><dd>Radial gradient fill.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2207
     *          </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2208
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2209
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2210
     *  <p>If a `linear` or `radial` is specified as the fill type. The following additional property is used:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2211
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2212
     *      <dt>stops</dt><dd>An array of objects containing the following properties:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2213
     *          <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2214
     *              <dt>color</dt><dd>The color of the stop.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2215
     *              <dt>opacity</dt><dd>Number between 0 and 1 that indicates the opacity of the stop. The default value is 1.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2216
     *              Note: No effect for IE 6 - 8</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2217
     *              <dt>offset</dt><dd>Number between 0 and 1 indicating where the color stop is positioned.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2218
     *          </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2219
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2220
     *      <p>Linear gradients also have the following property:</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2221
     *      <dt>rotation</dt><dd>Linear gradients flow left to right by default. The rotation property allows you to change the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2222
     *      flow by rotation. (e.g. A rotation of 180 would make the gradient pain from right to left.)</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2223
     *      <p>Radial gradients have the following additional properties:</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2224
     *      <dt>r</dt><dd>Radius of the gradient circle.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2225
     *      <dt>fx</dt><dd>Focal point x-coordinate of the gradient.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2226
     *      <dt>fy</dt><dd>Focal point y-coordinate of the gradient.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2227
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2228
     *  <p>The corresponding `SVGShape` class implements the following additional properties.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2229
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2230
     *      <dt>cx</dt><dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2231
     *          <p>The x-coordinate of the center of the gradient circle. Determines where the color stop begins. The default value 0.5.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2232
     *          <p><strong>Note: </strong>Currently, this property is not implemented for corresponding `CanvasShape` and
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2233
     *          `VMLShape` classes which are used on Android or IE 6 - 8.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2234
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2235
     *      <dt>cy</dt><dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2236
     *          <p>The y-coordinate of the center of the gradient circle. Determines where the color stop begins. The default value 0.5.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2237
     *          <p><strong>Note: </strong>Currently, this property is not implemented for corresponding `CanvasShape` and `VMLShape`
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2238
     *          classes which are used on Android or IE 6 - 8.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2239
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2240
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2241
     *  <p>These properties are not currently implemented in `CanvasShape` or `VMLShape`.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2242
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2243
	 * @config fill
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2244
	 * @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2245
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2246
	fill: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2247
		valueFn: "_getDefaultFill",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2248
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2249
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2250
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2251
			var fill,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2252
				tmpl = this.get("fill") || this._getDefaultFill();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2253
			fill = (val) ? Y.merge(tmpl, val) : null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2254
			if(fill && fill.color)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2255
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2256
				if(fill.color === undefined || fill.color === "none")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2257
				{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2258
					fill.color = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2259
				}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2260
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2261
			this._setFillProps(fill);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2262
			return fill;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2263
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2264
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2265
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2266
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2267
	 * Contains information about the stroke of the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2268
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2269
     *      <dt>color</dt><dd>The color of the stroke.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2270
     *      <dt>weight</dt><dd>Number that indicates the width of the stroke.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2271
     *      <dt>opacity</dt><dd>Number between 0 and 1 that indicates the opacity of the stroke. The default value is 1.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2272
     *      <dt>dashstyle</dt>Indicates whether to draw a dashed stroke. When set to "none", a solid stroke is drawn. When set
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2273
     *      to an array, the first index indicates the length of the dash. The second index indicates the length of gap.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2274
     *      <dt>linecap</dt><dd>Specifies the linecap for the stroke. The following values can be specified:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2275
     *          <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2276
     *              <dt>butt (default)</dt><dd>Specifies a butt linecap.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2277
     *              <dt>square</dt><dd>Specifies a sqare linecap.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2278
     *              <dt>round</dt><dd>Specifies a round linecap.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2279
     *          </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2280
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2281
     *      <dt>linejoin</dt><dd>Specifies a linejoin for the stroke. The following values can be specified:
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2282
     *          <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2283
     *              <dt>round (default)</dt><dd>Specifies that the linejoin will be round.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2284
     *              <dt>bevel</dt><dd>Specifies a bevel for the linejoin.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2285
     *              <dt>miter limit</dt><dd>An integer specifying the miter limit of a miter linejoin. If you want to specify a linejoin
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2286
     *              of miter, you simply specify the limit as opposed to having separate miter and miter limit values.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2287
     *          </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2288
     *      </dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2289
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2290
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2291
	 * @config stroke
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2292
	 * @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2293
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2294
	stroke: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2295
		valueFn: "_getDefaultStroke",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2296
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2297
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2298
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2299
			var tmpl = this.get("stroke") || this._getDefaultStroke(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2300
                wt;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2301
            if(val && val.hasOwnProperty("weight"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2302
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2303
                wt = parseInt(val.weight, 10);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2304
                if(!isNaN(wt))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2305
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2306
                    val.weight = wt;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2307
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2308
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2309
			val = (val) ? Y.merge(tmpl, val) : null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2310
			this._setStrokeProps(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2311
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2312
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2313
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2314
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2315
	//Not used. Remove in future.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2316
	autoSize: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2317
		value: false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2318
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2319
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2320
	// Only implemented in SVG
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2321
	// Determines whether the instance will receive mouse events.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2322
	//
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2323
	// @config pointerEvents
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2324
	// @type string
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2325
	//
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2326
	pointerEvents: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2327
		value: "visiblePainted"
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2328
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2329
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2330
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2331
     * Represents an SVG Path string. This will be parsed and added to shape's API to represent the SVG data across all
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2332
     * implementations. Note that when using VML or SVG implementations, part of this content will be added to the DOM using
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2333
     * respective VML/SVG attributes. If your content comes from an untrusted source, you will need to ensure that no
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2334
     * malicious code is included in that content.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2335
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2336
     * @config data
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2337
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2338
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2339
    data: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2340
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2341
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2342
            if(this.get("node"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2343
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2344
                this._parsePathData(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2345
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2346
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2347
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2348
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2349
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2350
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2351
	 * Reference to the container Graphic.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2352
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2353
	 * @config graphic
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2354
	 * @type Graphic
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2355
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2356
	graphic: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2357
		readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2358
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2359
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2360
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2361
			return this._graphic;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2362
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2363
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2364
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2365
Y.CanvasShape = CanvasShape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2366
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2367
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Path.html">`Path`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2368
 * `CanvasPath` is not intended to be used directly. Instead, use the <a href="Path.html">`Path`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2369
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2370
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Path.html">`Path`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2371
 * class will point to the `CanvasPath` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2372
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2373
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2374
 * @class CanvasPath
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2375
 * @extends CanvasShape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2376
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2377
CanvasPath = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2378
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2379
	CanvasPath.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2380
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2381
CanvasPath.NAME = "path";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2382
Y.extend(CanvasPath, Y.CanvasShape, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2383
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2384
     * Indicates the type of shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2385
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2386
     * @property _type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2387
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2388
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2389
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2390
    _type: "path",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2391
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2392
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2393
	 * Draws the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2394
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2395
	 * @method _draw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2396
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2397
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2398
    _draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2399
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2400
        this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2401
        this._updateTransform();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2402
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2403
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2404
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2405
	 * Creates the dom node for the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2406
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2407
     * @method createNode
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2408
	 * @return HTMLElement
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2409
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2410
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2411
	createNode: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2412
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2413
		var host = this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2414
            node = Y.config.doc.createElement('canvas'),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2415
			name = host.name,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2416
            concat = host._camelCaseConcat,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2417
            id = host.get("id");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2418
		host._context = node.getContext('2d');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2419
		node.setAttribute("overflow", "visible");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2420
        node.setAttribute("pointer-events", "none");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2421
        node.style.pointerEvents = "none";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2422
        node.style.overflow = "visible";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2423
		node.setAttribute("id", id);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2424
		id = "#" + id;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2425
		host.node = node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2426
		host.addClass(
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2427
            _getClassName(SHAPE) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2428
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2429
            _getClassName(concat(IMPLEMENTATION, SHAPE)) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2430
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2431
            _getClassName(name) +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2432
            " " +
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2433
            _getClassName(concat(IMPLEMENTATION, name))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2434
        );
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2435
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2436
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2437
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2438
     * Completes a drawing operation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2439
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2440
     * @method end
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2441
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2442
    end: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2443
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2444
        this._draw();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2445
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2446
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2447
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2448
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2449
CanvasPath.ATTRS = Y.merge(Y.CanvasShape.ATTRS, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2450
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2451
	 * Indicates the width of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2452
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2453
	 * @config width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2454
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2455
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2456
	width: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2457
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2458
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2459
			var offset = this._stroke && this._strokeWeight ? (this._strokeWeight * 2) : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2460
			return this._width - offset;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2461
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2462
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2463
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2464
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2465
			this._width = val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2466
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2467
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2468
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2469
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2470
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2471
	 * Indicates the height of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2472
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2473
	 * @config height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2474
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2475
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2476
	height: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2477
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2478
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2479
			var offset = this._stroke && this._strokeWeight ? (this._strokeWeight * 2) : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2480
            return this._height - offset;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2481
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2482
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2483
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2484
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2485
			this._height = val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2486
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2487
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2488
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2489
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2490
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2491
	 * Indicates the path used for the node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2492
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2493
	 * @config path
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2494
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2495
     * @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2496
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2497
	path: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2498
        readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2499
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2500
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2501
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2502
			return this._path;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2503
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2504
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2505
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2506
Y.CanvasPath = CanvasPath;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2507
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2508
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Rect.html">`Rect`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2509
 * `CanvasRect` is not intended to be used directly. Instead, use the <a href="Rect.html">`Rect`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2510
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2511
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Rect.html">`Rect`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2512
 * class will point to the `CanvasRect` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2513
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2514
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2515
 * @class CanvasRect
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2516
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2517
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2518
CanvasRect = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2519
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2520
	CanvasRect.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2521
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2522
CanvasRect.NAME = "rect";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2523
Y.extend(CanvasRect, Y.CanvasShape, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2524
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2525
	 * Indicates the type of shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2526
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2527
	 * @property _type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2528
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2529
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2530
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2531
	_type: "rect",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2532
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2533
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2534
	 * Draws the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2535
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2536
	 * @method _draw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2537
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2538
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2539
	_draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2540
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2541
		var w = this.get("width"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2542
			h = this.get("height");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2543
		this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2544
        this.drawRect(0, 0, w, h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2545
		this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2546
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2547
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2548
CanvasRect.ATTRS = Y.CanvasShape.ATTRS;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2549
Y.CanvasRect = CanvasRect;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2550
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2551
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Ellipse.html">`Ellipse`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2552
 * `CanvasEllipse` is not intended to be used directly. Instead, use the <a href="Ellipse.html">`Ellipse`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2553
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2554
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Ellipse.html">`Ellipse`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2555
 * class will point to the `CanvasEllipse` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2556
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2557
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2558
 * @class CanvasEllipse
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2559
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2560
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2561
CanvasEllipse = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2562
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2563
	CanvasEllipse.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2564
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2565
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2566
CanvasEllipse.NAME = "ellipse";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2567
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2568
Y.extend(CanvasEllipse, CanvasShape, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2569
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2570
	 * Indicates the type of shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2571
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2572
	 * @property _type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2573
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2574
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2575
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2576
	_type: "ellipse",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2577
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2578
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2579
     * Draws the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2580
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2581
     * @method _draw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2582
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2583
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2584
	_draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2585
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2586
		var w = this.get("width"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2587
			h = this.get("height");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2588
		this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2589
        this.drawEllipse(0, 0, w, h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2590
		this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2591
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2592
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2593
CanvasEllipse.ATTRS = Y.merge(CanvasShape.ATTRS, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2594
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2595
	 * Horizontal radius for the ellipse.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2596
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2597
	 * @config xRadius
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2598
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2599
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2600
	xRadius: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2601
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2602
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2603
			this.set("width", val * 2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2604
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2605
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2606
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2607
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2608
			var val = this.get("width");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2609
			if(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2610
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2611
				val *= 0.5;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2612
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2613
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2614
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2615
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2616
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2617
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2618
	 * Vertical radius for the ellipse.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2619
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2620
	 * @config yRadius
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2621
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2622
	 * @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2623
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2624
	yRadius: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2625
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2626
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2627
			this.set("height", val * 2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2628
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2629
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2630
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2631
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2632
			var val = this.get("height");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2633
			if(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2634
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2635
				val *= 0.5;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2636
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2637
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2638
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2639
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2640
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2641
Y.CanvasEllipse = CanvasEllipse;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2642
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2643
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the <a href="Circle.html">`Circle`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2644
 * `CanvasCircle` is not intended to be used directly. Instead, use the <a href="Circle.html">`Circle`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2645
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2646
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Circle.html">`Circle`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2647
 * class will point to the `CanvasCircle` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2648
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2649
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2650
 * @class CanvasCircle
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2651
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2652
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2653
CanvasCircle = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2654
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2655
	CanvasCircle.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2656
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2657
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2658
CanvasCircle.NAME = "circle";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2659
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2660
Y.extend(CanvasCircle, Y.CanvasShape, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2661
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2662
	 * Indicates the type of shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2663
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2664
	 * @property _type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2665
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2666
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2667
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2668
	_type: "circle",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2669
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2670
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2671
     * Draws the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2672
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2673
     * @method _draw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2674
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2675
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2676
	_draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2677
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2678
		var radius = this.get("radius");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2679
		if(radius)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2680
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2681
            this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2682
            this.drawCircle(0, 0, radius);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2683
			this._closePath();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2684
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2685
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2686
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2687
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2688
CanvasCircle.ATTRS = Y.merge(Y.CanvasShape.ATTRS, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2689
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2690
	 * Indicates the width of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2691
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2692
	 * @config width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2693
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2694
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2695
	width: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2696
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2697
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2698
            this.set("radius", val/2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2699
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2700
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2701
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2702
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2703
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2704
			return this.get("radius") * 2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2705
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2706
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2707
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2708
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2709
	 * Indicates the height of the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2710
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2711
	 * @config height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2712
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2713
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2714
	height: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2715
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2716
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2717
            this.set("radius", val/2);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2718
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2719
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2720
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2721
		getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2722
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2723
			return this.get("radius") * 2;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2724
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2725
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2726
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2727
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2728
	 * Radius of the circle
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2729
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2730
	 * @config radius
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2731
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2732
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2733
	radius: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2734
		lazyAdd: false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2735
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2736
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2737
Y.CanvasCircle = CanvasCircle;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2738
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2739
 * Draws pie slices
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2740
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2741
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2742
 * @class CanvasPieSlice
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2743
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2744
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2745
CanvasPieSlice = function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2746
{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2747
	CanvasPieSlice.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2748
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2749
CanvasPieSlice.NAME = "canvasPieSlice";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2750
Y.extend(CanvasPieSlice, Y.CanvasShape, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2751
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2752
     * Indicates the type of shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2753
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2754
     * @property _type
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2755
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2756
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2757
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2758
    _type: "path",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2759
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2760
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2761
	 * Change event listener
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2762
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2763
	 * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2764
	 * @method _updateHandler
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2765
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2766
	_draw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2767
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2768
        var x = this.get("cx"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2769
            y = this.get("cy"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2770
            startAngle = this.get("startAngle"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2771
            arc = this.get("arc"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2772
            radius = this.get("radius");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2773
        this.clear();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2774
        this._left = x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2775
        this._right = radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2776
        this._top = y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2777
        this._bottom = radius;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2778
        this.drawWedge(x, y, startAngle, arc, radius);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2779
		this.end();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2780
	}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2781
 });
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2782
CanvasPieSlice.ATTRS = Y.mix({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2783
    cx: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2784
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2785
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2786
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2787
    cy: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2788
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2789
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2790
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2791
     * Starting angle in relation to a circle in which to begin the pie slice drawing.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2792
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2793
     * @config startAngle
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2794
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2795
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2796
    startAngle: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2797
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2798
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2799
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2800
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2801
     * Arc of the slice.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2802
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2803
     * @config arc
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2804
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2805
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2806
    arc: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2807
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2808
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2809
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2810
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2811
     * Radius of the circle in which the pie slice is drawn
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2812
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2813
     * @config radius
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2814
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2815
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2816
    radius: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2817
        value: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2818
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2819
}, Y.CanvasShape.ATTRS);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2820
Y.CanvasPieSlice = CanvasPieSlice;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2821
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2822
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> implementation of the `Graphic` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2823
 * `CanvasGraphic` is not intended to be used directly. Instead, use the <a href="Graphic.html">`Graphic`</a> class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2824
 * If the browser lacks <a href="http://www.w3.org/TR/SVG/">SVG</a> capabilities but has
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2825
 * <a href="http://www.w3.org/TR/html5/the-canvas-element.html">Canvas</a> capabilities, the <a href="Graphic.html">`Graphic`</a>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2826
 * class will point to the `CanvasGraphic` class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2827
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2828
 * @module graphics
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2829
 * @class CanvasGraphic
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2830
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2831
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2832
function CanvasGraphic() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2833
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2834
    CanvasGraphic.superclass.constructor.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2835
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2836
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2837
CanvasGraphic.NAME = "canvasGraphic";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2838
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2839
CanvasGraphic.ATTRS = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2840
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2841
     * Whether or not to render the `Graphic` automatically after to a specified parent node after init. This can be a Node
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2842
     * instance or a CSS selector string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2843
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2844
     * @config render
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2845
     * @type Node | String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2846
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2847
    render: {},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2848
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2849
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2850
	 * Unique id for class instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2851
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2852
	 * @config id
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2853
	 * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2854
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2855
	id: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2856
		valueFn: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2857
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2858
			return Y.guid();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2859
		},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2860
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2861
		setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2862
		{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2863
			var node = this._node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2864
			if(node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2865
			{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2866
				node.setAttribute("id", val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2867
			}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2868
			return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2869
		}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2870
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2871
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2872
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2873
     * Key value pairs in which a shape instance is associated with its id.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2874
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2875
     *  @config shapes
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2876
     *  @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2877
     *  @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2878
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2879
    shapes: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2880
        readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2881
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2882
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2883
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2884
            return this._shapes;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2885
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2886
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2887
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2888
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2889
     *  Object containing size and coordinate data for the content of a Graphic in relation to the graphic instance's position.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2890
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2891
     *  @config contentBounds
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2892
     *  @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2893
     *  @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2894
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2895
    contentBounds: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2896
        readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2897
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2898
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2899
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2900
            return this._contentBounds;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2901
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2902
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2903
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2904
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2905
     *  The outermost html element of the Graphic instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2906
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2907
     *  @config node
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2908
     *  @type HTMLElement
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2909
     *  @readOnly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2910
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2911
    node: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2912
        readOnly: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2913
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2914
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2915
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2916
            return this._node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2917
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2918
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2919
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2920
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2921
	 * Indicates the width of the `Graphic`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2922
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2923
	 * @config width
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2924
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2925
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2926
    width: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2927
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2928
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2929
            if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2930
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2931
                this._node.style.width = val + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2932
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2933
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2934
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2935
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2936
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2937
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2938
	 * Indicates the height of the `Graphic`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2939
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2940
	 * @config height
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2941
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2942
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2943
    height: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2944
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2945
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2946
            if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2947
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2948
                this._node.style.height = val + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2949
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2950
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2951
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2952
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2953
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2954
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2955
     *  Determines the sizing of the Graphic.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2956
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2957
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2958
     *      <dt>sizeContentToGraphic</dt><dd>The Graphic's width and height attributes are, either explicitly set through the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2959
     *      <code>width</code> and <code>height</code> attributes or are determined by the dimensions of the parent element. The
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2960
     *      content contained in the Graphic will be sized to fit with in the Graphic instance's dimensions. When using this
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2961
     *      setting, the <code>preserveAspectRatio</code> attribute will determine how the contents are sized.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2962
     *      <dt>sizeGraphicToContent</dt><dd>(Also accepts a value of true) The Graphic's width and height are determined by the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2963
     *      size and positioning of the content.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2964
     *      <dt>false</dt><dd>The Graphic's width and height attributes are, either explicitly set through the <code>width</code>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2965
     *      and <code>height</code> attributes or are determined by the dimensions of the parent element. The contents of the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2966
     *      Graphic instance are not affected by this setting.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2967
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2968
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2969
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2970
     *  @config autoSize
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2971
     *  @type Boolean | String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2972
     *  @default false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2973
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2974
    autoSize: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2975
        value: false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2976
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2977
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2978
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2979
     * Determines how content is sized when <code>autoSize</code> is set to <code>sizeContentToGraphic</code>.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2980
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2981
     *  <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2982
     *      <dt>none<dt><dd>Do not force uniform scaling. Scale the graphic content of the given element non-uniformly if necessary
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2983
     *      such that the element's bounding box exactly matches the viewport rectangle.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2984
     *      <dt>xMinYMin</dt><dd>Force uniform scaling position along the top left of the Graphic's node.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2985
     *      <dt>xMidYMin</dt><dd>Force uniform scaling horizontally centered and positioned at the top of the Graphic's node.<dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2986
     *      <dt>xMaxYMin</dt><dd>Force uniform scaling positioned horizontally from the right and vertically from the top.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2987
     *      <dt>xMinYMid</dt>Force uniform scaling positioned horizontally from the left and vertically centered.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2988
     *      <dt>xMidYMid (the default)</dt><dd>Force uniform scaling with the content centered.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2989
     *      <dt>xMaxYMid</dt><dd>Force uniform scaling positioned horizontally from the right and vertically centered.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2990
     *      <dt>xMinYMax</dt><dd>Force uniform scaling positioned horizontally from the left and vertically from the bottom.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2991
     *      <dt>xMidYMax</dt><dd>Force uniform scaling horizontally centered and position vertically from the bottom.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2992
     *      <dt>xMaxYMax</dt><dd>Force uniform scaling positioned horizontally from the right and vertically from the bottom.</dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2993
     *  </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2994
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2995
     * @config preserveAspectRatio
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2996
     * @type String
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2997
     * @default xMidYMid
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2998
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  2999
    preserveAspectRatio: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3000
        value: "xMidYMid"
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3001
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3002
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3003
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3004
     * The contentBounds will resize to greater values but not smaller values. (for performance)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3005
     * When resizing the contentBounds down is desirable, set the resizeDown value to true.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3006
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3007
     * @config resizeDown
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3008
     * @type Boolean
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3009
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3010
    resizeDown: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3011
        value: false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3012
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3013
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3014
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3015
	 * Indicates the x-coordinate for the instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3016
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3017
	 * @config x
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3018
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3019
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3020
    x: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3021
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3022
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3023
            return this._x;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3024
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3025
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3026
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3027
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3028
            this._x = val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3029
            if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3030
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3031
                this._node.style.left = val + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3032
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3033
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3034
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3035
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3036
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3037
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3038
	 * Indicates the y-coordinate for the instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3039
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3040
	 * @config y
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3041
	 * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3042
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3043
    y: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3044
        getter: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3045
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3046
            return this._y;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3047
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3048
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3049
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3050
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3051
            this._y = val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3052
            if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3053
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3054
                this._node.style.top = val + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3055
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3056
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3057
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3058
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3059
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3060
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3061
     * Indicates whether or not the instance will automatically redraw after a change is made to a shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3062
     * This property will get set to false when batching operations.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3063
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3064
     * @config autoDraw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3065
     * @type Boolean
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3066
     * @default true
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3067
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3068
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3069
    autoDraw: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3070
        value: true
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3071
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3072
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3073
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3074
	 * Indicates whether the `Graphic` and its children are visible.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3075
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3076
	 * @config visible
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3077
	 * @type Boolean
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3078
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3079
    visible: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3080
        value: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3081
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3082
        setter: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3083
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3084
            this._toggleVisible(val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3085
            return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3086
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3087
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3088
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3089
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3090
Y.extend(CanvasGraphic, Y.GraphicBase, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3091
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3092
     * Sets the value of an attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3093
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3094
     * @method set
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3095
     * @param {String|Object} name The name of the attribute. Alternatively, an object of key value pairs can
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3096
     * be passed in to set multiple attributes at once.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3097
     * @param {Any} value The value to set the attribute to. This value is ignored if an object is received as
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3098
     * the name param.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3099
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3100
	set: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3101
	{
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3102
		var host = this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3103
            attr = arguments[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3104
            redrawAttrs = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3105
                autoDraw: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3106
                autoSize: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3107
                preserveAspectRatio: true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3108
                resizeDown: true
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3109
            },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3110
            key,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3111
            forceRedraw = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3112
		AttributeLite.prototype.set.apply(host, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3113
        if(host._state.autoDraw === true && Y.Object.size(this._shapes) > 0)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3114
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3115
            if(Y_LANG.isString && redrawAttrs[attr])
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3116
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3117
                forceRedraw = true;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3118
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3119
            else if(Y_LANG.isObject(attr))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3120
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3121
                for(key in redrawAttrs)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3122
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3123
                    if(redrawAttrs.hasOwnProperty(key) && attr[key])
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3124
                    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3125
                        forceRedraw = true;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3126
                        break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3127
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3128
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3129
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3130
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3131
        if(forceRedraw)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3132
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3133
            host._redraw();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3134
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3135
	},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3136
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3137
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3138
     * Storage for `x` attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3139
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3140
     * @property _x
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3141
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3142
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3143
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3144
    _x: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3145
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3146
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3147
     * Storage for `y` attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3148
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3149
     * @property _y
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3150
     * @type Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3151
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3152
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3153
    _y: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3154
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3155
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3156
     * Gets the current position of the graphic instance in page coordinates.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3157
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3158
     * @method getXY
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3159
     * @return Array The XY position of the shape.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3160
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3161
    getXY: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3162
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3163
        var node = this._node,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3164
            xy;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3165
        if(node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3166
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3167
            xy = Y.DOM.getXY(node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3168
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3169
        return xy;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3170
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3171
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3172
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3173
     * Initializes the class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3174
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3175
     * @method initializer
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3176
     * @param {Object} config Optional attributes
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3177
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3178
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3179
    initializer: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3180
        var render = this.get("render"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3181
            visibility = this.get("visible") ? "visible" : "hidden",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3182
            w = this.get("width") || 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3183
            h = this.get("height") || 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3184
        this._shapes = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3185
        this._redrawQueue = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3186
		this._contentBounds = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3187
            left: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3188
            top: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3189
            right: 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3190
            bottom: 0
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3191
        };
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3192
        this._node = DOCUMENT.createElement('div');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3193
        this._node.style.position = "absolute";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3194
        this._node.style.visibility = visibility;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3195
        this.set("width", w);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3196
        this.set("height", h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3197
        if(render)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3198
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3199
            this.render(render);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3200
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3201
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3202
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3203
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3204
     * Adds the graphics node to the dom.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3205
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3206
     * @method render
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3207
     * @param {HTMLElement} parentNode node in which to render the graphics node into.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3208
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3209
    render: function(render) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3210
        var parentNode = render || DOCUMENT.body,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3211
            node = this._node,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3212
            w,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3213
            h;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3214
        if(render instanceof Y.Node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3215
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3216
            parentNode = render._node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3217
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3218
        else if(Y.Lang.isString(render))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3219
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3220
            parentNode = Y.Selector.query(render, DOCUMENT.body, true);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3221
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3222
        w = this.get("width") || parseInt(Y.DOM.getComputedStyle(parentNode, "width"), 10);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3223
        h = this.get("height") || parseInt(Y.DOM.getComputedStyle(parentNode, "height"), 10);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3224
        parentNode.appendChild(node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3225
        node.style.display = "block";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3226
        node.style.position = "absolute";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3227
        node.style.left = this.get("x") + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3228
        node.style.top = this.get("y") + "px";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3229
        this.set("width", w);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3230
        this.set("height", h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3231
        this.parentNode = parentNode;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3232
        return this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3233
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3234
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3235
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3236
     * Removes all nodes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3237
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3238
     * @method destroy
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3239
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3240
    destroy: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3241
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3242
        this.removeAllShapes();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3243
        if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3244
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3245
            this._removeChildren(this._node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3246
            if(this._node.parentNode)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3247
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3248
                this._node.parentNode.removeChild(this._node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3249
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3250
            this._node = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3251
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3252
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3253
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3254
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3255
     * Generates a shape instance by type.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3256
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3257
     * @method addShape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3258
     * @param {Object} cfg attributes for the shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3259
     * @return Shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3260
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3261
    addShape: function(cfg)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3262
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3263
        cfg.graphic = this;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3264
        if(!this.get("visible"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3265
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3266
            cfg.visible = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3267
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3268
        var ShapeClass = this._getShapeClass(cfg.type),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3269
            shape = new ShapeClass(cfg);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3270
        this._appendShape(shape);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3271
        return shape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3272
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3273
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3274
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3275
     * Adds a shape instance to the graphic instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3276
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3277
     * @method _appendShape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3278
     * @param {Shape} shape The shape instance to be added to the graphic.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3279
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3280
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3281
    _appendShape: function(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3282
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3283
        var node = shape.node,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3284
            parentNode = this._frag || this._node;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3285
        if(this.get("autoDraw"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3286
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3287
            parentNode.appendChild(node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3288
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3289
        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3290
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3291
            this._getDocFrag().appendChild(node);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3292
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3293
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3294
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3295
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3296
     * Removes a shape instance from from the graphic instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3297
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3298
     * @method removeShape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3299
     * @param {Shape|String} shape The instance or id of the shape to be removed.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3300
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3301
    removeShape: function(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3302
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3303
        if(!(shape instanceof CanvasShape))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3304
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3305
            if(Y_LANG.isString(shape))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3306
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3307
                shape = this._shapes[shape];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3308
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3309
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3310
        if(shape && shape instanceof CanvasShape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3311
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3312
            shape._destroy();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3313
            delete this._shapes[shape.get("id")];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3314
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3315
        if(this.get("autoDraw"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3316
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3317
            this._redraw();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3318
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3319
        return shape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3320
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3321
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3322
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3323
     * Removes all shape instances from the dom.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3324
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3325
     * @method removeAllShapes
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3326
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3327
    removeAllShapes: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3328
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3329
        var shapes = this._shapes,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3330
            i;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3331
        for(i in shapes)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3332
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3333
            if(shapes.hasOwnProperty(i))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3334
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3335
                shapes[i].destroy();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3336
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3337
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3338
        this._shapes = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3339
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3340
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3341
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3342
     * Clears the graphics object.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3343
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3344
     * @method clear
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3345
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3346
    clear: function() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3347
        this.removeAllShapes();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3348
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3349
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3350
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3351
     * Removes all child nodes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3352
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3353
     * @method _removeChildren
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3354
     * @param {HTMLElement} node
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3355
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3356
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3357
    _removeChildren: function(node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3358
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3359
        if(node && node.hasChildNodes())
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3360
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3361
            var child;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3362
            while(node.firstChild)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3363
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3364
                child = node.firstChild;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3365
                this._removeChildren(child);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3366
                node.removeChild(child);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3367
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3368
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3369
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3370
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3371
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3372
     * Toggles visibility
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3373
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3374
     * @method _toggleVisible
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3375
     * @param {Boolean} val indicates visibilitye
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3376
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3377
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3378
    _toggleVisible: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3379
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3380
        var i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3381
            shapes = this._shapes,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3382
            visibility = val ? "visible" : "hidden";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3383
        if(shapes)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3384
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3385
            for(i in shapes)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3386
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3387
                if(shapes.hasOwnProperty(i))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3388
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3389
                    shapes[i].set("visible", val);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3390
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3391
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3392
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3393
        if(this._node)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3394
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3395
            this._node.style.visibility = visibility;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3396
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3397
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3398
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3399
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3400
     * Returns a shape class. Used by `addShape`.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3401
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3402
     * @method _getShapeClass
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3403
     * @param {Shape | String} val Indicates which shape class.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3404
     * @return Function
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3405
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3406
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3407
    _getShapeClass: function(val)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3408
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3409
        var shape = this._shapeClass[val];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3410
        if(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3411
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3412
            return shape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3413
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3414
        return val;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3415
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3416
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3417
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3418
     * Look up for shape classes. Used by `addShape` to retrieve a class for instantiation.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3419
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3420
     * @property _shapeClass
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3421
     * @type Object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3422
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3423
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3424
    _shapeClass: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3425
        circle: Y.CanvasCircle,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3426
        rect: Y.CanvasRect,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3427
        path: Y.CanvasPath,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3428
        ellipse: Y.CanvasEllipse,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3429
        pieslice: Y.CanvasPieSlice
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3430
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3431
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3432
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3433
     * Returns a shape based on the id of its dom node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3434
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3435
     * @method getShapeById
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3436
     * @param {String} id Dom id of the shape's node attribute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3437
     * @return Shape
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3438
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3439
    getShapeById: function(id)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3440
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3441
        var shape = this._shapes[id];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3442
        return shape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3443
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3444
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3445
	/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3446
	 * Allows for creating multiple shapes in order to batch appending and redraw operations.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3447
	 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3448
	 * @method batch
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3449
	 * @param {Function} method Method to execute.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3450
	 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3451
    batch: function(method)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3452
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3453
        var autoDraw = this.get("autoDraw");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3454
        this.set("autoDraw", false);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3455
        method();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3456
        this.set("autoDraw", autoDraw);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3457
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3458
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3459
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3460
     * Returns a document fragment to for attaching shapes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3461
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3462
     * @method _getDocFrag
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3463
     * @return DocumentFragment
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3464
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3465
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3466
    _getDocFrag: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3467
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3468
        if(!this._frag)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3469
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3470
            this._frag = DOCUMENT.createDocumentFragment();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3471
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3472
        return this._frag;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3473
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3474
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3475
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3476
     * Redraws all shapes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3477
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3478
     * @method _redraw
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3479
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3480
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3481
    _redraw: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3482
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3483
        var autoSize = this.get("autoSize"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3484
            preserveAspectRatio = this.get("preserveAspectRatio"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3485
            box = this.get("resizeDown") ? this._getUpdatedContentBounds() : this._contentBounds,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3486
            contentWidth,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3487
            contentHeight,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3488
            w,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3489
            h,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3490
            xScale,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3491
            yScale,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3492
            translateX = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3493
            translateY = 0,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3494
            matrix,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3495
            node = this.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3496
        if(autoSize)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3497
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3498
            if(autoSize === "sizeContentToGraphic")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3499
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3500
                contentWidth = box.right - box.left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3501
                contentHeight = box.bottom - box.top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3502
                w = parseFloat(Y_DOM.getComputedStyle(node, "width"));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3503
                h = parseFloat(Y_DOM.getComputedStyle(node, "height"));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3504
                matrix = new Y.Matrix();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3505
                if(preserveAspectRatio === "none")
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3506
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3507
                    xScale = w/contentWidth;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3508
                    yScale = h/contentHeight;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3509
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3510
                else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3511
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3512
                    if(contentWidth/contentHeight !== w/h)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3513
                    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3514
                        if(contentWidth * h/contentHeight > w)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3515
                        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3516
                            xScale = yScale = w/contentWidth;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3517
                            translateY = this._calculateTranslate(preserveAspectRatio.slice(5).toLowerCase(), contentHeight * w/contentWidth, h);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3518
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3519
                        else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3520
                        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3521
                            xScale = yScale = h/contentHeight;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3522
                            translateX = this._calculateTranslate(preserveAspectRatio.slice(1, 4).toLowerCase(), contentWidth * h/contentHeight, w);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3523
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3524
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3525
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3526
                Y_DOM.setStyle(node, "transformOrigin", "0% 0%");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3527
                translateX = translateX - (box.left * xScale);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3528
                translateY = translateY - (box.top * yScale);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3529
                matrix.translate(translateX, translateY);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3530
                matrix.scale(xScale, yScale);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3531
                Y_DOM.setStyle(node, "transform", matrix.toCSSText());
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3532
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3533
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3534
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3535
                this.set("width", box.right);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3536
                this.set("height", box.bottom);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3537
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3538
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3539
        if(this._frag)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3540
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3541
            this._node.appendChild(this._frag);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3542
            this._frag = null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3543
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3544
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3545
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3546
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3547
     * Determines the value for either an x or y value to be used for the <code>translate</code> of the Graphic.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3548
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3549
     * @method _calculateTranslate
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3550
     * @param {String} position The position for placement. Possible values are min, mid and max.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3551
     * @param {Number} contentSize The total size of the content.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3552
     * @param {Number} boundsSize The total size of the Graphic.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3553
     * @return Number
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3554
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3555
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3556
    _calculateTranslate: function(position, contentSize, boundsSize)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3557
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3558
        var ratio = boundsSize - contentSize,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3559
            coord;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3560
        switch(position)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3561
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3562
            case "mid" :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3563
                coord = ratio * 0.5;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3564
            break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3565
            case "max" :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3566
                coord = ratio;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3567
            break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3568
            default :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3569
                coord = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3570
            break;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3571
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3572
        return coord;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3573
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3574
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3575
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3576
     * Adds a shape to the redraw queue and calculates the contentBounds. Used internally
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3577
     * by `Shape` instances.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3578
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3579
     * @method addToRedrawQueue
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3580
     * @param Shape shape The shape instance to add to the queue
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3581
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3582
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3583
    addToRedrawQueue: function(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3584
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3585
        var shapeBox,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3586
            box;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3587
        this._shapes[shape.get("id")] = shape;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3588
        if(!this.get("resizeDown"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3589
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3590
            shapeBox = shape.getBounds();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3591
            box = this._contentBounds;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3592
            box.left = box.left < shapeBox.left ? box.left : shapeBox.left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3593
            box.top = box.top < shapeBox.top ? box.top : shapeBox.top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3594
            box.right = box.right > shapeBox.right ? box.right : shapeBox.right;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3595
            box.bottom = box.bottom > shapeBox.bottom ? box.bottom : shapeBox.bottom;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3596
            this._contentBounds = box;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3597
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3598
        if(this.get("autoDraw"))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3599
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3600
            this._redraw();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3601
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3602
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3603
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3604
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3605
     * Recalculates and returns the `contentBounds` for the `Graphic` instance.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3606
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3607
     * @method _getUpdatedContentBounds
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3608
     * @return {Object}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3609
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3610
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3611
    _getUpdatedContentBounds: function()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3612
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3613
        var bounds,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3614
            i,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3615
            shape,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3616
            queue = this._shapes,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3617
            box = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3618
        for(i in queue)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3619
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3620
            if(queue.hasOwnProperty(i))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3621
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3622
                shape = queue[i];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3623
                bounds = shape.getBounds();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3624
                box.left = Y_LANG.isNumber(box.left) ? Math.min(box.left, bounds.left) : bounds.left;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3625
                box.top = Y_LANG.isNumber(box.top) ? Math.min(box.top, bounds.top) : bounds.top;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3626
                box.right = Y_LANG.isNumber(box.right) ? Math.max(box.right, bounds.right) : bounds.right;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3627
                box.bottom = Y_LANG.isNumber(box.bottom) ? Math.max(box.bottom, bounds.bottom) : bounds.bottom;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3628
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3629
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3630
        box.left = Y_LANG.isNumber(box.left) ? box.left : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3631
        box.top = Y_LANG.isNumber(box.top) ? box.top : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3632
        box.right = Y_LANG.isNumber(box.right) ? box.right : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3633
        box.bottom = Y_LANG.isNumber(box.bottom) ? box.bottom : 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3634
        this._contentBounds = box;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3635
        return box;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3636
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3637
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3638
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3639
     * Inserts shape on the top of the tree.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3640
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3641
     * @method _toFront
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3642
     * @param {CanvasShape} Shape to add.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3643
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3644
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3645
    _toFront: function(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3646
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3647
        var contentNode = this.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3648
        if(shape instanceof Y.CanvasShape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3649
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3650
            shape = shape.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3651
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3652
        if(contentNode && shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3653
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3654
            contentNode.appendChild(shape);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3655
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3656
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3657
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3658
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3659
     * Inserts shape as the first child of the content node.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3660
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3661
     * @method _toBack
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3662
     * @param {CanvasShape} Shape to add.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3663
     * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3664
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3665
    _toBack: function(shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3666
    {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3667
        var contentNode = this.get("node"),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3668
            targetNode;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3669
        if(shape instanceof Y.CanvasShape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3670
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3671
            shape = shape.get("node");
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3672
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3673
        if(contentNode && shape)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3674
        {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3675
            targetNode = contentNode.firstChild;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3676
            if(targetNode)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3677
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3678
                contentNode.insertBefore(shape, targetNode);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3679
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3680
            else
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3681
            {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3682
                contentNode.appendChild(shape);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3683
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3684
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3685
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3686
});
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3687
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3688
Y.CanvasGraphic = CanvasGraphic;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3689
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3690
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
  3691
}, '@VERSION@', {"requires": ["graphics"]});