mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-08 05:42:07 -05:00
Have all visual changes include ChangeFlags.APPEARANCE.
This commit is contained in:
parent
bfe229ae14
commit
f0bc3f115b
7 changed files with 40 additions and 24 deletions
|
@ -15,10 +15,26 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var ChangeFlags = {
|
var ChangeFlags = {
|
||||||
GEOMETRY: 1, // Item geometry (path, bounds)
|
// Anything affecting the appearance of an item, including GEOMETRY,
|
||||||
STROKE: 2, // Stroke geometry (excluding color)
|
// STROKE, STYLE and ATTRIBUTE (except for the invisible ones: locked, name)
|
||||||
STYLE: 4, // Fill style or stroke color / dash,
|
APPEARANCE: 1,
|
||||||
APPEARANCE: 8, // Visible item attributes: visible, blendMode, opacity ...
|
// Change in item hierarchy
|
||||||
ATTRIBUTE: 16, // Any attributes, also inviislbe ones: locked, name, ...
|
HIERARCHY: 2,
|
||||||
HIERARCHY: 32 // Change in item hierarchy
|
// Item geometry (path, bounds)
|
||||||
|
GEOMETRY: 4,
|
||||||
|
// Stroke geometry (excluding color)
|
||||||
|
STROKE: 8,
|
||||||
|
// Fill style or stroke color / dash
|
||||||
|
STYLE: 16,
|
||||||
|
// Item attributes: visible, blendMode, locked, name, opacity, clipMask ...
|
||||||
|
ATTRIBUTE: 32
|
||||||
|
};
|
||||||
|
|
||||||
|
// Shortcuts to the ChangeFlags to send to #_changed(), all including appearance
|
||||||
|
var Change = {
|
||||||
|
HIERARCHY: ChangeFlags.HIERARCHY | ChangeFlags.APPEARANCE,
|
||||||
|
GEOMETRY: ChangeFlags.GEOMETRY | ChangeFlags.APPEARANCE,
|
||||||
|
STROKE: ChangeFlags.STROKE | ChangeFlags.APPEARANCE,
|
||||||
|
STYLE: ChangeFlags.STYLE | ChangeFlags.APPEARANCE,
|
||||||
|
ATTRIBUTE: ChangeFlags.ATTRIBUTE | ChangeFlags.APPEARANCE
|
||||||
};
|
};
|
||||||
|
|
|
@ -75,7 +75,7 @@ var Group = this.Group = Item.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
_getClipMask: function() {
|
_getClipMask: function() {
|
||||||
// TODO: Use caching once ChangeFlags.HIERARCHY is implemented
|
// TODO: Use caching once Change.HIERARCHY is implemented
|
||||||
for (var i = 0, l = this._children.length; i < l; i++) {
|
for (var i = 0, l = this._children.length; i < l; i++) {
|
||||||
var child = this._children[i];
|
var child = this._children[i];
|
||||||
if (child._clipMask)
|
if (child._clipMask)
|
||||||
|
|
|
@ -209,8 +209,8 @@ var Item = this.Item = Base.extend({
|
||||||
if (value != this[name]) {
|
if (value != this[name]) {
|
||||||
this[name] = value;
|
this[name] = value;
|
||||||
// #locked does not change appearance, all others do:
|
// #locked does not change appearance, all others do:
|
||||||
this._changed(ChangeFlags.ATTRIBUTE
|
this._changed(name === '_locked'
|
||||||
| (name !== '_locked' ? ChangeFlags.APPEARANCE : 0));
|
? ChangeFlags.ATTRIBUTE : Change.ATTRIBUTE);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}, {});
|
}, {});
|
||||||
|
@ -340,7 +340,7 @@ var Item = this.Item = Base.extend({
|
||||||
} else if ((selected = !!selected) != this._selected) {
|
} else if ((selected = !!selected) != this._selected) {
|
||||||
this._selected = selected;
|
this._selected = selected;
|
||||||
this._project._updateSelection(this);
|
this._project._updateSelection(this);
|
||||||
this._changed(ChangeFlags.ATTRIBUTE | ChangeFlags.APPEARANCE);
|
this._changed(Change.ATTRIBUTE);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -367,7 +367,7 @@ var Item = this.Item = Base.extend({
|
||||||
this.setFillColor(null);
|
this.setFillColor(null);
|
||||||
this.setStrokeColor(null);
|
this.setStrokeColor(null);
|
||||||
}
|
}
|
||||||
this._changed(ChangeFlags.ATTRIBUTE | ChangeFlags.APPEARANCE);
|
this._changed(Change.ATTRIBUTE);
|
||||||
},
|
},
|
||||||
|
|
||||||
_clipMask: false,
|
_clipMask: false,
|
||||||
|
@ -671,7 +671,7 @@ var Item = this.Item = Base.extend({
|
||||||
item._setProject(this._project);
|
item._setProject(this._project);
|
||||||
if (item._name)
|
if (item._name)
|
||||||
item.setName(item._name);
|
item.setName(item._name);
|
||||||
this._changed(ChangeFlags.HIERARCHY);
|
this._changed(Change.HIERARCHY);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -810,7 +810,7 @@ var Item = this.Item = Base.extend({
|
||||||
Base.splice(this._parent._children, null, this._index, 1);
|
Base.splice(this._parent._children, null, this._index, 1);
|
||||||
// Notify parent of changed hierarchy
|
// Notify parent of changed hierarchy
|
||||||
if (notify)
|
if (notify)
|
||||||
this._parent._changed(ChangeFlags.HIERARCHY);
|
this._parent._changed(Change.HIERARCHY);
|
||||||
this._parent = null;
|
this._parent = null;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -856,7 +856,7 @@ var Item = this.Item = Base.extend({
|
||||||
for (var i = removed.length - 1; i >= 0; i--)
|
for (var i = removed.length - 1; i >= 0; i--)
|
||||||
removed[i]._remove(true, false);
|
removed[i]._remove(true, false);
|
||||||
if (removed.length > 0)
|
if (removed.length > 0)
|
||||||
this._changed(ChangeFlags.HIERARCHY);
|
this._changed(Change.HIERARCHY);
|
||||||
return removed;
|
return removed;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -869,7 +869,7 @@ var Item = this.Item = Base.extend({
|
||||||
// Adjust inidces
|
// Adjust inidces
|
||||||
for (var i = 0, l = this._children.length; i < l; i++)
|
for (var i = 0, l = this._children.length; i < l; i++)
|
||||||
this._children[i]._index = i;
|
this._children[i]._index = i;
|
||||||
this._changed(ChangeFlags.HIERARCHY);
|
this._changed(Change.HIERARCHY);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -1435,7 +1435,7 @@ var Item = this.Item = Base.extend({
|
||||||
// and transform the cached _bounds and _position without
|
// and transform the cached _bounds and _position without
|
||||||
// recalculating each time.
|
// recalculating each time.
|
||||||
this._transform(matrix, flags);
|
this._transform(matrix, flags);
|
||||||
this._changed(ChangeFlags.GEOMETRY);
|
this._changed(Change.GEOMETRY);
|
||||||
}
|
}
|
||||||
// Transform position as well. Do not modify _position directly,
|
// Transform position as well. Do not modify _position directly,
|
||||||
// since it's a LinkedPoint and would cause recursion!
|
// since it's a LinkedPoint and would cause recursion!
|
||||||
|
|
|
@ -58,7 +58,7 @@ var Layer = this.Layer = Group.extend({
|
||||||
if (deselect)
|
if (deselect)
|
||||||
this.setSelected(false);
|
this.setSelected(false);
|
||||||
Base.splice(this._project.layers, null, this._index, 1);
|
Base.splice(this._project.layers, null, this._index, 1);
|
||||||
this._project._changed(ChangeFlags.HIERARCHY);
|
this._project._changed(Change.HIERARCHY);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -105,8 +105,8 @@ var PathStyle = this.PathStyle = Base.extend(new function() {
|
||||||
if (old != value && !(old && old.equals && old.equals(value))) {
|
if (old != value && !(old && old.equals && old.equals(value))) {
|
||||||
this['_' + key] = value;
|
this['_' + key] = value;
|
||||||
if (this._item) {
|
if (this._item) {
|
||||||
this._item._changed(ChangeFlags.STYLE
|
this._item._changed(Change.STYLE
|
||||||
| (strokeFlags[key] ? ChangeFlags.STROKE : 0));
|
| (strokeFlags[key] ? Change.STROKE : 0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -196,7 +196,7 @@ var Path = this.Path = PathItem.extend({
|
||||||
this._curves[i = length - 1] = Curve.create(this,
|
this._curves[i = length - 1] = Curve.create(this,
|
||||||
this._segments[i], this._segments[0]);
|
this._segments[i], this._segments[0]);
|
||||||
}
|
}
|
||||||
this._changed(ChangeFlags.GEOMETRY);
|
this._changed(Change.GEOMETRY);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -276,7 +276,7 @@ var Path = this.Path = PathItem.extend({
|
||||||
curve._segment1 = segments[index + amount];
|
curve._segment1 = segments[index + amount];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this._changed(ChangeFlags.GEOMETRY);
|
this._changed(Change.GEOMETRY);
|
||||||
return segs;
|
return segs;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -559,7 +559,7 @@ var Path = this.Path = PathItem.extend({
|
||||||
if (last && this._closed && (curve = curves[curves.length - 1]))
|
if (last && this._closed && (curve = curves[curves.length - 1]))
|
||||||
curve._segment2 = segments[0];
|
curve._segment2 = segments[0];
|
||||||
}
|
}
|
||||||
this._changed(ChangeFlags.GEOMETRY);
|
this._changed(Change.GEOMETRY);
|
||||||
return removed;
|
return removed;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -885,7 +885,7 @@ var Path = this.Path = PathItem.extend({
|
||||||
last1.remove();
|
last1.remove();
|
||||||
this.setClosed(true);
|
this.setClosed(true);
|
||||||
}
|
}
|
||||||
this._changed(ChangeFlags.GEOMETRY);
|
this._changed(Change.GEOMETRY);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -102,7 +102,7 @@ var Segment = this.Segment = Base.extend({
|
||||||
other._changed();
|
other._changed();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this._path._changed(ChangeFlags.GEOMETRY);
|
this._path._changed(Change.GEOMETRY);
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue