2011-06-20 08:56:49 -04:00
|
|
|
/*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2011-06-20 08:56:49 -04:00
|
|
|
* http://paperjs.org/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
|
2011-06-20 08:56:49 -04:00
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-07-01 06:17:45 -04:00
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
2011-06-20 08:56:49 -04:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2011-07-24 19:25:23 -04:00
|
|
|
* @name Style
|
|
|
|
*
|
|
|
|
* @class Internal base-class for all style objects, e.g. PathStyle,
|
|
|
|
* CharacterStyle, PargraphStyle.
|
|
|
|
*
|
|
|
|
* @private
|
2011-06-20 08:56:49 -04:00
|
|
|
*/
|
|
|
|
var Style = Item.extend({
|
2011-06-20 09:10:37 -04:00
|
|
|
initialize: function(style) {
|
2011-06-20 09:58:48 -04:00
|
|
|
// If the passed style object is also a Style, clone its clonable
|
|
|
|
// fields rather than simply copying them.
|
|
|
|
var clone = style instanceof Style;
|
|
|
|
// Note: This relies on bean getters and setters that get implicetly
|
|
|
|
// called when getting from style[key] and setting on this[key].
|
|
|
|
return Base.each(this._defaults, function(value, key) {
|
|
|
|
value = style && style[key] || value;
|
|
|
|
this[key] = value && clone && value.clone
|
|
|
|
? value.clone() : value;
|
2011-06-20 09:10:37 -04:00
|
|
|
}, this);
|
|
|
|
},
|
|
|
|
|
2012-10-22 19:07:22 -04:00
|
|
|
/**
|
|
|
|
* Returns the children to be used to unify style attributes, if any.
|
|
|
|
*/
|
2012-10-22 18:48:51 -04:00
|
|
|
_getChildren: function() {
|
2012-10-22 19:07:22 -04:00
|
|
|
// Only unify styles on children of Group items, excluding CompoundPath.
|
2012-10-22 18:48:51 -04:00
|
|
|
return this._item instanceof Group && this._item._children;
|
|
|
|
},
|
|
|
|
|
2011-06-20 08:56:49 -04:00
|
|
|
statics: {
|
|
|
|
create: function(item) {
|
2012-11-04 00:49:37 -04:00
|
|
|
var style = Base.create(this);
|
2011-06-20 08:56:49 -04:00
|
|
|
style._item = item;
|
|
|
|
return style;
|
2011-06-20 09:58:48 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
extend: function(src) {
|
|
|
|
// Inject style getters and setters into the 'owning' class, which
|
|
|
|
// redirect calls to the linked style objects through their internal
|
|
|
|
// property on the instances of that class, as defined by _style.
|
2011-12-19 16:14:10 -05:00
|
|
|
var styleKey = '_' + src._style,
|
|
|
|
stylePart = Base.capitalize(src._style),
|
|
|
|
flags = src._flags || {},
|
|
|
|
owner = {};
|
|
|
|
|
|
|
|
// Define accessor on owner class for this style:
|
|
|
|
owner['get' + stylePart] = function() {
|
|
|
|
return this[styleKey];
|
|
|
|
};
|
|
|
|
|
|
|
|
owner['set' + stylePart] = function(style) {
|
|
|
|
this[styleKey].initialize(style);
|
|
|
|
};
|
|
|
|
|
|
|
|
Base.each(src._defaults, function(value, key) {
|
2012-11-04 12:00:40 -05:00
|
|
|
var isColor = /Color$/.test(key),
|
2011-06-20 10:21:42 -04:00
|
|
|
part = Base.capitalize(key),
|
2011-06-20 09:58:48 -04:00
|
|
|
set = 'set' + part,
|
|
|
|
get = 'get' + part;
|
2011-06-20 10:21:42 -04:00
|
|
|
// Simply extend src with these getters and setters, to be
|
|
|
|
// injected into this class using this.base() further down.
|
|
|
|
src[set] = function(value) {
|
2012-10-22 18:48:51 -04:00
|
|
|
var children = this._getChildren();
|
2012-10-10 22:27:14 -04:00
|
|
|
// Clone color objects since they reference their owner
|
|
|
|
value = isColor ? Color.read(arguments, 0, 0, true) : value;
|
2011-06-20 10:21:42 -04:00
|
|
|
if (children) {
|
|
|
|
for (var i = 0, l = children.length; i < l; i++)
|
|
|
|
children[i][styleKey][set](value);
|
|
|
|
} else {
|
|
|
|
var old = this['_' + key];
|
2012-11-04 12:00:40 -05:00
|
|
|
if (!Base.equals(old, value)) {
|
2011-06-20 10:21:42 -04:00
|
|
|
if (isColor) {
|
|
|
|
if (old)
|
2012-10-10 22:27:14 -04:00
|
|
|
delete old._owner;
|
|
|
|
if (value) {
|
|
|
|
value._owner = this._item;
|
|
|
|
}
|
2011-06-20 10:21:42 -04:00
|
|
|
}
|
2012-10-10 22:27:14 -04:00
|
|
|
this['_' + key] = value;
|
2011-08-23 10:36:57 -04:00
|
|
|
// Notify the item of the style change STYLE is
|
|
|
|
// always set, additional flags come from _flags,
|
|
|
|
// as used for STROKE:
|
2011-06-20 10:21:42 -04:00
|
|
|
if (this._item)
|
2012-11-05 21:11:44 -05:00
|
|
|
this._item._changed(flags[key] || /*#=*/ Change.STYLE);
|
2011-06-20 10:21:42 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
src[get] = function() {
|
2012-10-22 18:48:51 -04:00
|
|
|
var children = this._getChildren(),
|
2011-06-20 10:21:42 -04:00
|
|
|
style;
|
|
|
|
// If this item has children, walk through all of them and
|
|
|
|
// see if they all have the same style.
|
|
|
|
if (!children)
|
|
|
|
return this['_' + key];
|
|
|
|
for (var i = 0, l = children.length; i < l; i++) {
|
|
|
|
var childStyle = children[i][styleKey][get]();
|
|
|
|
if (!style) {
|
|
|
|
style = childStyle;
|
2012-11-04 12:00:40 -05:00
|
|
|
} else if (!Base.equals(style, childStyle)) {
|
2011-06-20 10:21:42 -04:00
|
|
|
// If there is another item with a different
|
|
|
|
// style, the style is not defined:
|
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return style;
|
|
|
|
};
|
|
|
|
// Style-getters and setters for owner class:
|
2011-12-19 16:14:10 -05:00
|
|
|
owner[set] = function(value) {
|
2011-06-20 10:21:42 -04:00
|
|
|
this[styleKey][set](value);
|
2011-06-20 09:58:48 -04:00
|
|
|
return this;
|
|
|
|
};
|
2011-12-19 16:14:10 -05:00
|
|
|
owner[get] = function() {
|
2011-06-20 10:21:42 -04:00
|
|
|
return this[styleKey][get]();
|
2011-06-20 09:58:48 -04:00
|
|
|
};
|
2011-12-19 16:14:10 -05:00
|
|
|
});
|
|
|
|
src._owner.inject(owner);
|
|
|
|
// Pass on to base()
|
2011-11-18 14:08:54 -05:00
|
|
|
return this.base.apply(this, arguments);
|
2011-06-20 08:56:49 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|