Bump version to v0.9.8

This commit is contained in:
Jürg Lehni 2013-07-03 14:00:25 -07:00
parent 3ebfc94e87
commit a9cf4a373b
8 changed files with 986 additions and 530 deletions

View file

@ -1,6 +1,6 @@
{ {
"name": "paper", "name": "paper",
"version": "0.9.7", "version": "0.9.8",
"main": "dist/paper.js", "main": "dist/paper.js",
"ignore": [ "ignore": [
"build", "build",

335
dist/paper-core.js vendored
View file

@ -1,5 +1,5 @@
/*! /*!
* Paper.js v0.9.7 - The Swiss Army Knife of Vector Graphics Scripting. * Paper.js v0.9.8 - The Swiss Army Knife of Vector Graphics Scripting.
* http://paperjs.org/ * http://paperjs.org/
* *
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey * Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Thu Jun 27 14:31:03 2013 -0700 * Date: Wed Jul 3 12:14:01 2013 -0700
* *
*** ***
* *
@ -92,7 +92,7 @@ var Base = new function() {
var val = val || (val = describe(src, name)) var val = val || (val = describe(src, name))
&& (val.get ? val : val.value); && (val.get ? val : val.value);
if (typeof val === 'string' && val[0] === '#') if (typeof val === 'string' && val[0] === '#')
val = src[val.substring(1)] || val; val = dest[val.substring(1)] || val;
var isFunc = typeof val === 'function', var isFunc = typeof val === 'function',
res = val, res = val,
prev = preserve || isFunc prev = preserve || isFunc
@ -331,11 +331,11 @@ Base.inject({
return false; return false;
}, },
read: function(list, start, length, readNull, clone) { read: function(list, start, length, options) {
if (this === Base) { if (this === Base) {
var value = this.peek(list, start); var value = this.peek(list, start);
list._index++; list._index++;
list._read = 1; list.__read = 1;
return value; return value;
} }
var proto = this.prototype, var proto = this.prototype,
@ -344,21 +344,26 @@ Base.inject({
if (!length) if (!length)
length = list.length - index; length = list.length - index;
var obj = list[index]; var obj = list[index];
if (obj instanceof this || readNull && obj == null && length <= 1) { if (obj instanceof this
|| options && options.readNull && obj == null && length <= 1) {
if (readIndex) if (readIndex)
list._index = index + 1; list._index = index + 1;
return obj && clone ? obj.clone() : obj; return obj && options && options.clone ? obj.clone() : obj;
} }
obj = Base.create(this); obj = Base.create(this);
if (readIndex) if (readIndex)
obj._read = true; obj.__read = true;
if (options)
obj.__options = options;
obj = obj.initialize.apply(obj, index > 0 || length < list.length obj = obj.initialize.apply(obj, index > 0 || length < list.length
? Array.prototype.slice.call(list, index, index + length) ? Array.prototype.slice.call(list, index, index + length)
: list) || obj; : list) || obj;
if (readIndex) { if (readIndex) {
list._index = index + obj._read; list._index = index + obj.__read;
list._read = obj._read; list.__read = obj.__read;
delete obj._read; delete obj.__read;
if (options)
delete obj.__options;
} }
return obj; return obj;
}, },
@ -367,20 +372,20 @@ Base.inject({
return list[list._index = start || list._index || 0]; return list[list._index = start || list._index || 0];
}, },
readAll: function(list, start, readNull, clone) { readAll: function(list, start, options) {
var res = [], entry; var res = [], entry;
for (var i = start || 0, l = list.length; i < l; i++) { for (var i = start || 0, l = list.length; i < l; i++) {
res.push(Array.isArray(entry = list[i]) res.push(Array.isArray(entry = list[i])
? this.read(entry, 0, 0, readNull, clone) ? this.read(entry, 0, 0, options)
: this.read(list, i, 1, readNull, clone)); : this.read(list, i, 1, options));
} }
return res; return res;
}, },
readNamed: function(list, name, start, length, readNull, clone) { readNamed: function(list, name, start, length, options) {
var value = this.getNamed(list, name); var value = this.getNamed(list, name);
return this.read(value != null ? [value] : list, start, length, return this.read(value != null ? [value] : list, start, length,
readNull, clone); options);
}, },
getNamed: function(list, name) { getNamed: function(list, name) {
@ -670,7 +675,7 @@ var PaperScope = Base.extend({
} }
}, },
version: '0.9.7', version: '0.9.8',
getView: function() { getView: function() {
return this.project && this.project.view; return this.project && this.project.view;
@ -967,12 +972,12 @@ var Point = Base.extend({
var hasY = typeof arg1 === 'number'; var hasY = typeof arg1 === 'number';
this.x = arg0; this.x = arg0;
this.y = hasY ? arg1 : arg0; this.y = hasY ? arg1 : arg0;
if (this._read) if (this.__read)
this._read = hasY ? 2 : 1; this.__read = hasY ? 2 : 1;
} else if (type === 'undefined' || arg0 === null) { } else if (type === 'undefined' || arg0 === null) {
this.x = this.y = 0; this.x = this.y = 0;
if (this._read) if (this.__read)
this._read = arg0 === null ? 1 : 0; this.__read = arg0 === null ? 1 : 0;
} else { } else {
if (Array.isArray(arg0)) { if (Array.isArray(arg0)) {
this.x = arg0[0]; this.x = arg0[0];
@ -989,11 +994,11 @@ var Point = Base.extend({
this.setAngle(arg0.angle); this.setAngle(arg0.angle);
} else { } else {
this.x = this.y = 0; this.x = this.y = 0;
if (this._read) if (this.__read)
this._read = 0; this.__read = 0;
} }
if (this._read) if (this.__read)
this._read = 1; this.__read = 1;
} }
}, },
@ -1229,15 +1234,12 @@ var Point = Base.extend({
return new Point(Math.random(), Math.random()); return new Point(Math.random(), Math.random());
} }
} }
}, new function() { }, Base.each(['round', 'ceil', 'floor', 'abs'], function(name) {
return Base.each(['round', 'ceil', 'floor', 'abs'], function(name) {
var op = Math[name]; var op = Math[name];
this[name] = function() { this[name] = function() {
return new Point(op(this.x), op(this.y)); return new Point(op(this.x), op(this.y));
}; };
}, {}); }, {}));
});
var LinkedPoint = Point.extend({ var LinkedPoint = Point.extend({
initialize: function Point(x, y, owner, setter) { initialize: function Point(x, y, owner, setter) {
@ -1284,12 +1286,12 @@ var Size = Base.extend({
var hasHeight = typeof arg1 === 'number'; var hasHeight = typeof arg1 === 'number';
this.width = arg0; this.width = arg0;
this.height = hasHeight ? arg1 : arg0; this.height = hasHeight ? arg1 : arg0;
if (this._read) if (this.__read)
this._read = hasHeight ? 2 : 1; this.__read = hasHeight ? 2 : 1;
} else if (type === 'undefined' || arg0 === null) { } else if (type === 'undefined' || arg0 === null) {
this.width = this.height = 0; this.width = this.height = 0;
if (this._read) if (this.__read)
this._read = arg0 === null ? 1 : 0; this.__read = arg0 === null ? 1 : 0;
} else { } else {
if (Array.isArray(arg0)) { if (Array.isArray(arg0)) {
this.width = arg0[0]; this.width = arg0[0];
@ -1302,11 +1304,11 @@ var Size = Base.extend({
this.height = arg0.y; this.height = arg0.y;
} else { } else {
this.width = this.height = 0; this.width = this.height = 0;
if (this._read) if (this.__read)
this._read = 0; this.__read = 0;
} }
if (this._read) if (this.__read)
this._read = 1; this.__read = 1;
} }
}, },
@ -1393,15 +1395,12 @@ var Size = Base.extend({
return new Size(Math.random(), Math.random()); return new Size(Math.random(), Math.random());
} }
} }
}, new function() { }, Base.each(['round', 'ceil', 'floor', 'abs'], function(name) {
return Base.each(['round', 'ceil', 'floor', 'abs'], function(name) {
var op = Math[name]; var op = Math[name];
this[name] = function() { this[name] = function() {
return new Size(op(this.width), op(this.height)); return new Size(op(this.width), op(this.height));
}; };
}, {}); }, {}));
});
var LinkedSize = Size.extend({ var LinkedSize = Size.extend({
initialize: function Size(width, height, owner, setter) { initialize: function Size(width, height, owner, setter) {
@ -1497,8 +1496,8 @@ var Rectangle = Base.extend({
} }
read = arguments._index; read = arguments._index;
} }
if (this._read) if (this.__read)
this._read = read; this.__read = read;
}, },
set: function(x, y, width, height) { set: function(x, y, width, height) {
@ -1886,7 +1885,7 @@ var Matrix = Base.extend({
scale: function() { scale: function() {
var scale = Point.read(arguments), var scale = Point.read(arguments),
center = Point.read(arguments, 0, 0, true); center = Point.read(arguments, 0, 0, { readNull: true });
if (center) if (center)
this.translate(center); this.translate(center);
this._a *= scale.x; this._a *= scale.x;
@ -1931,7 +1930,7 @@ var Matrix = Base.extend({
shear: function() { shear: function() {
var point = Point.read(arguments), var point = Point.read(arguments),
center = Point.read(arguments, 0, 0, true); center = Point.read(arguments, 0, 0, { readNull: true });
if (center) if (center)
this.translate(center); this.translate(center);
var a = this._a, var a = this._a,
@ -3071,6 +3070,10 @@ var Item = Base.extend(Callback, {
} }
}, },
importJSON: function(json) {
return this.addChild(Base.importJSON(json));
},
addChild: function(item, _preserve) { addChild: function(item, _preserve) {
return this.insertChild(undefined, item, _preserve); return this.insertChild(undefined, item, _preserve);
}, },
@ -3363,10 +3366,6 @@ var Item = Base.extend(Callback, {
this.setBounds(newBounds); this.setBounds(newBounds);
}, },
importJSON: function(json) {
return this.addChild(Base.importJSON(json));
},
_setStyles: function(ctx) { _setStyles: function(ctx) {
var style = this._style, var style = this._style,
width = style.getStrokeWidth(), width = style.getStrokeWidth(),
@ -3615,6 +3614,29 @@ var Shape = Item.extend({
this._size = size; this._size = size;
}, },
getSize: function() {
var size = this._size;
return new LinkedSize(size.width, size.height, this, 'setSize');
},
setSize: function() {
var size = Size.read(arguments);
if (!this._size.equals(size)) {
this._size.set(size.width, size.height);
this._changed(5);
}
},
getRadius: function() {
var size = this._size;
return (size.width + size.height) / 4;
},
setRadius: function(radius) {
var size = radius * 2;
this.setSize(size, size);
},
_draw: function(ctx, param) { _draw: function(ctx, param) {
var style = this._style, var style = this._style,
size = this._size, size = this._size,
@ -3776,7 +3798,8 @@ var Raster = Item.extend({
}, },
getSize: function() { getSize: function() {
return this._size; var size = this._size;
return new LinkedSize(size.width, size.height, this, 'setSize');
}, },
setSize: function() { setSize: function() {
@ -3996,7 +4019,7 @@ var Raster = Item.extend({
getImageData: function(rect) { getImageData: function(rect) {
rect = Rectangle.read(arguments); rect = Rectangle.read(arguments);
if (rect.isEmpty()) if (rect.isEmpty())
rect = new Rectangle(this.getSize()); rect = new Rectangle(this._size);
return this.getContext().getImageData(rect.x, rect.y, return this.getContext().getImageData(rect.x, rect.y,
rect.width, rect.height); rect.width, rect.height);
}, },
@ -4600,10 +4623,19 @@ var Curve = Base.extend({
return new Curve(this._segment2.reverse(), this._segment1.reverse()); return new Curve(this._segment2.reverse(), this._segment1.reverse());
}, },
divide: function(parameter) { _getParameter: function(offset, isParameter) {
var res = null; return isParameter
if (parameter && parameter.curve === this) ? offset
parameter = parameter.parameter; : offset && offset.curve === this
? offset.parameter
: offset === undefined && isParameter === undefined
? 0.5
: this.getParameterAt(offset, 0);
},
divide: function(offset, isParameter) {
var parameter = this._getParameter(offset, isParameter),
res = null;
if (parameter > 0 && parameter < 1) { if (parameter > 0 && parameter < 1) {
var parts = Curve.subdivide(this.getValues(), parameter), var parts = Curve.subdivide(this.getValues(), parameter),
isLinear = this.isLinear(), isLinear = this.isLinear(),
@ -4638,9 +4670,10 @@ var Curve = Base.extend({
return res; return res;
}, },
split: function(parameter) { split: function(offset, isParameter) {
return this._path return this._path
? this._path.split(this._segment1._index, parameter) ? this._path.split(this._segment1._index,
this._getParameter(offset, isParameter))
: null; : null;
}, },
@ -4672,9 +4705,8 @@ statics: {
]; ];
}, },
evaluate: function(v, offset, isParameter, type) { evaluate: function(v, t, type) {
var t = isParameter ? offset : Curve.getParameterAt(v, offset, 0), var p1x = v[0], p1y = v[1],
p1x = v[0], p1y = v[1],
c1x = v[2], c1y = v[3], c1x = v[2], c1y = v[3],
c2x = v[4], c2y = v[5], c2x = v[4], c2y = v[5],
p2x = v[6], p2y = v[7], p2x = v[6], p2y = v[7],
@ -4829,7 +4861,7 @@ statics: {
abs = Math.abs; abs = Math.abs;
function changesOrientation(tangent) { function changesOrientation(tangent) {
return Curve.evaluate(prev, 1, true, 1).y return Curve.evaluate(prev, 1, 1).y
* tangent.y > 0; * tangent.y > 0;
} }
@ -4840,9 +4872,9 @@ statics: {
for (var i = 0; i < count; i++) { for (var i = 0; i < count; i++) {
var t = roots[i]; var t = roots[i];
if (t > -tolerance && t < 1 - tolerance) { if (t > -tolerance && t < 1 - tolerance) {
var pt = Curve.evaluate(v, t, true, 0); var pt = Curve.evaluate(v, t, 0);
if (x < pt.x + tolerance) { if (x < pt.x + tolerance) {
var tan = Curve.evaluate(v, t, true, 1); var tan = Curve.evaluate(v, t, 1);
if (abs(pt.x - x) < tolerance) { if (abs(pt.x - x) < tolerance) {
var angle = tan.getAngle(); var angle = tan.getAngle();
if (angle > -180 && angle < 0 if (angle > -180 && angle < 0
@ -4902,13 +4934,15 @@ statics: {
}, },
{ {
}), Base.each(['getPoint', 'getTangent', 'getNormal', 'getCurvatureAt'], }), Base.each(['getPoint', 'getTangent', 'getNormal', 'getCurvature'],
function(name, index) { function(name, index) {
this[name + 'At'] = function(offset, isParameter) { this[name + 'At'] = function(offset, isParameter) {
return Curve.evaluate(this.getValues(), offset, isParameter, index); var values = this.getValues();
return Curve.evaluate(values, isParameter
? offset : Curve.getParameterAt(values, offset, 0), index);
}; };
this[name] = function(parameter) { this[name] = function(parameter) {
return Curve.evaluate(this.getValues(), parameter, true, index); return Curve.evaluate(this.getValues(), parameter, index);
}; };
}, },
{ {
@ -4945,7 +4979,7 @@ statics: {
function refine(t) { function refine(t) {
if (t >= 0 && t <= 1) { if (t >= 0 && t <= 1) {
var dist = point.getDistance( var dist = point.getDistance(
Curve.evaluate(values, t, true, 0), true); Curve.evaluate(values, t, 0), true);
if (dist < minDist) { if (dist < minDist) {
minDist = dist; minDist = dist;
minT = t; minT = t;
@ -4962,7 +4996,7 @@ statics: {
if (!refine(minT - step) && !refine(minT + step)) if (!refine(minT - step) && !refine(minT + step))
step /= 2; step /= 2;
} }
var pt = Curve.evaluate(values, minT, true, 0); var pt = Curve.evaluate(values, minT, 0);
return new CurveLocation(this, minT, pt, null, null, null, return new CurveLocation(this, minT, pt, null, null, null,
point.getDistance(pt)); point.getDistance(pt));
}, },
@ -5103,8 +5137,8 @@ new function() {
var t1 = (range1[0] + range1[1]) / 2, var t1 = (range1[0] + range1[1]) / 2,
t2 = (range2[0] + range2[1]) / 2; t2 = (range2[0] + range2[1]) / 2;
addLocation(locations, addLocation(locations,
curve1, t1, Curve.evaluate(v1, t1, true, 0), curve1, t1, Curve.evaluate(v1, t1, 0),
curve2, t2, Curve.evaluate(v2, t2, true, 0)); curve2, t2, Curve.evaluate(v2, t2, 0));
break; break;
} }
} }
@ -5239,11 +5273,11 @@ new function() {
for (var i = 0; i < count; i++) { for (var i = 0; i < count; i++) {
var t = roots[i]; var t = roots[i];
if (t >= 0 && t <= 1) { if (t >= 0 && t <= 1) {
var point = Curve.evaluate(vcr, t, true, 0); var point = Curve.evaluate(vcr, t, 0);
if (point.x >= 0 && point.x <= rl2x) if (point.x >= 0 && point.x <= rl2x)
addLocation(locations, addLocation(locations,
flip ? curve2 : curve1, flip ? curve2 : curve1,
t, Curve.evaluate(vc, t, true, 0), t, Curve.evaluate(vc, t, 0),
flip ? curve1 : curve2); flip ? curve1 : curve2);
} }
} }
@ -5874,7 +5908,7 @@ var Path = PathItem.extend({
split: function(index, parameter) { split: function(index, parameter) {
if (parameter === null) if (parameter === null)
return; return;
if (arguments.length == 1) { if (arguments.length === 1) {
var arg = index; var arg = index;
if (typeof arg === 'number') if (typeof arg === 'number')
arg = this.getLocationAt(arg); arg = this.getLocationAt(arg);
@ -5938,12 +5972,13 @@ var Path = PathItem.extend({
last2 = path.getLastSegment(); last2 = path.getLastSegment();
if (last1._point.equals(last2._point)) if (last1._point.equals(last2._point))
path.reverse(); path.reverse();
var first2 = path.getFirstSegment(); var first1,
first2 = path.getFirstSegment();
if (last1._point.equals(first2._point)) { if (last1._point.equals(first2._point)) {
last1.setHandleOut(first2._handleOut); last1.setHandleOut(first2._handleOut);
this._add(segments.slice(1)); this._add(segments.slice(1));
} else { } else {
var first1 = this.getFirstSegment(); first1 = this.getFirstSegment();
if (first1._point.equals(first2._point)) if (first1._point.equals(first2._point))
path.reverse(); path.reverse();
last2 = path.getLastSegment(); last2 = path.getLastSegment();
@ -5954,8 +5989,10 @@ var Path = PathItem.extend({
this._add(segments.slice()); this._add(segments.slice());
} }
} }
if (path.closed)
this._add([segments[0]]);
path.remove(); path.remove();
var first1 = this.getFirstSegment(); first1 = this.getFirstSegment();
last1 = this.getLastSegment(); last1 = this.getLastSegment();
if (last1._point.equals(first1._point)) { if (last1._point.equals(first1._point)) {
first1.setHandleIn(last1._handleIn); first1.setHandleIn(last1._handleIn);
@ -6846,7 +6883,8 @@ Path.inject({ statics: new function() {
function createRectangle() { function createRectangle() {
var rect = Rectangle.readNamed(arguments, 'rectangle'), var rect = Rectangle.readNamed(arguments, 'rectangle'),
radius = Size.readNamed(arguments, 'radius', 0, 0, true), radius = Size.readNamed(arguments, 'radius', 0, 0,
{ readNull: true }),
bl = rect.getBottomLeft(true), bl = rect.getBottomLeft(true),
tl = rect.getTopLeft(true), tl = rect.getTopLeft(true),
tr = rect.getTopRight(true), tr = rect.getTopRight(true),
@ -6916,14 +6954,6 @@ Path.inject({ statics: new function() {
).set(Base.getNamed(arguments)); ).set(Base.getNamed(arguments));
}, },
Rectangle: createRectangle,
RoundRectangle: createRectangle,
Ellipse: createEllipse,
Oval: createEllipse,
Circle: function() { Circle: function() {
var center = Point.readNamed(arguments, 'center'), var center = Point.readNamed(arguments, 'center'),
radius = Base.readNamed(arguments, 'radius'); radius = Base.readNamed(arguments, 'radius');
@ -6932,6 +6962,14 @@ Path.inject({ statics: new function() {
.set(Base.getNamed(arguments)); .set(Base.getNamed(arguments));
}, },
Rectangle: createRectangle,
RoundRectangle: createRectangle,
Ellipse: createEllipse,
Oval: createEllipse,
Arc: function() { Arc: function() {
var from = Point.readNamed(arguments, 'from'), var from = Point.readNamed(arguments, 'from'),
through = Point.readNamed(arguments, 'through'), through = Point.readNamed(arguments, 'through'),
@ -7230,7 +7268,7 @@ var PathFlattener = Base.extend({
evaluate: function(offset, type) { evaluate: function(offset, type) {
var param = this.getParameterAt(offset); var param = this.getParameterAt(offset);
return Curve.evaluate(this.curves[param.index], param.value, true, type); return Curve.evaluate(this.curves[param.index], param.value, type);
}, },
drawPart: function(ctx, from, to) { drawPart: function(ctx, from, to) {
@ -7723,7 +7761,7 @@ var Color = Base.extend(new function() {
gradient: ['gradient', 'origin', 'destination', 'highlight'] gradient: ['gradient', 'origin', 'destination', 'highlight']
}; };
var parsers = {}, var componentParsers = {},
colorCache = {}, colorCache = {},
colorCtx; colorCtx;
@ -7861,16 +7899,16 @@ var Color = Base.extend(new function() {
}; };
return Base.each(types, function(properties, type) { return Base.each(types, function(properties, type) {
parsers[type] = []; componentParsers[type] = [];
Base.each(properties, function(name, index) { Base.each(properties, function(name, index) {
var part = Base.capitalize(name), var part = Base.capitalize(name),
hasOverlap = /^(hue|saturation)$/.test(name), hasOverlap = /^(hue|saturation)$/.test(name),
parser = parsers[type][index] = name === 'gradient' parser = componentParsers[type][index] = name === 'gradient'
? function(value) { ? function(value) {
var current = this._components[0]; var current = this._components[0];
value = Gradient.read( value = Gradient.read(
Array.isArray(value) ? value : arguments, Array.isArray(value) ? value : arguments,
0, 0, true); 0, 0, { readNull: true });
if (current !== value) { if (current !== value) {
if (current) if (current)
current._removeOwner(this); current._removeOwner(this);
@ -7886,8 +7924,10 @@ var Color = Base.extend(new function() {
} }
: type === 'gradient' : type === 'gradient'
? function() { ? function() {
return Point.read(arguments, 0, 0, return Point.read(arguments, 0, 0, {
name === 'highlight', true); readNull: name === 'highlight',
clone: true
});
} }
: function(value) { : function(value) {
return isNaN(value) ? 0 return isNaN(value) ? 0
@ -7905,6 +7945,7 @@ var Color = Base.extend(new function() {
if (this._type !== type if (this._type !== type
&& !(hasOverlap && /^hs[bl]$/.test(this._type))) { && !(hasOverlap && /^hs[bl]$/.test(this._type))) {
this._components = this._convert(type); this._components = this._convert(type);
this._properties = types[type];
this._type = type; this._type = type;
} }
value = parser.call(this, value); value = parser.call(this, value);
@ -7922,6 +7963,7 @@ var Color = Base.extend(new function() {
var slice = Array.prototype.slice, var slice = Array.prototype.slice,
args = arguments, args = arguments,
read = 0, read = 0,
parse = true,
type, type,
components, components,
alpha, alpha,
@ -7938,13 +7980,14 @@ var Color = Base.extend(new function() {
components = arg; components = arg;
alpha = args[2]; alpha = args[2];
} else { } else {
if (this._read) if (this.__read)
read = 1; read = 1;
args = slice.call(args, 1); args = slice.call(args, 1);
argType = typeof arg; argType = typeof arg;
} }
} }
if (!components) { if (!components) {
parse = !(this.__options && this.__options.dontParse);
values = argType === 'number' values = argType === 'number'
? args ? args
: argType === 'object' && arg.length != null : argType === 'object' && arg.length != null
@ -7957,7 +8000,7 @@ var Color = Base.extend(new function() {
: 'gray'; : 'gray';
var length = types[type].length; var length = types[type].length;
alpha = values[length]; alpha = values[length];
if (this._read) if (this.__read)
read += values === arguments read += values === arguments
? length + (alpha != null ? 1 : 0) ? length + (alpha != null ? 1 : 0)
: 1; : 1;
@ -7995,7 +8038,7 @@ var Color = Base.extend(new function() {
? 'gray' ? 'gray'
: 'rgb'; : 'rgb';
var properties = types[type]; var properties = types[type];
parse = parsers[type]; parsers = parse && componentParsers[type];
this._components = components = []; this._components = components = [];
for (var i = 0, l = properties.length; i < l; i++) { for (var i = 0, l = properties.length; i < l; i++) {
var value = arg[properties[i]]; var value = arg[properties[i]];
@ -8006,14 +8049,15 @@ var Color = Base.extend(new function() {
radial: arg.radial radial: arg.radial
}; };
} }
value = parse[i].call(this, value); if (parse)
value = parsers[i].call(this, value);
if (value != null) if (value != null)
components[i] = value; components[i] = value;
} }
alpha = arg.alpha; alpha = arg.alpha;
} }
} }
if (this._read && type) if (this.__read && type)
read = 1; read = 1;
} }
this._type = type || 'rgb'; this._type = type || 'rgb';
@ -8021,17 +8065,20 @@ var Color = Base.extend(new function() {
this._id = Color._id = (Color._id || 0) + 1; this._id = Color._id = (Color._id || 0) + 1;
if (!components) { if (!components) {
this._components = components = []; this._components = components = [];
var parse = parsers[this._type]; var parsers = componentParsers[this._type];
for (var i = 0, l = parse.length; i < l; i++) { for (var i = 0, l = parsers.length; i < l; i++) {
var value = parse[i].call(this, values && values[i]); var value = values && values[i];
if (parse)
value = parsers[i].call(this, value);
if (value != null) if (value != null)
components[i] = value; components[i] = value;
} }
} }
this._components = components; this._components = components;
this._properties = types[this._type];
this._alpha = alpha; this._alpha = alpha;
if (this._read) if (this.__read)
this._read = read; this.__read = read;
}, },
_serialize: function(options, dictionary) { _serialize: function(options, dictionary) {
@ -8074,6 +8121,7 @@ var Color = Base.extend(new function() {
setType: function(type) { setType: function(type) {
this._components = this._convert(type); this._components = this._convert(type);
this._properties = types[type];
this._type = type; this._type = type;
}, },
@ -8107,7 +8155,7 @@ var Color = Base.extend(new function() {
}, },
toString: function() { toString: function() {
var properties = types[this._type], var properties = this._properties,
parts = [], parts = [],
isGradient = this._type === 'gradient', isGradient = this._type === 'gradient',
f = Formatter.instance; f = Formatter.instance;
@ -8190,6 +8238,54 @@ var Color = Base.extend(new function() {
} }
} }
}); });
}, new function() {
function clamp(value, hue) {
return value < 0
? 0
: hue && value > 360
? 360
: !hue && value > 1
? 1
: value;
}
var operators = {
add: function(a, b, hue) {
return clamp(a + b, hue);
},
subtract: function(a, b, hue) {
return clamp(a - b, hue);
},
multiply: function(a, b, hue) {
return clamp(a * b, hue);
},
divide: function(a, b, hue) {
return clamp(a / b, hue);
}
};
return Base.each(operators, function(operator, name) {
var options = { dontParse: /^(multiply|divide)$/.test(name) };
this[name] = function(color) {
color = Color.read(arguments, 0, 0, options);
var type = this._type,
properties = this._properties,
components1 = this._components,
components2 = color._convert(type);
for (var i = 0, l = components1.length; i < l; i++)
components2[i] = operator(components1[i], components2[i],
properties[i] === 'hue');
return new Color(type, components2,
this._alpha != null
? operator(this._alpha, color.getAlpha())
: null);
};
}, {
});
}); });
Base.each(Color._types, function(properties, type) { Base.each(Color._types, function(properties, type) {
@ -8208,7 +8304,7 @@ Base.each(Color._types, function(properties, type) {
var acronym = type.toUpperCase(); var acronym = type.toUpperCase();
Color[acronym] = this[acronym + 'Color'] = ctor; Color[acronym] = this[acronym + 'Color'] = ctor;
} }
}, this); }, Base.exports);
var Gradient = Base.extend({ var Gradient = Base.extend({
_class: 'Gradient', _class: 'Gradient',
@ -8445,7 +8541,7 @@ var Style = Base.extend(new function() {
this._values[key] = value; this._values[key] = value;
} else if (isColor && !(value && value.constructor === Color)) { } else if (isColor && !(value && value.constructor === Color)) {
this._values[key] = value = Color.read( this._values[key] = value = Color.read(
[value], 0, 0, true, true); [value], 0, 0, { readNull: true, clone: true });
if (value) if (value)
value._owner = this._item; value._owner = this._item;
} }
@ -10219,7 +10315,7 @@ var SVGNamespaces = {
}; };
new function() { new function() {
var formatter = Formatter.instance; var formatter;
function setAttributes(node, attrs) { function setAttributes(node, attrs) {
for (var key in attrs) { for (var key in attrs) {
@ -10619,7 +10715,7 @@ new function() {
definitions.svgs[type + '-' + item._id] = node; definitions.svgs[type + '-' + item._id] = node;
} }
function exportDefinitions(node) { function exportDefinitions(node, options) {
if (!definitions) if (!definitions)
return node; return node;
var svg = node.nodeName.toLowerCase() === 'svg' && node, var svg = node.nodeName.toLowerCase() === 'svg' && node,
@ -10635,7 +10731,9 @@ new function() {
defs.appendChild(definitions.svgs[i]); defs.appendChild(definitions.svgs[i]);
} }
definitions = null; definitions = null;
return svg; return options && options.asString
? new XMLSerializer().serializeToString(svg)
: svg;
} }
function exportSVG(item) { function exportSVG(item) {
@ -10646,14 +10744,22 @@ new function() {
return node && applyStyle(item, node); return node && applyStyle(item, node);
} }
function setOptions(options) {
formatter = options && options.precision
? new Formatter(options.precision)
: Formatter.instance;
}
Item.inject({ Item.inject({
exportSVG: function() { exportSVG: function(options) {
return exportDefinitions(exportSVG(this)); setOptions(options);
return exportDefinitions(exportSVG(this), options);
} }
}); });
Project.inject({ Project.inject({
exportSVG: function() { exportSVG: function(options) {
setOptions(options);
var layers = this.layers, var layers = this.layers,
size = this.view.getSize(), size = this.view.getSize(),
node = createElement('svg', { node = createElement('svg', {
@ -10667,7 +10773,7 @@ new function() {
}); });
for (var i = 0, l = layers.length; i < l; i++) for (var i = 0, l = layers.length; i < l; i++)
node.appendChild(exportSVG(layers[i])); node.appendChild(exportSVG(layers[i]));
return exportDefinitions(node); return exportDefinitions(node, options);
} }
}); });
}; };
@ -11064,4 +11170,3 @@ if (typeof define === 'function' && define.amd)
return paper; return paper;
}; };

File diff suppressed because one or more lines are too long

361
dist/paper-full.js vendored

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

361
dist/paper-node.js vendored

File diff suppressed because one or more lines are too long

361
dist/paper.js vendored

File diff suppressed because one or more lines are too long

View file

@ -1,6 +1,6 @@
{ {
"name": "paper", "name": "paper",
"version": "0.9.7", "version": "0.9.8",
"description": "The Swiss Army Knife of Vector Graphics Scripting", "description": "The Swiss Army Knife of Vector Graphics Scripting",
"homepage": "http://paperjs.org", "homepage": "http://paperjs.org",
"repository": "git://github.com/paperjs/paper.js", "repository": "git://github.com/paperjs/paper.js",