diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/event.js | 22 | ||||
-rw-r--r-- | src/fx.js | 1 | ||||
-rw-r--r-- | src/pattern.js | 48 | ||||
-rw-r--r-- | src/set.js | 92 | ||||
-rw-r--r-- | src/svg.js | 4 |
5 files changed, 93 insertions, 74 deletions
diff --git a/src/event.js b/src/event.js index 84022c7..2fc14bb 100644 --- a/src/event.js +++ b/src/event.js @@ -3,19 +3,15 @@ // rect.click(function() { // this.fill({ color: '#f06' }) // }) -;[ 'click' -, 'dblclick' -, 'mousedown' -, 'mouseup' -, 'mouseover' -, 'mouseout' -, 'mousemove' -, 'mouseenter' -, 'mouseleave' -, 'touchstart' -, 'touchend' -, 'touchmove' -, 'touchcancel' ].forEach(function(event) { +;[ 'click' + , 'dblclick' + , 'mousedown' + , 'mouseup' + , 'mouseover' + , 'mouseout' + , 'mousemove' + , 'mouseenter' + , 'mouseleave' ].forEach(function(event) { /* add event to SVG.Element */ SVG.Element.prototype[event] = function(f) { @@ -335,6 +335,7 @@ SVG.extend(SVG.FX, { } }) + // SVG.extend(SVG.Element, { // Get fx module or create a new one, then animate with given duration and ease diff --git a/src/pattern.js b/src/pattern.js deleted file mode 100644 index 4807049..0000000 --- a/src/pattern.js +++ /dev/null @@ -1,48 +0,0 @@ -SVG.Pattern = function(type) { - this.constructor.call(this, SVG.create('pattern')) -} - -// Inherit from SVG.Container -SVG.Pattern.prototype = new SVG.Container - -// -SVG.extend(SVG.Pattern, { - // Return the fill id - fill: function() { - return 'url(#' + this.attr('id') + ')' - } - // Alias string convertion to fill -, toString: function() { - return this.fill() - } - -}) - -// -SVG.extend(SVG.Defs, { - // Define gradient - pattern: function(width, height, block) { - var element = this.put(new SVG.Pattern) - - /* invoke passed block */ - block(element) - - return element.attr({ - x: 0 - , y: 0 - , width: width - , height: height - , patternUnits: 'userSpaceOnUse' - }) - } - -}) - -// -SVG.extend(SVG.Container, { - // Create pattern element in defs - pattern: function(width, height, block) { - return this.defs().pattern(width, height, block) - } - -})
\ No newline at end of file @@ -1,37 +1,103 @@ SVG.Set = function() { - this.children = [] + /* set initial state */ + this.clear() } +// Set FX class +SVG.SetFX = function(set) { + /* store reference to set */ + this.set = set +} + +// SVG.extend(SVG.Set, { // Add element to set add: function(element) { - this.children.push(element) + this.members.push(element) return this } // Remove element from set , remove: function(element) { - var i = this.children.indexOf(element) + var i = this.members.indexOf(element) + /* remove given child */ if (i > -1) - this.children.splice(i, 1) + this.members.splice(i, 1) + + return this + } + // Iterate over all members +, each: function(block) { + for (var i = 0, il = this.members.length; i < il; i++) + block.apply(this.members[i], [i, this.members]) return this } - // Move all children -, move: function(x, y) { - return this.x(x).y(y) + // Restore to defaults +, clear: function() { + /* initialize store */ + this.members = [] + + return this + } + // Default value +, valueOf: function() { + return this.members } }) -// Create method aliases -;['attr'].forEach(function(method) { - SVG.Set.prototype[method] = function() { - for (var i = 0, il = this.children.length; i < il; i++) - this.children[i][method](arguments) +// Alias methods +SVG.Set.inherit = function() { + var m + , methods = [] + + /* gather shape methods */ + for(var m in SVG.Shape.prototype) + if (typeof SVG.Shape.prototype[m] == 'function' && typeof SVG.Set.prototype[m] != 'function') + methods.push(m) + + /* apply shape aliasses */ + methods.forEach(function(method) { + SVG.Set.prototype[method] = function() { + for (var i = 0, il = this.members.length; i < il; i++) + if (this.members[i] && typeof this.members[i][method] == 'function') + this.members[i][method].apply(this.members[i], arguments) + + return method == 'animate' ? (this.fx || (this.fx = new SVG.SetFX(this))) : this + } + }) + + /* clear methods for the next round */ + methods = [] + + /* gather fx methods */ + for(var m in SVG.FX.prototype) + if (typeof SVG.FX.prototype[m] == 'function' && typeof SVG.SetFX.prototype[m] != 'function') + methods.push(m) + + /* apply fx aliasses */ + methods.forEach(function(method) { + SVG.SetFX.prototype[method] = function() { + for (var i = 0, il = this.set.members.length; i < il; i++) + this.set.members[i].fx[method].apply(this.set.members[i].fx, arguments) + + return this + } + }) +} + +// +SVG.extend(SVG.Container, { + // Create a new set + set: function() { + return new SVG.Set } -})
\ No newline at end of file +}) + + + @@ -49,6 +49,10 @@ SVG.extend = function() { if (modules[i]) for (key in methods) modules[i].prototype[key] = methods[key] + + /* make sure SVG.Set inherits any newly added methods */ + if (SVG.Set && SVG.Set.inherit) + SVG.Set.inherit() } // Method for getting an eleemnt by id |