Implement Item#isAbove / #isBelow and define tests for it.

This commit is contained in:
Jürg Lehni 2011-05-29 19:54:43 +01:00
parent a05d330106
commit 15da2fe257
3 changed files with 86 additions and 2 deletions

View file

@ -607,6 +607,32 @@ var Item = this.Item = Base.extend({
*/ */
// TODO: isValid / checkValid // TODO: isValid / checkValid
/**
* Returns -1 if 'this' is above 'item', 1 if below, 0 if their order is not
* defined in such a way, e.g. if one is a descendant of the other.
*/
_getOrder: function(item) {
// Private method that prodces a list of anchestors, starting with the
// root and the actual element as the last entry.
function getList(item) {
var list = [];
do {
list.unshift(item);
} while (item = item._parent)
return list;
}
var list1 = getList(this),
list2 = getList(item);
for (var i = 0, l = Math.min(list1.length, list2.length); i < l; i++) {
if (list1[i] != list2[i]) {
// Found the position in the parents list where the two start
// to differ. Look at who's above who.
return list1[i]._index < list2[i]._index ? 1 : -1;
}
}
return 0;
},
/** /**
* Checks if this item is above the specified item in the stacking order * Checks if this item is above the specified item in the stacking order
* of the project. * of the project.
@ -614,7 +640,9 @@ var Item = this.Item = Base.extend({
* @param {Item} item The item to check against * @param {Item} item The item to check against
* @return {boolean} {@true if it is above the specified item} * @return {boolean} {@true if it is above the specified item}
*/ */
// TODO: isAbove isAbove: function(item) {
return this._getOrder(item) == -1;
},
/** /**
* Checks if the item is below the specified item in the stacking order of * Checks if the item is below the specified item in the stacking order of
@ -623,7 +651,9 @@ var Item = this.Item = Base.extend({
* @param {Item} item The item to check against * @param {Item} item The item to check against
* @return {boolean} {@true if it is below the specified item} * @return {boolean} {@true if it is below the specified item}
*/ */
// TODO: isBelow isBelow: function(item) {
return this._getOrder(item) == 1;
},
/** /**
* {@grouptitle Hierarchy Tests} * {@grouptitle Hierarchy Tests}
@ -652,6 +682,7 @@ var Item = this.Item = Base.extend({
* @param {Item} item The item to check against * @param {Item} item The item to check against
* @return {boolean} {@true if it is inside the specified item} * @return {boolean} {@true if it is inside the specified item}
*/ */
// TODO: Consider naming this isInside?
isDescendant: function(item) { isDescendant: function(item) {
var parent = this; var parent = this;
while (parent = parent._parent) { while (parent = parent._parent) {
@ -668,6 +699,7 @@ var Item = this.Item = Base.extend({
* @return {boolean} {@true if the item is an ancestor of the specified * @return {boolean} {@true if the item is an ancestor of the specified
* item} * item}
*/ */
// TODO: Consider naming this contains?
isAncestor: function(item) { isAncestor: function(item) {
return item ? item.isDescendant(this) : false; return item ? item.isDescendant(this) : false;
}, },

View file

@ -93,13 +93,19 @@ if (window.tests) {
'test/tests/Point.js', 'test/tests/Point.js',
'test/tests/Size.js', 'test/tests/Size.js',
'test/tests/Rectangle.js', 'test/tests/Rectangle.js',
'test/tests/Color.js', 'test/tests/Color.js',
'test/tests/Project.js', 'test/tests/Project.js',
'test/tests/Item.js', 'test/tests/Item.js',
'test/tests/Item_Cloning.js', 'test/tests/Item_Cloning.js',
'test/tests/Item_Order.js',
'test/tests/Layer.js', 'test/tests/Layer.js',
'test/tests/Group.js', 'test/tests/Group.js',
'test/tests/Segment.js', 'test/tests/Segment.js',
'test/tests/Path.js', 'test/tests/Path.js',
'test/tests/PathStyle.js', 'test/tests/PathStyle.js',
'test/tests/Path_Shapes.js', 'test/tests/Path_Shapes.js',
@ -108,6 +114,7 @@ if (window.tests) {
'test/tests/Path_Bounds.js', 'test/tests/Path_Bounds.js',
'test/tests/Path_Length.js', 'test/tests/Path_Length.js',
'test/tests/CompoundPath.js', 'test/tests/CompoundPath.js',
'test/tests/PlacedSymbol.js' 'test/tests/PlacedSymbol.js'
); );
} }

45
test/tests/Item_Order.js Normal file
View file

@ -0,0 +1,45 @@
test('Item Order', function() {
var line = new Path();
line.add([0, 0], [100, 100]);
line.name = 'line';
var circle = new Path.Circle([50, 50], 50);
circle.name = 'circle';
window.console.log(circle._getOrder(line), circle.isAbove(line));
var group = new Group([circle]);
group.name = 'group';
equals(function() {
return circle.isAbove(line);
}, true);
equals(function() {
return line.isBelow(circle);
}, true);
equals(function() {
return group.isAbove(line);
}, true);
equals(function() {
return line.isBelow(group);
}, true);
equals(function() {
return group.isAncestor(circle);
}, true);
equals(function() {
return circle.isDescendant(group);
}, true);
equals(function() {
return group.isAbove(circle);
}, false);
equals(function() {
return group.isBelow(circle);
}, false);
});