mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
Move color owner handling directly to Color class
There was already Color#_owner, now there is Color#_setter too
This commit is contained in:
parent
06e0c43325
commit
aca3059814
6 changed files with 37 additions and 27 deletions
|
@ -11,6 +11,7 @@
|
||||||
- Fix drawing with compound-paths as clip-items (#1361).
|
- Fix drawing with compound-paths as clip-items (#1361).
|
||||||
- Fix drawing of path selection with small handle size (#1327).
|
- Fix drawing of path selection with small handle size (#1327).
|
||||||
- Correctly calculate bounds with nested empty items (#1467).
|
- Correctly calculate bounds with nested empty items (#1467).
|
||||||
|
- Fix color change propagation on groups (#1152).
|
||||||
- SVG Export: Fix error when `Item#matrix` is not invertible (#1580).
|
- SVG Export: Fix error when `Item#matrix` is not invertible (#1580).
|
||||||
- SVG Export: Include missing viewBox attribute (#1576).
|
- SVG Export: Include missing viewBox attribute (#1576).
|
||||||
- SVG Import: Use correct default values for gradients (#1632, #1661).
|
- SVG Import: Use correct default values for gradients (#1632, #1661).
|
||||||
|
|
|
@ -711,8 +711,9 @@ var Color = Base.extend(new function() {
|
||||||
*/
|
*/
|
||||||
_changed: function() {
|
_changed: function() {
|
||||||
this._canvasStyle = null;
|
this._canvasStyle = null;
|
||||||
if (this._owner)
|
if (this._owner) {
|
||||||
this._owner._changed(/*#=*/Change.STYLE);
|
this._owner[this._setter](this);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1200,6 +1201,20 @@ var Color = Base.extend(new function() {
|
||||||
random: function() {
|
random: function() {
|
||||||
var random = Math.random;
|
var random = Math.random;
|
||||||
return new Color(random(), random(), random());
|
return new Color(random(), random(), random());
|
||||||
|
},
|
||||||
|
|
||||||
|
_setOwner: function(color, owner, setter) {
|
||||||
|
if (color) {
|
||||||
|
// Clone color if owner changes:
|
||||||
|
if (color._owner && owner && color._owner !== owner) {
|
||||||
|
color = color.clone();
|
||||||
|
}
|
||||||
|
if (!color._owner ^ !owner) {
|
||||||
|
color._owner = owner || null;
|
||||||
|
color._setter = setter || null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return color;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -175,12 +175,10 @@ var GradientStop = Base.extend(/** @lends GradientStop# */{
|
||||||
},
|
},
|
||||||
|
|
||||||
setColor: function(/* color */) {
|
setColor: function(/* color */) {
|
||||||
// Make sure newly set colors are cloned, since they can only have
|
// Clear old color owner before setting new one:
|
||||||
// one owner.
|
Color._setOwner(this._color, null);
|
||||||
var color = Color.read(arguments, 0, { clone: true });
|
this._color = Color._setOwner(Color.read(arguments, 0), this,
|
||||||
if (color)
|
'setColor');
|
||||||
color._owner = this;
|
|
||||||
this._color = color;
|
|
||||||
this._changed();
|
this._changed();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -180,17 +180,14 @@ var Style = Base.extend(new function() {
|
||||||
if (isColor) {
|
if (isColor) {
|
||||||
// The old value may be a native string or other color
|
// The old value may be a native string or other color
|
||||||
// description that wasn't coerced to a color object yet
|
// description that wasn't coerced to a color object yet
|
||||||
if (old && old._owner !== undefined) {
|
if (old) {
|
||||||
old._owner = undefined;
|
Color._setOwner(old, null);
|
||||||
old._canvasStyle = null;
|
old._canvasStyle = null;
|
||||||
}
|
}
|
||||||
if (value && value.constructor === Color) {
|
if (value && value.constructor === Color) {
|
||||||
// Clone color if it already has an owner.
|
|
||||||
// NOTE: If value is not a Color, it is only
|
// NOTE: If value is not a Color, it is only
|
||||||
// converted and cloned in the getter further down.
|
// converted and cloned in the getter further down.
|
||||||
if (value._owner)
|
value = Color._setOwner(value, owner, set);
|
||||||
value = value.clone();
|
|
||||||
value._owner = owner;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// NOTE: We do not convert the values to Colors in the
|
// NOTE: We do not convert the values to Colors in the
|
||||||
|
@ -216,8 +213,10 @@ var Style = Base.extend(new function() {
|
||||||
var value = this._values[key];
|
var value = this._values[key];
|
||||||
if (value === undefined) {
|
if (value === undefined) {
|
||||||
value = this._defaults[key];
|
value = this._defaults[key];
|
||||||
if (value && value.clone)
|
// Clone defaults if available:
|
||||||
|
if (value && value.clone) {
|
||||||
value = value.clone();
|
value = value.clone();
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
var ctor = isColor ? Color : isPoint ? Point : null;
|
var ctor = isColor ? Color : isPoint ? Point : null;
|
||||||
if (ctor && !(value && value.constructor === ctor)) {
|
if (ctor && !(value && value.constructor === ctor)) {
|
||||||
|
@ -225,8 +224,6 @@ var Style = Base.extend(new function() {
|
||||||
// conversion.
|
// conversion.
|
||||||
this._values[key] = value = ctor.read([value], 0,
|
this._values[key] = value = ctor.read([value], 0,
|
||||||
{ readNull: true, clone: true });
|
{ readNull: true, clone: true });
|
||||||
if (value && isColor)
|
|
||||||
value._owner = owner;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (children) {
|
} else if (children) {
|
||||||
|
@ -241,11 +238,10 @@ var Style = Base.extend(new function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Turn group related colors into LinkedColor instances that will
|
if (value && isColor) {
|
||||||
// allow calls like `group.fillColor.hue += 10` to be propagated to
|
// Color._setOwner() may clone the color if it already has a
|
||||||
// children.
|
// different owner (e.g. resulting from `childValue` above):
|
||||||
if (owner instanceof Group && value instanceof Color) {
|
value = Color._setOwner(value, owner, set);
|
||||||
value = new LinkedColor(value, owner, set);
|
|
||||||
}
|
}
|
||||||
return value;
|
return value;
|
||||||
};
|
};
|
||||||
|
|
|
@ -106,7 +106,7 @@ var equals = function(actual, expected, message, options) {
|
||||||
|| type === 'boolean' && 'Boolean'
|
|| type === 'boolean' && 'Boolean'
|
||||||
|| type === 'undefined' && 'Undefined'
|
|| type === 'undefined' && 'Undefined'
|
||||||
|| Array.isArray(expected) && 'Array'
|
|| Array.isArray(expected) && 'Array'
|
||||||
|| expected instanceof window.Element && 'Element' // handle DOM Elements
|
|| expected instanceof window.Element && 'Element' // DOM Elements
|
||||||
|| (cls = expected && expected._class) // check _class 2nd last
|
|| (cls = expected && expected._class) // check _class 2nd last
|
||||||
|| type === 'object' && 'Object'; // Object as catch-all
|
|| type === 'object' && 'Object'; // Object as catch-all
|
||||||
var comparator = type && comparators[type];
|
var comparator = type && comparators[type];
|
||||||
|
@ -456,7 +456,7 @@ var comparators = {
|
||||||
equals(actual.components, expected.components,
|
equals(actual.components, expected.components,
|
||||||
message + ' (#components)', options);
|
message + ' (#components)', options);
|
||||||
} else {
|
} else {
|
||||||
QUnit.strictEqual(actual, expected, message);
|
QUnit.push(expected.equals(actual), actual, expected, message);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -303,10 +303,10 @@ test('Gradients with applyMatrix', function() {
|
||||||
comparePixels(path, shape);
|
comparePixels(path, shape);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('LinkedColor for group colors', function() {
|
test('Modifying group.strokeColor for multiple children', function() {
|
||||||
var item = new Group(new Path(), new Path());
|
var item = new Group(new Path(), new Path());
|
||||||
item.strokeColor = 'red';
|
item.strokeColor = 'red';
|
||||||
|
var strokeColor = item.strokeColor;
|
||||||
item.strokeColor.hue = 50;
|
item.strokeColor.hue = 50;
|
||||||
item.strokeColor.hue = 100;
|
equals(function() { return item.strokeColor !== undefined; }, true);
|
||||||
expect(0);
|
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue