mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Define CompoundPath#reverse() and #clockwise, and replace reversePath() with it.
This commit is contained in:
parent
3515574f65
commit
d5543842e9
3 changed files with 33 additions and 22 deletions
|
@ -89,11 +89,36 @@ var CompoundPath = this.CompoundPath = PathItem.extend(/** @lends CompoundPath#
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverses the orientation of all nested paths.
|
||||||
|
*/
|
||||||
|
reverse: function() {
|
||||||
|
var children = this._children;
|
||||||
|
for (var i = 0, l = children.length; i < l; i++)
|
||||||
|
children[i].reverse();
|
||||||
|
},
|
||||||
|
|
||||||
smooth: function() {
|
smooth: function() {
|
||||||
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].smooth();
|
this._children[i].smooth();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Specifies whether the compound path is oriented clock-wise.
|
||||||
|
*
|
||||||
|
* @type Boolean
|
||||||
|
* @bean
|
||||||
|
*/
|
||||||
|
isClockwise: function() {
|
||||||
|
var child = this.getFirstChild();
|
||||||
|
return child && child.isClockwise();
|
||||||
|
},
|
||||||
|
|
||||||
|
setClockwise: function(clockwise) {
|
||||||
|
if (this.isClockwise() != !!clockwise)
|
||||||
|
this.reverse();
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The first Segment contained within the path.
|
* The first Segment contained within the path.
|
||||||
*
|
*
|
||||||
|
|
|
@ -1085,19 +1085,18 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
|
||||||
},
|
},
|
||||||
|
|
||||||
setClockwise: function(clockwise) {
|
setClockwise: function(clockwise) {
|
||||||
// On-the-fly conversion to boolean:
|
|
||||||
if (this.isClockwise() != (clockwise = !!clockwise)) {
|
|
||||||
// Only revers the path if its clockwise orientation is not the same
|
// Only revers the path if its clockwise orientation is not the same
|
||||||
// as what it is now demanded to be.
|
// as what it is now demanded to be.
|
||||||
|
// On-the-fly conversion to boolean:
|
||||||
|
if (this.isClockwise() != (clockwise = !!clockwise))
|
||||||
this.reverse();
|
this.reverse();
|
||||||
}
|
|
||||||
// Reverse only flips _clockwise state if it was already set, so let's
|
// Reverse only flips _clockwise state if it was already set, so let's
|
||||||
// always set this here now.
|
// always set this here now.
|
||||||
this._clockwise = clockwise;
|
this._clockwise = clockwise;
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reverses the segments of the path.
|
* Reverses the orientation of the path, by reversing all its segments.
|
||||||
*/
|
*/
|
||||||
reverse: function() {
|
reverse: function() {
|
||||||
this._segments.reverse();
|
this._segments.reverse();
|
||||||
|
|
|
@ -108,21 +108,6 @@ PathItem.inject(new function() {
|
||||||
return baseWinding;
|
return baseWinding;
|
||||||
}
|
}
|
||||||
|
|
||||||
function reversePath(path) {
|
|
||||||
var baseWinding;
|
|
||||||
if (path instanceof CompoundPath) {
|
|
||||||
var children = path.children, i, len;
|
|
||||||
for (i = 0, len = children.length; i < len; i++) {
|
|
||||||
children[i].reverse();
|
|
||||||
}
|
|
||||||
baseWinding = children[0].clockwise;
|
|
||||||
} else {
|
|
||||||
path.reverse();
|
|
||||||
baseWinding = path.clockwise;
|
|
||||||
}
|
|
||||||
return baseWinding;
|
|
||||||
}
|
|
||||||
|
|
||||||
function computeBoolean(path1, path2, operator, subtract, _cache) {
|
function computeBoolean(path1, path2, operator, subtract, _cache) {
|
||||||
var _path1, _path2, path1Clockwise, path2Clockwise;
|
var _path1, _path2, path1Clockwise, path2Clockwise;
|
||||||
var ixs, path1Id, path2Id;
|
var ixs, path1Id, path2Id;
|
||||||
|
@ -147,8 +132,10 @@ PathItem.inject(new function() {
|
||||||
path1Id = _path1.id;
|
path1Id = _path1.id;
|
||||||
path2Id = _path2.id;
|
path2Id = _path2.id;
|
||||||
// Do operator specific calculations before we begin
|
// Do operator specific calculations before we begin
|
||||||
if (subtract)
|
if (subtract) {
|
||||||
path2Clockwise = reversePath(_path2);
|
_path2.reverse();
|
||||||
|
path2Clockwise = !path2Clockwise;
|
||||||
|
}
|
||||||
|
|
||||||
var i, j, len, path, crv;
|
var i, j, len, path, crv;
|
||||||
var paths = [];
|
var paths = [];
|
||||||
|
|
Loading…
Reference in a new issue