Implement PaperScope#settings.insertItems

Controlling whether newly created items are automatically inserted into the scene graph.
This commit is contained in:
Jürg Lehni 2016-02-14 21:34:35 +01:00
parent 56dd636f22
commit 4e7fa2f04e
4 changed files with 102 additions and 16 deletions

View file

@ -50,6 +50,7 @@ var PaperScope = Base.extend(/** @lends PaperScope# */{
// Default configurable settings. // Default configurable settings.
this.settings = new Base({ this.settings = new Base({
applyMatrix: true, applyMatrix: true,
insertItems: true,
handleSize: 4, handleSize: 4,
hitTolerance: 0 hitTolerance: 0
}); });
@ -115,16 +116,22 @@ var PaperScope = Base.extend(/** @lends PaperScope# */{
*/ */
version: /*#=*/__options.version, version: /*#=*/__options.version,
// DOCS: PaperScope#settings
/** /**
* Gives access to paper's configurable settings. * Gives access to paper's configurable settings.
* *
* @name PaperScope#settings * @name PaperScope#settings
* @type Object * @type Object
* *
* @option [settings.applyMatrix=true] {Boolean} * @option [settings.insertItems=true] {Boolean} controls whether newly
* @option [settings.handleSize=4] {Number} * created items are automatically inserted into the scene graph, by
* @option [settings.hitTolerance=0] {Number} * adding them to {@link Project#getActiveLayer()}
* @option [settings.applyMatrix=true] {Boolean} controls what value newly
* created items have their {@link Item#getApplyMatrix()} property set
* to (Note that not all items can set this to `false`)
* @option [settings.handleSize=4] {Number} the size of the curve handles
* when drawing selections
* @option [settings.hitTolerance=0] {Number} the default tolerance for hit-
* tests, when no value is specified
*/ */
/** /**

View file

@ -127,20 +127,22 @@ new function() { // Injection scope for various item event handlers
internal = hasProps && props.internal === true, internal = hasProps && props.internal === true,
matrix = this._matrix = new Matrix(), matrix = this._matrix = new Matrix(),
// Allow setting another project than the currently active one. // Allow setting another project than the currently active one.
project = hasProps && props.project || paper.project; project = hasProps && props.project || paper.project,
settings = paper.settings;
this._id = internal ? null : UID.get(); this._id = internal ? null : UID.get();
this._parent = this._index = null; this._parent = this._index = null;
// Inherit the applyMatrix setting from paper.settings.applyMatrix // Inherit the applyMatrix setting from settings.applyMatrix
this._applyMatrix = this._canApplyMatrix && paper.settings.applyMatrix; this._applyMatrix = this._canApplyMatrix && settings.applyMatrix;
// Handle matrix before everything else, to avoid issues with // Handle matrix before everything else, to avoid issues with
// #addChild() calling _changed() and accessing _matrix already. // #addChild() calling _changed() and accessing _matrix already.
if (point) if (point)
matrix.translate(point); matrix.translate(point);
matrix._owner = this; matrix._owner = this;
this._style = new Style(project._currentStyle, this, project); this._style = new Style(project._currentStyle, this, project);
// Do not add to the project if it's an internal path, if props.insert // Do not add to the project if it's an internal path, or if
// is false, or if the props are setting a different parent anyway. // props.insert or settings.isnertItems is false.
if (internal || hasProps && props.insert === false) { if (internal || hasProps && props.insert === false
|| !settings.insertItems && !(hasProps && props.insert === true)) {
this._setProject(project); this._setProject(project);
} else { } else {
(hasProps && props.parent || project) (hasProps && props.parent || project)
@ -2327,10 +2329,11 @@ new function() { // Injection scope for hit-test functions shared with project
} else { } else {
// If the item is removed and inserted it again further // If the item is removed and inserted it again further
/// above, the index needs to be adjusted accordingly. /// above, the index needs to be adjusted accordingly.
var shift = item._parent === this && item._index < index; var parent = item._parent,
shift = parent === this && item._index < index;
// Notify parent of change. Don't notify item itself yet, // Notify parent of change. Don't notify item itself yet,
// as we're doing so when adding it to the new parent below. // as we're doing so when adding it to the new parent below.
if (item._remove(false, true) && shift) if (parent && item._remove(false, true) && shift)
index--; index--;
} }
} }

View file

@ -238,7 +238,7 @@ var Project = PaperScopeItem.extend(/** @lends Project# */{
* @type Layer * @type Layer
*/ */
getActiveLayer: function() { getActiveLayer: function() {
return this._activeLayer || new Layer({ project: this }); return this._activeLayer || new Layer({ project: this, insert: true });
}, },
/** /**

View file

@ -693,6 +693,81 @@ test('Item#blendMode in a transformed Group', function() {
'Middle center pixel should be yellow:'); 'Middle center pixel should be yellow:');
}); });
test('Item#applyMatrix', function() {
equals(function() {
return new Path({ applyMatrix: true }).applyMatrix;
}, true);
equals(function() {
return new Path({ applyMatrix: false }).applyMatrix;
}, false);
equals(function() {
return new Raster({ applyMatrix: false }).applyMatrix;
}, false);
equals(function() {
return new Raster({ applyMatrix: true }).applyMatrix;
}, false);
var applyMatrix = paper.settings.applyMatrix;
paper.settings.applyMatrix = true;
equals(function() {
return new Path().applyMatrix;
}, true);
equals(function() {
return new Raster().applyMatrix;
}, false);
paper.settings.applyMatrix = false;
equals(function() {
return new Path().applyMatrix;
}, false);
equals(function() {
return new Raster().applyMatrix;
}, false);
paper.settings.applyMatrix = applyMatrix;
var path = new Path.Rectangle({
size: [100, 100],
position: [0, 0],
applyMatrix: false
});
equals(path.matrix, new Matrix(),
'path.matrix before scaling');
equals(path.bounds, new Rectangle(-50, -50, 100, 100),
'path.bounds before scaling');
equals(path.segments[0].point, new Point(-50, 50),
'path.segments[0].point before scaling');
path.scale(1, 2);
equals(path.matrix, new Matrix().scale(1, 2),
'path.matrix after scaling');
equals(path.bounds, new Rectangle(-50, -100, 100, 200),
'path.bounds after scaling');
equals(path.segments[0].point, new Point(-50, 50),
'path.segments[0].point after scaling');
path.applyMatrix = true;
equals(path.matrix, new Matrix(),
'path.matrix after setting path.applyMatrix = true;');
equals(path.bounds, new Rectangle(-50, -100, 100, 200),
'path.bounds after setting path.applyMatrix = true;');
equals(path.segments[0].point, new Point(-50, 100),
'path.segments[0].point after setting path.applyMatrix = true;');
});
test('PaperScope#settings.insertItems', function() {
var insertItems = paper.settings.insertItems;
paper.settings.insertItems = true;
equals(function() {
return new Path().parent === project.activeLayer;
}, true);
paper.settings.insertItems = false;
equals(function() {
return new Path().parent === null;
}, true);
paper.settings.insertItems = insertItems;
});
test('Item#pivot', function() { test('Item#pivot', function() {
var path1 = new Path.Rectangle({ var path1 = new Path.Rectangle({
@ -713,11 +788,12 @@ test('Item#pivot', function() {
path1.pivot = pivot; path1.pivot = pivot;
path1.position = [200, 200]; path1.position = [200, 200];
equals(path1.pivot, pivot, 'Changing position of an item with applyMatrix = false should not change pivot'); equals(path1.pivot, pivot,
'Changing position of an item with applyMatrix = false should not change pivot');
var difference = new Point(100, 100); var difference = new Point(100, 100);
path2.pivot = pivot; path2.pivot = pivot;
path2.position = path2.position.add(difference); path2.position = path2.position.add(difference);
equals(path2.pivot, pivot.add(difference), 'Changing position of an item with applyMatrix = true should change pivot'); equals(path2.pivot, pivot.add(difference),
'Changing position of an item with applyMatrix = true should change pivot');
}); });