mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Optimize code a bit by changing parameter sequence.
This commit is contained in:
parent
c29a7e38a0
commit
f142a9d015
1 changed files with 42 additions and 37 deletions
|
@ -69,7 +69,7 @@ new function() {
|
||||||
return new Group(clip, item);
|
return new Group(clip, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Importer functions for various SVG node types //
|
// Importer functions for various SVG node types
|
||||||
|
|
||||||
function importGroup(node, type) {
|
function importGroup(node, type) {
|
||||||
var nodes = node.childNodes,
|
var nodes = node.childNodes,
|
||||||
|
@ -348,9 +348,13 @@ new function() {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Attributes & Styles //
|
// Attributes and Styles
|
||||||
|
|
||||||
function applyTransform(item, node, name, value) {
|
// NOTE: Parmeter sequence for all apply*() functions is:
|
||||||
|
// (item, value, name, node) rather than (item, node, name, value),
|
||||||
|
// so we can ommit the less likely parameters from right to left.
|
||||||
|
|
||||||
|
function applyTransform(item, value, name, node) {
|
||||||
// http://www.w3.org/TR/SVG/types.html#DataTypeTransformList
|
// http://www.w3.org/TR/SVG/types.html#DataTypeTransformList
|
||||||
var transforms = node[name].baseVal,
|
var transforms = node[name].baseVal,
|
||||||
matrix = new Matrix();
|
matrix = new Matrix();
|
||||||
|
@ -362,16 +366,16 @@ new function() {
|
||||||
item.transform(matrix);
|
item.transform(matrix);
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyOpacity(item, node, name, value) {
|
function applyOpacity(item, value, name) {
|
||||||
// http://www.w3.org/TR/SVG/painting.html#FillOpacityProperty
|
// http://www.w3.org/TR/SVG/painting.html#FillOpacityProperty
|
||||||
// http://www.w3.org/TR/SVG/painting.html#StrokeOpacityProperty
|
// http://www.w3.org/TR/SVG/painting.html#StrokeOpacityProperty
|
||||||
var color = item[name == 'fill-opacity' ? 'getFillColor'
|
var color = item[name === 'fill-opacity' ? 'getFillColor'
|
||||||
: 'getStrokeColor']();
|
: 'getStrokeColor']();
|
||||||
if (color)
|
if (color)
|
||||||
color.setAlpha(parseFloat(value));
|
color.setAlpha(parseFloat(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
function applyTextAttribute(item, node, name, value) {
|
function applyTextAttribute(item, value, name, node) {
|
||||||
if (item instanceof TextItem) {
|
if (item instanceof TextItem) {
|
||||||
switch (name) {
|
switch (name) {
|
||||||
case 'font':
|
case 'font':
|
||||||
|
@ -380,7 +384,7 @@ new function() {
|
||||||
text.style.font = value;
|
text.style.font = value;
|
||||||
for (var i = 0; i < text.style.length; i++) {
|
for (var i = 0; i < text.style.length; i++) {
|
||||||
var name = text.style[i];
|
var name = text.style[i];
|
||||||
item = applyAttribute(item, node, name, text.style[name]);
|
item = applyAttribute(item, text.style[name], name, node);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'font-family':
|
case 'font-family':
|
||||||
|
@ -410,17 +414,17 @@ new function() {
|
||||||
|
|
||||||
// Create apply methos for attributes, and merge in those for SvgStlyes:
|
// Create apply methos for attributes, and merge in those for SvgStlyes:
|
||||||
var attributes = Base.each(SvgStyles, function(entry) {
|
var attributes = Base.each(SvgStyles, function(entry) {
|
||||||
this[entry.attribute] = function(item, node, name, value) {
|
this[entry.attribute] = function(item, value, name, node) {
|
||||||
item._style[entry.set](convertValue(value, entry.type));
|
item._style[entry.set](convertValue(value, entry.type));
|
||||||
};
|
};
|
||||||
}, {
|
}, {
|
||||||
id: function(item, node, name, value) {
|
id: function(item, value) {
|
||||||
definitions[value] = item;
|
definitions[value] = item;
|
||||||
if (item.setName)
|
if (item.setName)
|
||||||
item.setName(value);
|
item.setName(value);
|
||||||
},
|
},
|
||||||
|
|
||||||
'clip-path': function(item, node, name, value) {
|
'clip-path': function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/masking.html#ClipPathProperty
|
// http://www.w3.org/TR/SVG/masking.html#ClipPathProperty
|
||||||
var def = getDefinition(value);
|
var def = getDefinition(value);
|
||||||
return def && createClipGroup(item, def.clone().reduce());
|
return def && createClipGroup(item, def.clone().reduce());
|
||||||
|
@ -429,7 +433,7 @@ new function() {
|
||||||
gradientTransform: applyTransform,
|
gradientTransform: applyTransform,
|
||||||
transform: applyTransform,
|
transform: applyTransform,
|
||||||
|
|
||||||
opacity: function(item, node, name, value) {
|
opacity: function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/masking.html#OpacityProperty
|
// http://www.w3.org/TR/SVG/masking.html#OpacityProperty
|
||||||
item.setOpacity(parseFloat(value));
|
item.setOpacity(parseFloat(value));
|
||||||
},
|
},
|
||||||
|
@ -442,29 +446,29 @@ new function() {
|
||||||
'font-size': applyTextAttribute,
|
'font-size': applyTextAttribute,
|
||||||
'text-anchor': applyTextAttribute,
|
'text-anchor': applyTextAttribute,
|
||||||
|
|
||||||
visibility: function(item, node, name, value) {
|
visibility: function(item, value) {
|
||||||
item.setVisible(value === 'visible');
|
item.setVisible(value === 'visible');
|
||||||
},
|
},
|
||||||
|
|
||||||
'stop-color': function(item, node, name, value) {
|
'stop-color': function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/pservers.html#StopColorProperty
|
// http://www.w3.org/TR/SVG/pservers.html#StopColorProperty
|
||||||
item.setColor(value);
|
item.setColor(value);
|
||||||
},
|
},
|
||||||
|
|
||||||
'stop-opacity': function(item, node, name, value) {
|
'stop-opacity': function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/pservers.html#StopOpacityProperty
|
// http://www.w3.org/TR/SVG/pservers.html#StopOpacityProperty
|
||||||
// NOTE: It is important that this is applied after stop-color!
|
// NOTE: It is important that this is applied after stop-color!
|
||||||
if (item._color)
|
if (item._color)
|
||||||
item._color.setAlpha(parseFloat(value));
|
item._color.setAlpha(parseFloat(value));
|
||||||
},
|
},
|
||||||
|
|
||||||
offset: function(item, node, name, value) {
|
offset: function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/pservers.html#StopElementOffsetAttribute
|
// http://www.w3.org/TR/SVG/pservers.html#StopElementOffsetAttribute
|
||||||
var percentage = value.match(/(.*)%$/);
|
var percentage = value.match(/(.*)%$/);
|
||||||
item.setRampPoint(percentage ? percentage[1] / 100 : value);
|
item.setRampPoint(percentage ? percentage[1] / 100 : value);
|
||||||
},
|
},
|
||||||
|
|
||||||
viewBox: function(item, node, name, value) {
|
viewBox: function(item, value) {
|
||||||
// http://www.w3.org/TR/SVG/coords.html#ViewBoxAttribute
|
// http://www.w3.org/TR/SVG/coords.html#ViewBoxAttribute
|
||||||
// TODO: implement preserveAspectRatio attribute
|
// TODO: implement preserveAspectRatio attribute
|
||||||
if (item instanceof Symbol)
|
if (item instanceof Symbol)
|
||||||
|
@ -484,6 +488,24 @@ new function() {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses an SVG style attibute and applies it to a Paper.js item.
|
||||||
|
*
|
||||||
|
* @param {SVGSVGElement} node an SVG node
|
||||||
|
* @param {Item} item the item to apply the style or attribute to.
|
||||||
|
* @param {String} name an SVG style name
|
||||||
|
* @param value the value of the SVG style
|
||||||
|
*/
|
||||||
|
function applyAttribute(item, value, name, node) {
|
||||||
|
var attribute;
|
||||||
|
if (value != null && (attribute = attributes[name])) {
|
||||||
|
var res = attribute(item, value, name, node);
|
||||||
|
if (res !== undefined)
|
||||||
|
item = res;
|
||||||
|
}
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts various SVG styles and attributes into Paper.js styles and
|
* Converts various SVG styles and attributes into Paper.js styles and
|
||||||
* attributes and applies them to the passed item.
|
* attributes and applies them to the passed item.
|
||||||
|
@ -493,13 +515,14 @@ new function() {
|
||||||
*/
|
*/
|
||||||
function applyAttributes(item, node) {
|
function applyAttributes(item, node) {
|
||||||
// SVG attributes can be set both as styles and direct node attributes,
|
// SVG attributes can be set both as styles and direct node attributes,
|
||||||
// so we need to parse both
|
// so we need to handle both.
|
||||||
var styles = DomElement.getStyles(node),
|
var styles = DomElement.getStyles(node),
|
||||||
parentStyles = DomElement.getStyles(node.parentNode);
|
parentStyles = DomElement.getStyles(node.parentNode);
|
||||||
Base.each(attributes, function(apply, key) {
|
Base.each(attributes, function(apply, key) {
|
||||||
|
// First see if the given attribute is defined.
|
||||||
var attr = node.attributes[key];
|
var attr = node.attributes[key];
|
||||||
if (attr) {
|
if (attr) {
|
||||||
item = applyAttribute(item, node, attr.name, attr.value);
|
item = applyAttribute(item, attr.value, attr.name, node);
|
||||||
} else {
|
} else {
|
||||||
// Fallback to using styles. See if there is a style, either set
|
// Fallback to using styles. See if there is a style, either set
|
||||||
// directly on the object or applied to it through CSS rules.
|
// directly on the object or applied to it through CSS rules.
|
||||||
|
@ -509,30 +532,12 @@ new function() {
|
||||||
if (!value && styles[name] !== parentStyles[name])
|
if (!value && styles[name] !== parentStyles[name])
|
||||||
value = styles[name];
|
value = styles[name];
|
||||||
if (value && value != 'none')
|
if (value && value != 'none')
|
||||||
item = applyAttribute(item, node, key, value);
|
item = applyAttribute(item, value, key, node);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Parses an SVG style attibute and applies it to a Paper.js item.
|
|
||||||
*
|
|
||||||
* @param {SVGSVGElement} node an SVG node
|
|
||||||
* @param {Item} item the item to apply the style or attribute to.
|
|
||||||
* @param {String} name an SVG style name
|
|
||||||
* @param value the value of the SVG style
|
|
||||||
*/
|
|
||||||
function applyAttribute(item, node, name, value) {
|
|
||||||
var attribute;
|
|
||||||
if (value != null && (attribute = attributes[name])) {
|
|
||||||
var res = attribute(item, node, name, value);
|
|
||||||
if (res !== undefined)
|
|
||||||
item = res;
|
|
||||||
}
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
|
|
||||||
var definitions = {};
|
var definitions = {};
|
||||||
function getDefinition(value) {
|
function getDefinition(value) {
|
||||||
// When url() comes from a style property, '#'' seems to be missing on
|
// When url() comes from a style property, '#'' seems to be missing on
|
||||||
|
|
Loading…
Reference in a new issue