diff options
Diffstat (limited to 'dist/svg.js')
-rw-r--r-- | dist/svg.js | 224 |
1 files changed, 112 insertions, 112 deletions
diff --git a/dist/svg.js b/dist/svg.js index 70096a9..fcf1042 100644 --- a/dist/svg.js +++ b/dist/svg.js @@ -6,7 +6,7 @@ * @copyright Wout Fierens <wout@impinc.co.uk> * @license MIT * -* BUILT: Fri Nov 06 2015 21:41:47 GMT+0100 (Mitteleuropäische Zeit) +* BUILT: Fri Nov 06 2015 22:21:59 GMT+0100 (Mitteleuropäische Zeit) */; (function(root, factory) { if (typeof define === 'function' && define.amd) { @@ -237,7 +237,7 @@ SVG.utils = { SVG.defaults = { // Default attribute values attrs: { - /* fill and stroke */ + // fill and stroke 'fill-opacity': 1 , 'stroke-opacity': 1 , 'stroke-width': 0 @@ -246,23 +246,23 @@ SVG.defaults = { , fill: '#000000' , stroke: '#000000' , opacity: 1 - /* position */ + // position , x: 0 , y: 0 , cx: 0 , cy: 0 - /* size */ + // size , width: 0 , height: 0 - /* radius */ + // radius , r: 0 , rx: 0 , ry: 0 - /* gradient */ + // gradient , offset: 0 , 'stop-opacity': 1 , 'stop-color': '#000000' - /* text */ + // text , 'font-size': 16 , 'font-family': 'Helvetica, Arial, sans-serif' , 'text-anchor': 'start' @@ -273,27 +273,27 @@ SVG.defaults = { SVG.Color = function(color) { var match - /* initialize defaults */ + // initialize defaults this.r = 0 this.g = 0 this.b = 0 - /* parse color */ + // parse color if (typeof color === 'string') { if (SVG.regex.isRgb.test(color)) { - /* get rgb values */ + // get rgb values match = SVG.regex.rgb.exec(color.replace(/\s/g,'')) - /* parse numeric values */ + // parse numeric values this.r = parseInt(match[1]) this.g = parseInt(match[2]) this.b = parseInt(match[3]) } else if (SVG.regex.isHex.test(color)) { - /* get hex values */ + // get hex values match = SVG.regex.hex.exec(fullHex(color)) - /* parse numeric values */ + // parse numeric values this.r = parseInt(match[1], 16) this.g = parseInt(match[2], 16) this.b = parseInt(match[3], 16) @@ -339,13 +339,13 @@ SVG.extend(SVG.Color, { } // Get morphed color at given position , at: function(pos) { - /* make sure a destination is defined */ + // make sure a destination is defined if (!this.destination) return this - /* normalise pos */ + // normalise pos pos = pos < 0 ? 0 : pos > 1 ? 1 : pos - /* generate morphed color */ + // generate morphed color return new SVG.Color({ r: ~~(this.r + (this.destination.r - this.r) * pos) , g: ~~(this.g + (this.destination.g - this.g) * pos) @@ -379,11 +379,11 @@ SVG.Color.isColor = function(color) { SVG.Array = function(array, fallback) { array = (array || []).valueOf() - /* if array is empty and fallback is provided, use fallback */ + // if array is empty and fallback is provided, use fallback if (array.length == 0 && fallback) array = fallback.valueOf() - /* parse array */ + // parse array this.value = this.parse(array) } @@ -392,7 +392,7 @@ SVG.extend(SVG.Array, { morph: function(array) { this.destination = this.parse(array) - /* normalize length of arrays */ + // normalize length of arrays if (this.value.length != this.destination.length) { var lastValue = this.value[this.value.length - 1] , lastDestination = this.destination[this.destination.length - 1] @@ -407,20 +407,20 @@ SVG.extend(SVG.Array, { } // Clean up any duplicate points , settle: function() { - /* find all unique values */ + // find all unique values for (var i = 0, il = this.value.length, seen = []; i < il; i++) if (seen.indexOf(this.value[i]) == -1) seen.push(this.value[i]) - /* set new value */ + // set new value return this.value = seen } // Get morphed array at given position , at: function(pos) { - /* make sure a destination is defined */ + // make sure a destination is defined if (!this.destination) return this - /* generate morphed array */ + // generate morphed array for (var i = 0, il = this.value.length, array = []; i < il; i++) array.push(this.value[i] + (this.destination[i] - this.value[i]) * pos) @@ -438,7 +438,7 @@ SVG.extend(SVG.Array, { , parse: function(array) { array = array.valueOf() - /* if already is an array, no need to parse it */ + // if already is an array, no need to parse it if (Array.isArray(array)) return array return this.split(array) @@ -466,7 +466,7 @@ SVG.PointArray.prototype = new SVG.Array SVG.extend(SVG.PointArray, { // Convert array to string toString: function() { - /* convert to a poly point string */ + // convert to a poly point string for (var i = 0, il = this.value.length, array = []; i < il; i++) array.push(this.value[i].join(',')) @@ -483,10 +483,10 @@ SVG.extend(SVG.PointArray, { } // Get morphed array at given position , at: function(pos) { - /* make sure a destination is defined */ + // make sure a destination is defined if (!this.destination) return this - /* generate morphed point string */ + // generate morphed point string for (var i = 0, il = this.value.length, array = []; i < il; i++) array.push([ this.value[i][0] + (this.destination[i][0] - this.value[i][0]) * pos @@ -499,13 +499,13 @@ SVG.extend(SVG.PointArray, { , parse: function(array) { array = array.valueOf() - /* if already is an array, no need to parse it */ + // if already is an array, no need to parse it if (Array.isArray(array)) return array - /* split points */ + // split points array = this.split(array) - /* parse points */ + // parse points for (var i = 0, il = array.length, p, points = []; i < il; i++) { p = array[i].split(',') points.push([parseFloat(p[0]), parseFloat(p[1])]) @@ -517,11 +517,11 @@ SVG.extend(SVG.PointArray, { , move: function(x, y) { var box = this.bbox() - /* get relative offset */ + // get relative offset x -= box.x y -= box.y - /* move every point */ + // move every point if (!isNaN(x) && !isNaN(y)) for (var i = this.value.length - 1; i >= 0; i--) this.value[i] = [this.value[i][0] + x, this.value[i][1] + y] @@ -532,7 +532,7 @@ SVG.extend(SVG.PointArray, { , size: function(width, height) { var i, box = this.bbox() - /* recalculate position of all points according to new size */ + // recalculate position of all points according to new size for (i = this.value.length - 1; i >= 0; i--) { this.value[i][0] = ((this.value[i][0] - box.x) * width) / box.width + box.x this.value[i][1] = ((this.value[i][1] - box.y) * height) / box.height + box.y @@ -563,15 +563,15 @@ SVG.extend(SVG.PathArray, { } // Move path string , move: function(x, y) { - /* get bounding box of current situation */ - var box = this.bbox() + // get bounding box of current situation + var box = this.bbox() - /* get relative offset */ + // get relative offset x -= box.x y -= box.y if (!isNaN(x) && !isNaN(y)) { - /* move every point */ + // move every point for (var l, i = this.value.length - 1; i >= 0; i--) { l = this.value[i][0] @@ -608,10 +608,10 @@ SVG.extend(SVG.PathArray, { } // Resize path string , size: function(width, height) { - /* get bounding box of current situation */ - var i, l, box = this.bbox() + // get bounding box of current situation + var i, l, box = this.bbox() - /* recalculate position of all points according to new size */ + // recalculate position of all points according to new size for (i = this.value.length - 1; i >= 0; i--) { l = this.value[i][0] @@ -637,11 +637,11 @@ SVG.extend(SVG.PathArray, { } } else if (l == 'A') { - /* resize radii */ + // resize radii this.value[i][1] = (this.value[i][1] * width) / box.width this.value[i][2] = (this.value[i][2] * height) / box.height - /* move position values */ + // move position values this.value[i][6] = ((this.value[i][6] - box.x) * width) / box.width + box.x this.value[i][7] = ((this.value[i][7] - box.y) * height) / box.height + box.y } @@ -652,25 +652,25 @@ SVG.extend(SVG.PathArray, { } // Absolutize and parse path to array , parse: function(array) { - /* if it's already is a patharray, no need to parse it */ + // if it's already is a patharray, no need to parse it if (array instanceof SVG.PathArray) return array.valueOf() - /* prepare for parsing */ + // prepare for parsing var i, il, x0, y0, x1, y1, x2, y2, s, seg, segs , x = 0 , y = 0 - /* populate working path */ + // populate working path SVG.parser.path.setAttribute('d', typeof array === 'string' ? array : arrayToString(array)) - /* get segments */ + // get segments segs = SVG.parser.path.pathSegList for (i = 0, il = segs.numberOfItems; i < il; ++i) { seg = segs.getItem(i) s = seg.pathSegTypeAsLetter - /* yes, this IS quite verbose but also about 30 times faster than .test() with a precompiled regex */ + // yes, this IS quite verbose but also about 30 times faster than .test() with a precompiled regex if (s == 'M' || s == 'L' || s == 'H' || s == 'V' || s == 'C' || s == 'S' || s == 'Q' || s == 'T' || s == 'A') { if ('x' in seg) x = seg.x if ('y' in seg) y = seg.y @@ -707,14 +707,14 @@ SVG.extend(SVG.PathArray, { } } - /* record the start of a subpath */ + // record the start of a subpath if (s == 'M' || s == 'm') { x0 = x y0 = y } } - /* build internal representation */ + // build internal representation array = [] segs = SVG.parser.path.pathSegList @@ -738,7 +738,7 @@ SVG.extend(SVG.PathArray, { else if (s == 'A') x.push(seg.r1, seg.r2, seg.angle, seg.largeArcFlag | 0, seg.sweepFlag | 0, seg.x, seg.y) - /* store segment */ + // store segment array.push(x) } @@ -854,18 +854,18 @@ SVG.Number = SVG.invent({ SVG.ViewBox = function(element) { var x, y, width, height - , wm = 1 /* width multiplier */ - , hm = 1 /* height multiplier */ + , wm = 1 // width multiplier + , hm = 1 // height multiplier , box = element.bbox() , view = (element.attr('viewBox') || '').match(/-?[\d\.]+/g) , we = element , he = element - /* get dimensions of current node */ + // get dimensions of current node width = new SVG.Number(element.width()) height = new SVG.Number(element.height()) - /* find nearest non-percentual dimensions */ + // find nearest non-percentual dimensions while (width.unit == '%') { wm *= width.value width = new SVG.Number(we instanceof SVG.Doc ? we.parent().offsetWidth : we.parent().width()) @@ -877,7 +877,7 @@ SVG.ViewBox = function(element) { he = he.parent() } - /* ensure defaults */ + // ensure defaults this.x = box.x this.y = box.y this.width = width * wm @@ -885,18 +885,18 @@ SVG.ViewBox = function(element) { this.zoom = 1 if (view) { - /* get width and height from viewbox */ + // get width and height from viewbox x = parseFloat(view[0]) y = parseFloat(view[1]) width = parseFloat(view[2]) height = parseFloat(view[3]) - /* calculate zoom accoring to viewbox */ + // calculate zoom accoring to viewbox this.zoom = ((this.width / this.height) > (width / height)) ? this.height / height : this.width / width - /* calculate real pixel dimensions on parent SVG.Doc element */ + // calculate real pixel dimensions on parent SVG.Doc element this.x = x this.y = y this.width = width @@ -2231,25 +2231,25 @@ SVG.extend(SVG.Element, { // Dynamic style generator style: function(s, v) { if (arguments.length == 0) { - /* get full style */ + // get full style return this.node.style.cssText || '' } else if (arguments.length < 2) { - /* apply every style individually if an object is passed */ + // apply every style individually if an object is passed if (typeof s == 'object') { for (v in s) this.style(v, s[v]) } else if (SVG.regex.isCss.test(s)) { - /* parse css string */ + // parse css string s = s.split(';') - /* apply every definition individually */ + // apply every definition individually for (var i = 0; i < s.length; i++) { v = s[i].split(':') this.style(v[0].replace(/\s+/g, ''), v[1]) } } else { - /* act as a getter if the first and only argument is not an object */ + // act as a getter if the first and only argument is not an object return this.node.style[camelCase(s)] } @@ -2392,10 +2392,10 @@ SVG.Container = SVG.invent({ // Get the viewBox and calculate the zoom value viewbox: function(v) { if (arguments.length == 0) - /* act as a getter if there are no arguments */ + // act as a getter if there are no arguments return new SVG.ViewBox(this) - /* otherwise act as a setter */ + // otherwise act as a setter v = arguments.length == 1 ? [v.x, v.y, v.width, v.height] : [].slice.call(arguments) @@ -2421,11 +2421,11 @@ SVG.Container = SVG.invent({ , 'touchend' , 'touchcancel' ].forEach(function(event) { - /* add event to SVG.Element */ + // add event to SVG.Element SVG.Element.prototype[event] = function(f) { var self = this - /* bind event to element rather than element node */ + // bind event to element rather than element node this.node['on' + event] = typeof f == 'function' ? function() { return f.apply(self, arguments) } : null @@ -2675,7 +2675,7 @@ SVG.Mask = SVG.invent({ create: function() { this.constructor.call(this, SVG.create('mask')) - /* keep references to masked elements */ + // keep references to masked elements this.targets = [] } @@ -2686,13 +2686,13 @@ SVG.Mask = SVG.invent({ , extend: { // Unmask all masked elements and remove itself remove: function() { - /* unmask all targets */ + // unmask all targets for (var i = this.targets.length - 1; i >= 0; i--) if (this.targets[i]) this.targets[i].unmask() delete this.targets - /* remove mask from parent */ + // remove mask from parent this.parent().removeElement(this) return this @@ -2712,13 +2712,13 @@ SVG.Mask = SVG.invent({ SVG.extend(SVG.Element, { // Distribute mask to svg element maskWith: function(element) { - /* use given mask or create a new one */ + // use given mask or create a new one this.masker = element instanceof SVG.Mask ? element : this.parent().mask().add(element) - /* store reverence on self in mask */ + // store reverence on self in mask this.masker.targets.push(this) - /* apply mask */ + // apply mask return this.attr('mask', 'url("#' + this.masker.attr('id') + '")') } // Unmask element @@ -2734,7 +2734,7 @@ SVG.ClipPath = SVG.invent({ create: function() { this.constructor.call(this, SVG.create('clipPath')) - /* keep references to clipped elements */ + // keep references to clipped elements this.targets = [] } @@ -2745,13 +2745,13 @@ SVG.ClipPath = SVG.invent({ , extend: { // Unclip all clipped elements and remove itself remove: function() { - /* unclip all targets */ + // unclip all targets for (var i = this.targets.length - 1; i >= 0; i--) if (this.targets[i]) this.targets[i].unclip() delete this.targets - /* remove clipPath from parent */ + // remove clipPath from parent this.parent().removeElement(this) return this @@ -2771,13 +2771,13 @@ SVG.ClipPath = SVG.invent({ SVG.extend(SVG.Element, { // Distribute clipPath to svg element clipWith: function(element) { - /* use given clip or create a new one */ + // use given clip or create a new one this.clipper = element instanceof SVG.ClipPath ? element : this.parent().clip().add(element) - /* store reverence on self in mask */ + // store reverence on self in mask this.clipper.targets.push(this) - /* apply mask */ + // apply mask return this.attr('clip-path', 'url("#' + this.clipper.attr('id') + '")') } // Unclip element @@ -2792,7 +2792,7 @@ SVG.Gradient = SVG.invent({ create: function(type) { this.constructor.call(this, SVG.create(type + 'Gradient')) - /* store type */ + // store type this.type = type } @@ -2807,10 +2807,10 @@ SVG.Gradient = SVG.invent({ } // Update gradient , update: function(block) { - /* remove all stops */ + // remove all stops this.clear() - /* invoke passed block */ + // invoke passed block if (typeof block == 'function') block.call(this, this) @@ -2884,7 +2884,7 @@ SVG.Stop = SVG.invent({ } } - /* set attributes */ + // set attributes if (o.opacity != null) this.attr('stop-opacity', o.opacity) if (o.color != null) this.attr('stop-color', o.color) if (o.offset != null) this.attr('offset', new SVG.Number(o.offset)) @@ -2905,24 +2905,24 @@ SVG.Pattern = SVG.invent({ // Add class methods , extend: { // Return the fill id - fill: function() { - return 'url(#' + this.id() + ')' - } - // Update pattern by rebuilding - , update: function(block) { + fill: function() { + return 'url(#' + this.id() + ')' + } + // Update pattern by rebuilding + , update: function(block) { // remove content this.clear() // invoke passed block if (typeof block == 'function') - block.call(this, this) + block.call(this, this) return this - } - // Alias string convertion to fill - , toString: function() { - return this.fill() - } + } + // Alias string convertion to fill + , toString: function() { + return this.fill() + } // custom attr to handle transform , attr: function(a, b, c) { if(a == 'transform') a = 'patternTransform' @@ -2934,9 +2934,9 @@ SVG.Pattern = SVG.invent({ // Add parent method , construct: { // Create pattern element in defs - pattern: function(width, height, block) { - return this.defs().pattern(width, height, block) - } + pattern: function(width, height, block) { + return this.defs().pattern(width, height, block) + } } }) @@ -3037,8 +3037,8 @@ SVG.Doc = SVG.invent({ SVG.Shape = SVG.invent({ // Initialize node create: function(element) { - this.constructor.call(this, element) - } + this.constructor.call(this, element) + } // Inherit from , inherit: SVG.Element @@ -3100,7 +3100,7 @@ SVG.Use = SVG.invent({ , extend: { // Use element as a reference element: function(element, file) { - /* Set lined element */ + // Set lined element return this.attr('href', (file || '') + '#' + element, SVG.xlink) } } @@ -3848,10 +3848,10 @@ SVG.Marker = SVG.invent({ } // Update marker , update: function(block) { - /* remove all content */ + // remove all content this.clear() - /* invoke passed block */ + // invoke passed block if (typeof block == 'function') block.call(this, this) @@ -3914,7 +3914,7 @@ var sugar = { } } -/* Add sugar for fill and stroke */ +// Add sugar for fill and stroke ;['fill', 'stroke'].forEach(function(m) { var i, extension = {} @@ -3923,7 +3923,7 @@ var sugar = { this.attr(m, o) else - /* set all attributes from sugar.fill and sugar.stroke list */ + // set all attributes from sugar.fill and sugar.stroke list for (i = sugar[m].length - 1; i >= 0; i--) if (o[sugar[m][i]] != null) this.attr(sugar.prefix(m, sugar[m][i]), o[sugar[m][i]]) @@ -4172,13 +4172,13 @@ SVG.Set.inherit = function() { -// + SVG.extend(SVG.Element, { - // Store data values on svg nodes + // Store data values on svg nodes data: function(a, v, r) { - if (typeof a == 'object') { - for (v in a) - this.data(v, a[v]) + if (typeof a == 'object') { + for (v in a) + this.data(v, a[v]) } else if (arguments.length < 2) { try { @@ -4204,16 +4204,16 @@ SVG.extend(SVG.Element, { SVG.extend(SVG.Element, { // Remember arbitrary data remember: function(k, v) { - /* remember every item in an object individually */ + // remember every item in an object individually if (typeof arguments[0] == 'object') for (var v in k) this.remember(v, k[v]) - /* retrieve memory */ + // retrieve memory else if (arguments.length == 1) return this.memory()[k] - /* store memory */ + // store memory else this.memory()[k] = v |