Implement Item#onMouseEnter / #onMouseLeave.

This commit is contained in:
Jürg Lehni 2011-11-16 22:59:39 +01:00
parent c0e6d5b2ee
commit b3bf57c8e9
2 changed files with 23 additions and 15 deletions

View file

@ -74,28 +74,18 @@ var CanvasView = View.extend(/** @lends CanvasView# */{
tolerance: 0 tolerance: 0
}; };
function callEvent(item, event, bubble) {
var called = false;
while (item) {
called = item.fire(event.type, event) || called;
if (called && (!bubble || event._stopped))
break;
item = item.getParent();
}
return called;
}
function handleEvent(view, type, event, point) { function handleEvent(view, type, event, point) {
if (view._eventCounters[type]) { if (view._eventCounters[type]) {
var hit = view._project.hitTest(point, hitOptions); var hit = view._project.hitTest(point, hitOptions);
if (hit && hit.item) { if (hit && hit.item) {
callEvent(hit.item, new MouseEvent(type, point, new MouseEvent(type, point, hit.item, event)._call();
hit.item, event), false); return hit.item;
return hit;
} }
} }
} }
var overItem = null;
return { return {
_onMouseDown: function(event, point) { _onMouseDown: function(event, point) {
handleEvent(this, 'mousedown', event, point); handleEvent(this, 'mousedown', event, point);
@ -106,7 +96,12 @@ var CanvasView = View.extend(/** @lends CanvasView# */{
}, },
_onMouseMove: function(event, point) { _onMouseMove: function(event, point) {
handleEvent(this, 'mousemove', event, point); var item = handleEvent(this, 'mousemove', event, point);
if (item != overItem) {
new MouseEvent('mouseleave', point, overItem, event)._call();
overItem = item;
new MouseEvent('mouseenter', point, item, event)._call();
}
} }
}; };
}); });

View file

@ -36,5 +36,18 @@ var MouseEvent = this.MouseEvent = Event.extend(/** @lends MouseEvent# */{
+ ', target: ' + this.target + ', target: ' + this.target
+ ', modifiers: ' + this.getModifiers() + ', modifiers: ' + this.getModifiers()
+ ' }'; + ' }';
},
// TODO: Move to Event perhaps?
_call: function(bubble) {
var item = this.target,
called = false;
while (item) {
called = item.fire(this.type, this) || called;
if (called && (!bubble || this._stopped))
break;
item = item.getParent();
}
return called;
} }
}); });