From ec56136a1a3cd83f856723d1076536e550296e31 Mon Sep 17 00:00:00 2001 From: wout Date: Sat, 2 Feb 2013 17:34:25 +0100 Subject: Added SVG.Line as a native element --- dist/svg.js | 49 ++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 48 insertions(+), 1 deletion(-) (limited to 'dist/svg.js') diff --git a/dist/svg.js b/dist/svg.js index 5b6461c..92fd6ca 100644 --- a/dist/svg.js +++ b/dist/svg.js @@ -1,4 +1,4 @@ -/* svg.js v0.4-1-g7323d05 - svg element container fx event group arrange defs mask pattern gradient doc shape wrap rect ellipse poly path image text nested sugar - svgjs.com/license */ +/* svg.js v0.4-2-g1c9b6af - svg element container fx event group arrange defs mask pattern gradient doc shape wrap rect ellipse line poly path image text nested sugar - svgjs.com/license */ (function() { this.svg = function(element) { @@ -1180,6 +1180,53 @@ // draw.ellipse(200, 100); + SVG.Line = function Line() { + this.constructor.call(this, SVG.create('line')); + }; + + // Inherit from SVG.Shape + SVG.Line.prototype = new SVG.Shape(); + + // Add required methods + SVG.extend(SVG.Line, { + // Move line + move: function(x, y) { + var bbox = this.bbox(); + + return this.attr({ + x1: this.attr('x1') - bbox.x + x, + y1: this.attr('y1') - bbox.y + y, + x2: this.attr('x2') - bbox.x + x, + y2: this.attr('y2') - bbox.y + y + }); + }, + // Move element by its center + center: function(x, y) { + var bbox = this.bbox(); + + return this.move(x - bbox.width / 2, y - bbox.height / 2); + }, + // Set line size by width and height + size: function(width, height) { + var bbox = this.bbox(); + + this.attr(this.attr('x1') < this.attr('x2') ? 'x2' : 'x1', bbox.x + width); + return this.attr(this.attr('y1') < this.attr('y2') ? 'y2' : 'y1', bbox.y + height); + } + }); + + // Extend all container modules + SVG.extend(SVG.Container, { + line: function(x1, y1, x2, y2) { + return this.put(new SVG.Line().attr({ + x1: x1, + y1: y1, + x2: x2, + y2: y2 + })); + } + }); + SVG.Poly = { // Set polygon data with default zero point if no data is passed plot: function(points) { -- cgit v1.2.3