mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-04 03:45:58 -05:00
Implement PaperScope#settings.insertItems
Controlling whether newly created items are automatically inserted into the scene graph.
This commit is contained in:
parent
56dd636f22
commit
4e7fa2f04e
4 changed files with 102 additions and 16 deletions
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 });
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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');
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue