mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Prebuilt module for commit 0e658da104
This commit is contained in:
parent
8bdbfcdb5f
commit
9de778c97b
5 changed files with 276 additions and 234 deletions
164
dist/docs/assets/js/paper.js
vendored
164
dist/docs/assets/js/paper.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Wed Mar 16 09:56:10 2016 +0100
|
* Date: Wed Mar 16 20:47:57 2016 +0100
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -11100,7 +11100,7 @@ var GradientStop = Base.extend({
|
||||||
});
|
});
|
||||||
|
|
||||||
var Style = Base.extend(new function() {
|
var Style = Base.extend(new function() {
|
||||||
var defaults = {
|
var itemDefaults = {
|
||||||
fillColor: null,
|
fillColor: null,
|
||||||
fillRule: 'nonzero',
|
fillRule: 'nonzero',
|
||||||
strokeColor: null,
|
strokeColor: null,
|
||||||
|
@ -11116,14 +11116,16 @@ var Style = Base.extend(new function() {
|
||||||
shadowOffset: new Point(),
|
shadowOffset: new Point(),
|
||||||
selectedColor: null
|
selectedColor: null
|
||||||
},
|
},
|
||||||
textDefaults = Base.set({}, defaults, {
|
groupDefaults = Base.set({}, itemDefaults, {
|
||||||
fillColor: new Color(),
|
|
||||||
fontFamily: 'sans-serif',
|
fontFamily: 'sans-serif',
|
||||||
fontWeight: 'normal',
|
fontWeight: 'normal',
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
leading: null,
|
leading: null,
|
||||||
justification: 'left'
|
justification: 'left'
|
||||||
}),
|
}),
|
||||||
|
textDefaults = Base.set({}, groupDefaults, {
|
||||||
|
fillColor: new Color()
|
||||||
|
}),
|
||||||
flags = {
|
flags = {
|
||||||
strokeWidth: 97,
|
strokeWidth: 97,
|
||||||
strokeCap: 97,
|
strokeCap: 97,
|
||||||
|
@ -11142,22 +11144,21 @@ var Style = Base.extend(new function() {
|
||||||
},
|
},
|
||||||
fields = {
|
fields = {
|
||||||
_class: 'Style',
|
_class: 'Style',
|
||||||
|
beans: true,
|
||||||
|
|
||||||
initialize: function Style(style, owner, project) {
|
initialize: function Style(style, owner, project) {
|
||||||
this._values = {};
|
this._values = {};
|
||||||
this._owner = owner;
|
this._owner = owner;
|
||||||
this._project = owner && owner._project || project || paper.project;
|
this._project = owner && owner._project || project || paper.project;
|
||||||
if (owner instanceof TextItem)
|
this._defaults = !owner || owner instanceof Group ? groupDefaults
|
||||||
this._defaults = textDefaults;
|
: owner instanceof TextItem ? textDefaults
|
||||||
|
: itemDefaults;
|
||||||
if (style)
|
if (style)
|
||||||
this.set(style);
|
this.set(style);
|
||||||
},
|
}
|
||||||
|
|
||||||
_defaults: defaults,
|
|
||||||
beans: true
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Base.each(textDefaults, function(value, key) {
|
Base.each(groupDefaults, function(value, key) {
|
||||||
var isColor = /Color$/.test(key),
|
var isColor = /Color$/.test(key),
|
||||||
isPoint = key === 'shadowOffset',
|
isPoint = key === 'shadowOffset',
|
||||||
part = Base.capitalize(key),
|
part = Base.capitalize(key),
|
||||||
|
@ -13548,7 +13549,7 @@ new function() {
|
||||||
var childNode = nodes[i],
|
var childNode = nodes[i],
|
||||||
child;
|
child;
|
||||||
if (childNode.nodeType === 1
|
if (childNode.nodeType === 1
|
||||||
&& childNode.nodeName.toLowerCase() !== 'defs'
|
&& !/^defs$/i.test(childNode.nodeName)
|
||||||
&& (child = importNode(childNode, options, false))
|
&& (child = importNode(childNode, options, false))
|
||||||
&& !(child instanceof SymbolDefinition))
|
&& !(child instanceof SymbolDefinition))
|
||||||
children.push(child);
|
children.push(child);
|
||||||
|
@ -13703,63 +13704,68 @@ new function() {
|
||||||
};
|
};
|
||||||
|
|
||||||
function applyTransform(item, value, name, node) {
|
function applyTransform(item, value, name, node) {
|
||||||
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
if (item.transform) {
|
||||||
matrix = new Matrix();
|
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
||||||
for (var i = 0, l = transforms.length; i < l; i++) {
|
matrix = new Matrix();
|
||||||
var transform = transforms[i];
|
for (var i = 0, l = transforms.length; i < l; i++) {
|
||||||
if (!transform)
|
var transform = transforms[i];
|
||||||
break;
|
if (!transform)
|
||||||
var parts = transform.split(/\(\s*/),
|
break;
|
||||||
command = parts[0],
|
var parts = transform.split(/\(\s*/),
|
||||||
v = parts[1].split(/[\s,]+/g);
|
command = parts[0],
|
||||||
for (var j = 0, m = v.length; j < m; j++)
|
v = parts[1].split(/[\s,]+/g);
|
||||||
v[j] = parseFloat(v[j]);
|
for (var j = 0, m = v.length; j < m; j++)
|
||||||
switch (command) {
|
v[j] = parseFloat(v[j]);
|
||||||
case 'matrix':
|
switch (command) {
|
||||||
matrix.append(new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
case 'matrix':
|
||||||
break;
|
matrix.append(
|
||||||
case 'rotate':
|
new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
||||||
matrix.rotate(v[0], v[1], v[2]);
|
break;
|
||||||
break;
|
case 'rotate':
|
||||||
case 'translate':
|
matrix.rotate(v[0], v[1], v[2]);
|
||||||
matrix.translate(v[0], v[1]);
|
break;
|
||||||
break;
|
case 'translate':
|
||||||
case 'scale':
|
matrix.translate(v[0], v[1]);
|
||||||
matrix.scale(v);
|
break;
|
||||||
break;
|
case 'scale':
|
||||||
case 'skewX':
|
matrix.scale(v);
|
||||||
matrix.skew(v[0], 0);
|
break;
|
||||||
break;
|
case 'skewX':
|
||||||
case 'skewY':
|
matrix.skew(v[0], 0);
|
||||||
matrix.skew(0, v[0]);
|
break;
|
||||||
break;
|
case 'skewY':
|
||||||
|
matrix.skew(0, v[0]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
item.transform(matrix);
|
||||||
}
|
}
|
||||||
item.transform(matrix);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyOpacity(item, value, name) {
|
function applyOpacity(item, value, name) {
|
||||||
var color = item[name === 'fill-opacity' ? 'getFillColor'
|
var key = name === 'fill-opacity' ? 'getFillColor' : 'getStrokeColor',
|
||||||
: 'getStrokeColor']();
|
color = item[key] && item[key]();
|
||||||
if (color)
|
if (color)
|
||||||
color.setAlpha(parseFloat(value));
|
color.setAlpha(parseFloat(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
||||||
this[entry.attribute] = function(item, value) {
|
this[entry.attribute] = function(item, value) {
|
||||||
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
if (item[entry.set]) {
|
||||||
if (entry.type === 'color') {
|
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
||||||
var color = item[entry.get]();
|
if (entry.type === 'color') {
|
||||||
if (color) {
|
var color = item[entry.get]();
|
||||||
if (color._scaleToBounds) {
|
if (color) {
|
||||||
var bounds = item.getBounds();
|
if (color._scaleToBounds) {
|
||||||
color.transform(new Matrix()
|
var bounds = item.getBounds();
|
||||||
.translate(bounds.getPoint())
|
color.transform(new Matrix()
|
||||||
.scale(bounds.getSize()));
|
.translate(bounds.getPoint())
|
||||||
}
|
.scale(bounds.getSize()));
|
||||||
if (item instanceof Shape) {
|
}
|
||||||
color.transform(new Matrix()
|
if (item instanceof Shape) {
|
||||||
.translate(item.getPosition(true).negate()));
|
color.transform(new Matrix().translate(
|
||||||
|
item.getPosition(true).negate()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13791,11 +13797,13 @@ new function() {
|
||||||
'stroke-opacity': applyOpacity,
|
'stroke-opacity': applyOpacity,
|
||||||
|
|
||||||
visibility: function(item, value) {
|
visibility: function(item, value) {
|
||||||
item.setVisible(value === 'visible');
|
if (item.setVisible)
|
||||||
|
item.setVisible(value === 'visible');
|
||||||
},
|
},
|
||||||
|
|
||||||
display: function(item, value) {
|
display: function(item, value) {
|
||||||
item.setVisible(value !== null);
|
if (item.setVisible)
|
||||||
|
item.setVisible(value !== null);
|
||||||
},
|
},
|
||||||
|
|
||||||
'stop-color': function(item, value) {
|
'stop-color': function(item, value) {
|
||||||
|
@ -13809,9 +13817,11 @@ new function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
offset: function(item, value) {
|
offset: function(item, value) {
|
||||||
var percentage = value.match(/(.*)%$/);
|
if (item.setRampPoint) {
|
||||||
item.setRampPoint(percentage ? percentage[1] / 100
|
var percentage = value.match(/(.*)%$/);
|
||||||
: parseFloat(value));
|
item.setRampPoint(percentage ? percentage[1] / 100
|
||||||
|
: parseFloat(value));
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
viewBox: function(item, value, name, node, styles) {
|
viewBox: function(item, value, name, node, styles) {
|
||||||
|
@ -13829,13 +13839,15 @@ new function() {
|
||||||
rect.setSize(size);
|
rect.setSize(size);
|
||||||
group = item._item;
|
group = item._item;
|
||||||
}
|
}
|
||||||
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
if (group) {
|
||||||
var clip = new Shape.Rectangle(rect);
|
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
||||||
clip.setClipMask(true);
|
var clip = new Shape.Rectangle(rect);
|
||||||
group.addChild(clip);
|
clip.setClipMask(true);
|
||||||
|
group.addChild(clip);
|
||||||
|
}
|
||||||
|
if (matrix)
|
||||||
|
group.transform(matrix);
|
||||||
}
|
}
|
||||||
if (matrix)
|
|
||||||
group.transform(matrix);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -13854,14 +13866,16 @@ new function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyAttributes(item, node, isRoot) {
|
function applyAttributes(item, node, isRoot) {
|
||||||
var styles = {
|
var parent = node.parentNode,
|
||||||
node: DomElement.getStyles(node) || {},
|
styles = {
|
||||||
parent: !isRoot && DomElement.getStyles(node.parentNode) || {}
|
node: DomElement.getStyles(node) || {},
|
||||||
};
|
parent: !isRoot && !/^defs$/i.test(parent.tagName)
|
||||||
|
&& DomElement.getStyles(parent) || {}
|
||||||
|
};
|
||||||
Base.each(attributes, function(apply, name) {
|
Base.each(attributes, function(apply, name) {
|
||||||
var value = getAttribute(node, name, styles);
|
var value = getAttribute(node, name, styles);
|
||||||
if (value !== undefined)
|
item = value !== undefined && apply(item, value, name, node, styles)
|
||||||
item = Base.pick(apply(item, value, name, node, styles), item);
|
|| item;
|
||||||
});
|
});
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
164
dist/paper-core.js
vendored
164
dist/paper-core.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Wed Mar 16 09:56:10 2016 +0100
|
* Date: Wed Mar 16 20:47:57 2016 +0100
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -11100,7 +11100,7 @@ var GradientStop = Base.extend({
|
||||||
});
|
});
|
||||||
|
|
||||||
var Style = Base.extend(new function() {
|
var Style = Base.extend(new function() {
|
||||||
var defaults = {
|
var itemDefaults = {
|
||||||
fillColor: null,
|
fillColor: null,
|
||||||
fillRule: 'nonzero',
|
fillRule: 'nonzero',
|
||||||
strokeColor: null,
|
strokeColor: null,
|
||||||
|
@ -11116,14 +11116,16 @@ var Style = Base.extend(new function() {
|
||||||
shadowOffset: new Point(),
|
shadowOffset: new Point(),
|
||||||
selectedColor: null
|
selectedColor: null
|
||||||
},
|
},
|
||||||
textDefaults = Base.set({}, defaults, {
|
groupDefaults = Base.set({}, itemDefaults, {
|
||||||
fillColor: new Color(),
|
|
||||||
fontFamily: 'sans-serif',
|
fontFamily: 'sans-serif',
|
||||||
fontWeight: 'normal',
|
fontWeight: 'normal',
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
leading: null,
|
leading: null,
|
||||||
justification: 'left'
|
justification: 'left'
|
||||||
}),
|
}),
|
||||||
|
textDefaults = Base.set({}, groupDefaults, {
|
||||||
|
fillColor: new Color()
|
||||||
|
}),
|
||||||
flags = {
|
flags = {
|
||||||
strokeWidth: 97,
|
strokeWidth: 97,
|
||||||
strokeCap: 97,
|
strokeCap: 97,
|
||||||
|
@ -11142,22 +11144,21 @@ var Style = Base.extend(new function() {
|
||||||
},
|
},
|
||||||
fields = {
|
fields = {
|
||||||
_class: 'Style',
|
_class: 'Style',
|
||||||
|
beans: true,
|
||||||
|
|
||||||
initialize: function Style(style, owner, project) {
|
initialize: function Style(style, owner, project) {
|
||||||
this._values = {};
|
this._values = {};
|
||||||
this._owner = owner;
|
this._owner = owner;
|
||||||
this._project = owner && owner._project || project || paper.project;
|
this._project = owner && owner._project || project || paper.project;
|
||||||
if (owner instanceof TextItem)
|
this._defaults = !owner || owner instanceof Group ? groupDefaults
|
||||||
this._defaults = textDefaults;
|
: owner instanceof TextItem ? textDefaults
|
||||||
|
: itemDefaults;
|
||||||
if (style)
|
if (style)
|
||||||
this.set(style);
|
this.set(style);
|
||||||
},
|
}
|
||||||
|
|
||||||
_defaults: defaults,
|
|
||||||
beans: true
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Base.each(textDefaults, function(value, key) {
|
Base.each(groupDefaults, function(value, key) {
|
||||||
var isColor = /Color$/.test(key),
|
var isColor = /Color$/.test(key),
|
||||||
isPoint = key === 'shadowOffset',
|
isPoint = key === 'shadowOffset',
|
||||||
part = Base.capitalize(key),
|
part = Base.capitalize(key),
|
||||||
|
@ -13548,7 +13549,7 @@ new function() {
|
||||||
var childNode = nodes[i],
|
var childNode = nodes[i],
|
||||||
child;
|
child;
|
||||||
if (childNode.nodeType === 1
|
if (childNode.nodeType === 1
|
||||||
&& childNode.nodeName.toLowerCase() !== 'defs'
|
&& !/^defs$/i.test(childNode.nodeName)
|
||||||
&& (child = importNode(childNode, options, false))
|
&& (child = importNode(childNode, options, false))
|
||||||
&& !(child instanceof SymbolDefinition))
|
&& !(child instanceof SymbolDefinition))
|
||||||
children.push(child);
|
children.push(child);
|
||||||
|
@ -13703,63 +13704,68 @@ new function() {
|
||||||
};
|
};
|
||||||
|
|
||||||
function applyTransform(item, value, name, node) {
|
function applyTransform(item, value, name, node) {
|
||||||
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
if (item.transform) {
|
||||||
matrix = new Matrix();
|
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
||||||
for (var i = 0, l = transforms.length; i < l; i++) {
|
matrix = new Matrix();
|
||||||
var transform = transforms[i];
|
for (var i = 0, l = transforms.length; i < l; i++) {
|
||||||
if (!transform)
|
var transform = transforms[i];
|
||||||
break;
|
if (!transform)
|
||||||
var parts = transform.split(/\(\s*/),
|
break;
|
||||||
command = parts[0],
|
var parts = transform.split(/\(\s*/),
|
||||||
v = parts[1].split(/[\s,]+/g);
|
command = parts[0],
|
||||||
for (var j = 0, m = v.length; j < m; j++)
|
v = parts[1].split(/[\s,]+/g);
|
||||||
v[j] = parseFloat(v[j]);
|
for (var j = 0, m = v.length; j < m; j++)
|
||||||
switch (command) {
|
v[j] = parseFloat(v[j]);
|
||||||
case 'matrix':
|
switch (command) {
|
||||||
matrix.append(new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
case 'matrix':
|
||||||
break;
|
matrix.append(
|
||||||
case 'rotate':
|
new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
||||||
matrix.rotate(v[0], v[1], v[2]);
|
break;
|
||||||
break;
|
case 'rotate':
|
||||||
case 'translate':
|
matrix.rotate(v[0], v[1], v[2]);
|
||||||
matrix.translate(v[0], v[1]);
|
break;
|
||||||
break;
|
case 'translate':
|
||||||
case 'scale':
|
matrix.translate(v[0], v[1]);
|
||||||
matrix.scale(v);
|
break;
|
||||||
break;
|
case 'scale':
|
||||||
case 'skewX':
|
matrix.scale(v);
|
||||||
matrix.skew(v[0], 0);
|
break;
|
||||||
break;
|
case 'skewX':
|
||||||
case 'skewY':
|
matrix.skew(v[0], 0);
|
||||||
matrix.skew(0, v[0]);
|
break;
|
||||||
break;
|
case 'skewY':
|
||||||
|
matrix.skew(0, v[0]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
item.transform(matrix);
|
||||||
}
|
}
|
||||||
item.transform(matrix);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyOpacity(item, value, name) {
|
function applyOpacity(item, value, name) {
|
||||||
var color = item[name === 'fill-opacity' ? 'getFillColor'
|
var key = name === 'fill-opacity' ? 'getFillColor' : 'getStrokeColor',
|
||||||
: 'getStrokeColor']();
|
color = item[key] && item[key]();
|
||||||
if (color)
|
if (color)
|
||||||
color.setAlpha(parseFloat(value));
|
color.setAlpha(parseFloat(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
||||||
this[entry.attribute] = function(item, value) {
|
this[entry.attribute] = function(item, value) {
|
||||||
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
if (item[entry.set]) {
|
||||||
if (entry.type === 'color') {
|
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
||||||
var color = item[entry.get]();
|
if (entry.type === 'color') {
|
||||||
if (color) {
|
var color = item[entry.get]();
|
||||||
if (color._scaleToBounds) {
|
if (color) {
|
||||||
var bounds = item.getBounds();
|
if (color._scaleToBounds) {
|
||||||
color.transform(new Matrix()
|
var bounds = item.getBounds();
|
||||||
.translate(bounds.getPoint())
|
color.transform(new Matrix()
|
||||||
.scale(bounds.getSize()));
|
.translate(bounds.getPoint())
|
||||||
}
|
.scale(bounds.getSize()));
|
||||||
if (item instanceof Shape) {
|
}
|
||||||
color.transform(new Matrix()
|
if (item instanceof Shape) {
|
||||||
.translate(item.getPosition(true).negate()));
|
color.transform(new Matrix().translate(
|
||||||
|
item.getPosition(true).negate()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13791,11 +13797,13 @@ new function() {
|
||||||
'stroke-opacity': applyOpacity,
|
'stroke-opacity': applyOpacity,
|
||||||
|
|
||||||
visibility: function(item, value) {
|
visibility: function(item, value) {
|
||||||
item.setVisible(value === 'visible');
|
if (item.setVisible)
|
||||||
|
item.setVisible(value === 'visible');
|
||||||
},
|
},
|
||||||
|
|
||||||
display: function(item, value) {
|
display: function(item, value) {
|
||||||
item.setVisible(value !== null);
|
if (item.setVisible)
|
||||||
|
item.setVisible(value !== null);
|
||||||
},
|
},
|
||||||
|
|
||||||
'stop-color': function(item, value) {
|
'stop-color': function(item, value) {
|
||||||
|
@ -13809,9 +13817,11 @@ new function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
offset: function(item, value) {
|
offset: function(item, value) {
|
||||||
var percentage = value.match(/(.*)%$/);
|
if (item.setRampPoint) {
|
||||||
item.setRampPoint(percentage ? percentage[1] / 100
|
var percentage = value.match(/(.*)%$/);
|
||||||
: parseFloat(value));
|
item.setRampPoint(percentage ? percentage[1] / 100
|
||||||
|
: parseFloat(value));
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
viewBox: function(item, value, name, node, styles) {
|
viewBox: function(item, value, name, node, styles) {
|
||||||
|
@ -13829,13 +13839,15 @@ new function() {
|
||||||
rect.setSize(size);
|
rect.setSize(size);
|
||||||
group = item._item;
|
group = item._item;
|
||||||
}
|
}
|
||||||
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
if (group) {
|
||||||
var clip = new Shape.Rectangle(rect);
|
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
||||||
clip.setClipMask(true);
|
var clip = new Shape.Rectangle(rect);
|
||||||
group.addChild(clip);
|
clip.setClipMask(true);
|
||||||
|
group.addChild(clip);
|
||||||
|
}
|
||||||
|
if (matrix)
|
||||||
|
group.transform(matrix);
|
||||||
}
|
}
|
||||||
if (matrix)
|
|
||||||
group.transform(matrix);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -13854,14 +13866,16 @@ new function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyAttributes(item, node, isRoot) {
|
function applyAttributes(item, node, isRoot) {
|
||||||
var styles = {
|
var parent = node.parentNode,
|
||||||
node: DomElement.getStyles(node) || {},
|
styles = {
|
||||||
parent: !isRoot && DomElement.getStyles(node.parentNode) || {}
|
node: DomElement.getStyles(node) || {},
|
||||||
};
|
parent: !isRoot && !/^defs$/i.test(parent.tagName)
|
||||||
|
&& DomElement.getStyles(parent) || {}
|
||||||
|
};
|
||||||
Base.each(attributes, function(apply, name) {
|
Base.each(attributes, function(apply, name) {
|
||||||
var value = getAttribute(node, name, styles);
|
var value = getAttribute(node, name, styles);
|
||||||
if (value !== undefined)
|
item = value !== undefined && apply(item, value, name, node, styles)
|
||||||
item = Base.pick(apply(item, value, name, node, styles), item);
|
|| item;
|
||||||
});
|
});
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
8
dist/paper-core.min.js
vendored
8
dist/paper-core.min.js
vendored
File diff suppressed because one or more lines are too long
164
dist/paper-full.js
vendored
164
dist/paper-full.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Wed Mar 16 09:56:10 2016 +0100
|
* Date: Wed Mar 16 20:47:57 2016 +0100
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -11100,7 +11100,7 @@ var GradientStop = Base.extend({
|
||||||
});
|
});
|
||||||
|
|
||||||
var Style = Base.extend(new function() {
|
var Style = Base.extend(new function() {
|
||||||
var defaults = {
|
var itemDefaults = {
|
||||||
fillColor: null,
|
fillColor: null,
|
||||||
fillRule: 'nonzero',
|
fillRule: 'nonzero',
|
||||||
strokeColor: null,
|
strokeColor: null,
|
||||||
|
@ -11116,14 +11116,16 @@ var Style = Base.extend(new function() {
|
||||||
shadowOffset: new Point(),
|
shadowOffset: new Point(),
|
||||||
selectedColor: null
|
selectedColor: null
|
||||||
},
|
},
|
||||||
textDefaults = Base.set({}, defaults, {
|
groupDefaults = Base.set({}, itemDefaults, {
|
||||||
fillColor: new Color(),
|
|
||||||
fontFamily: 'sans-serif',
|
fontFamily: 'sans-serif',
|
||||||
fontWeight: 'normal',
|
fontWeight: 'normal',
|
||||||
fontSize: 12,
|
fontSize: 12,
|
||||||
leading: null,
|
leading: null,
|
||||||
justification: 'left'
|
justification: 'left'
|
||||||
}),
|
}),
|
||||||
|
textDefaults = Base.set({}, groupDefaults, {
|
||||||
|
fillColor: new Color()
|
||||||
|
}),
|
||||||
flags = {
|
flags = {
|
||||||
strokeWidth: 97,
|
strokeWidth: 97,
|
||||||
strokeCap: 97,
|
strokeCap: 97,
|
||||||
|
@ -11142,22 +11144,21 @@ var Style = Base.extend(new function() {
|
||||||
},
|
},
|
||||||
fields = {
|
fields = {
|
||||||
_class: 'Style',
|
_class: 'Style',
|
||||||
|
beans: true,
|
||||||
|
|
||||||
initialize: function Style(style, owner, project) {
|
initialize: function Style(style, owner, project) {
|
||||||
this._values = {};
|
this._values = {};
|
||||||
this._owner = owner;
|
this._owner = owner;
|
||||||
this._project = owner && owner._project || project || paper.project;
|
this._project = owner && owner._project || project || paper.project;
|
||||||
if (owner instanceof TextItem)
|
this._defaults = !owner || owner instanceof Group ? groupDefaults
|
||||||
this._defaults = textDefaults;
|
: owner instanceof TextItem ? textDefaults
|
||||||
|
: itemDefaults;
|
||||||
if (style)
|
if (style)
|
||||||
this.set(style);
|
this.set(style);
|
||||||
},
|
}
|
||||||
|
|
||||||
_defaults: defaults,
|
|
||||||
beans: true
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Base.each(textDefaults, function(value, key) {
|
Base.each(groupDefaults, function(value, key) {
|
||||||
var isColor = /Color$/.test(key),
|
var isColor = /Color$/.test(key),
|
||||||
isPoint = key === 'shadowOffset',
|
isPoint = key === 'shadowOffset',
|
||||||
part = Base.capitalize(key),
|
part = Base.capitalize(key),
|
||||||
|
@ -13548,7 +13549,7 @@ new function() {
|
||||||
var childNode = nodes[i],
|
var childNode = nodes[i],
|
||||||
child;
|
child;
|
||||||
if (childNode.nodeType === 1
|
if (childNode.nodeType === 1
|
||||||
&& childNode.nodeName.toLowerCase() !== 'defs'
|
&& !/^defs$/i.test(childNode.nodeName)
|
||||||
&& (child = importNode(childNode, options, false))
|
&& (child = importNode(childNode, options, false))
|
||||||
&& !(child instanceof SymbolDefinition))
|
&& !(child instanceof SymbolDefinition))
|
||||||
children.push(child);
|
children.push(child);
|
||||||
|
@ -13703,63 +13704,68 @@ new function() {
|
||||||
};
|
};
|
||||||
|
|
||||||
function applyTransform(item, value, name, node) {
|
function applyTransform(item, value, name, node) {
|
||||||
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
if (item.transform) {
|
||||||
matrix = new Matrix();
|
var transforms = (node.getAttribute(name) || '').split(/\)\s*/g),
|
||||||
for (var i = 0, l = transforms.length; i < l; i++) {
|
matrix = new Matrix();
|
||||||
var transform = transforms[i];
|
for (var i = 0, l = transforms.length; i < l; i++) {
|
||||||
if (!transform)
|
var transform = transforms[i];
|
||||||
break;
|
if (!transform)
|
||||||
var parts = transform.split(/\(\s*/),
|
break;
|
||||||
command = parts[0],
|
var parts = transform.split(/\(\s*/),
|
||||||
v = parts[1].split(/[\s,]+/g);
|
command = parts[0],
|
||||||
for (var j = 0, m = v.length; j < m; j++)
|
v = parts[1].split(/[\s,]+/g);
|
||||||
v[j] = parseFloat(v[j]);
|
for (var j = 0, m = v.length; j < m; j++)
|
||||||
switch (command) {
|
v[j] = parseFloat(v[j]);
|
||||||
case 'matrix':
|
switch (command) {
|
||||||
matrix.append(new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
case 'matrix':
|
||||||
break;
|
matrix.append(
|
||||||
case 'rotate':
|
new Matrix(v[0], v[1], v[2], v[3], v[4], v[5]));
|
||||||
matrix.rotate(v[0], v[1], v[2]);
|
break;
|
||||||
break;
|
case 'rotate':
|
||||||
case 'translate':
|
matrix.rotate(v[0], v[1], v[2]);
|
||||||
matrix.translate(v[0], v[1]);
|
break;
|
||||||
break;
|
case 'translate':
|
||||||
case 'scale':
|
matrix.translate(v[0], v[1]);
|
||||||
matrix.scale(v);
|
break;
|
||||||
break;
|
case 'scale':
|
||||||
case 'skewX':
|
matrix.scale(v);
|
||||||
matrix.skew(v[0], 0);
|
break;
|
||||||
break;
|
case 'skewX':
|
||||||
case 'skewY':
|
matrix.skew(v[0], 0);
|
||||||
matrix.skew(0, v[0]);
|
break;
|
||||||
break;
|
case 'skewY':
|
||||||
|
matrix.skew(0, v[0]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
item.transform(matrix);
|
||||||
}
|
}
|
||||||
item.transform(matrix);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyOpacity(item, value, name) {
|
function applyOpacity(item, value, name) {
|
||||||
var color = item[name === 'fill-opacity' ? 'getFillColor'
|
var key = name === 'fill-opacity' ? 'getFillColor' : 'getStrokeColor',
|
||||||
: 'getStrokeColor']();
|
color = item[key] && item[key]();
|
||||||
if (color)
|
if (color)
|
||||||
color.setAlpha(parseFloat(value));
|
color.setAlpha(parseFloat(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
var attributes = Base.set(Base.each(SvgStyles, function(entry) {
|
||||||
this[entry.attribute] = function(item, value) {
|
this[entry.attribute] = function(item, value) {
|
||||||
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
if (item[entry.set]) {
|
||||||
if (entry.type === 'color') {
|
item[entry.set](convertValue(value, entry.type, entry.fromSVG));
|
||||||
var color = item[entry.get]();
|
if (entry.type === 'color') {
|
||||||
if (color) {
|
var color = item[entry.get]();
|
||||||
if (color._scaleToBounds) {
|
if (color) {
|
||||||
var bounds = item.getBounds();
|
if (color._scaleToBounds) {
|
||||||
color.transform(new Matrix()
|
var bounds = item.getBounds();
|
||||||
.translate(bounds.getPoint())
|
color.transform(new Matrix()
|
||||||
.scale(bounds.getSize()));
|
.translate(bounds.getPoint())
|
||||||
}
|
.scale(bounds.getSize()));
|
||||||
if (item instanceof Shape) {
|
}
|
||||||
color.transform(new Matrix()
|
if (item instanceof Shape) {
|
||||||
.translate(item.getPosition(true).negate()));
|
color.transform(new Matrix().translate(
|
||||||
|
item.getPosition(true).negate()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13791,11 +13797,13 @@ new function() {
|
||||||
'stroke-opacity': applyOpacity,
|
'stroke-opacity': applyOpacity,
|
||||||
|
|
||||||
visibility: function(item, value) {
|
visibility: function(item, value) {
|
||||||
item.setVisible(value === 'visible');
|
if (item.setVisible)
|
||||||
|
item.setVisible(value === 'visible');
|
||||||
},
|
},
|
||||||
|
|
||||||
display: function(item, value) {
|
display: function(item, value) {
|
||||||
item.setVisible(value !== null);
|
if (item.setVisible)
|
||||||
|
item.setVisible(value !== null);
|
||||||
},
|
},
|
||||||
|
|
||||||
'stop-color': function(item, value) {
|
'stop-color': function(item, value) {
|
||||||
|
@ -13809,9 +13817,11 @@ new function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
offset: function(item, value) {
|
offset: function(item, value) {
|
||||||
var percentage = value.match(/(.*)%$/);
|
if (item.setRampPoint) {
|
||||||
item.setRampPoint(percentage ? percentage[1] / 100
|
var percentage = value.match(/(.*)%$/);
|
||||||
: parseFloat(value));
|
item.setRampPoint(percentage ? percentage[1] / 100
|
||||||
|
: parseFloat(value));
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
viewBox: function(item, value, name, node, styles) {
|
viewBox: function(item, value, name, node, styles) {
|
||||||
|
@ -13829,13 +13839,15 @@ new function() {
|
||||||
rect.setSize(size);
|
rect.setSize(size);
|
||||||
group = item._item;
|
group = item._item;
|
||||||
}
|
}
|
||||||
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
if (group) {
|
||||||
var clip = new Shape.Rectangle(rect);
|
if (getAttribute(node, 'overflow', styles) !== 'visible') {
|
||||||
clip.setClipMask(true);
|
var clip = new Shape.Rectangle(rect);
|
||||||
group.addChild(clip);
|
clip.setClipMask(true);
|
||||||
|
group.addChild(clip);
|
||||||
|
}
|
||||||
|
if (matrix)
|
||||||
|
group.transform(matrix);
|
||||||
}
|
}
|
||||||
if (matrix)
|
|
||||||
group.transform(matrix);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -13854,14 +13866,16 @@ new function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyAttributes(item, node, isRoot) {
|
function applyAttributes(item, node, isRoot) {
|
||||||
var styles = {
|
var parent = node.parentNode,
|
||||||
node: DomElement.getStyles(node) || {},
|
styles = {
|
||||||
parent: !isRoot && DomElement.getStyles(node.parentNode) || {}
|
node: DomElement.getStyles(node) || {},
|
||||||
};
|
parent: !isRoot && !/^defs$/i.test(parent.tagName)
|
||||||
|
&& DomElement.getStyles(parent) || {}
|
||||||
|
};
|
||||||
Base.each(attributes, function(apply, name) {
|
Base.each(attributes, function(apply, name) {
|
||||||
var value = getAttribute(node, name, styles);
|
var value = getAttribute(node, name, styles);
|
||||||
if (value !== undefined)
|
item = value !== undefined && apply(item, value, name, node, styles)
|
||||||
item = Base.pick(apply(item, value, name, node, styles), item);
|
|| item;
|
||||||
});
|
});
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
10
dist/paper-full.min.js
vendored
10
dist/paper-full.min.js
vendored
File diff suppressed because one or more lines are too long
Loading…
Reference in a new issue