Implement Item#onMouseUp events and work on #onMouseMove.

This commit is contained in:
Jürg Lehni 2011-11-16 22:41:22 +01:00
parent 57bd659023
commit 8efc7ce7cd
2 changed files with 34 additions and 19 deletions

View file

@ -65,17 +65,16 @@ var CanvasView = View.extend(/** @lends CanvasView# */{
ctx.restore();
this._redrawNeeded = false;
return true;
},
}
}, new function() { // Item based mouse handling:
// Item based mouse handling:
_hitOptions: {
var hitOptions = {
fill: true,
stroke: true,
tolerance: 0
},
};
_callEvent: function(item, event, bubble) {
function callEvent(item, event, bubble) {
var called = false;
while (item) {
called = item.fire(event.type, event) || called;
@ -84,17 +83,32 @@ var CanvasView = View.extend(/** @lends CanvasView# */{
item = item.getParent();
}
return called;
}
function handleEvent(view, type, event, point) {
if (view._eventCounters[type]) {
var hit = view._project.hitTest(point, hitOptions);
if (hit && hit.item) {
callEvent(hit.item, new MouseEvent(type, point,
hit.item, event), false);
return hit;
}
}
}
return {
_onMouseDown: function(event, point) {
handleEvent(this, 'mousedown', event, point);
},
_onMouseDown: function(event, point) {
if (this._eventCounters.mousedown) {
var hit = this._project.hitTest(point, this._hitOptions);
if (hit && hit.item) {
this._callEvent(hit.item, new MouseEvent('mousedown', point,
hit.item, event), false);
}
}
_onMouseUp: function(event, point) {
handleEvent(this, 'mouseup', event, point);
},
_onMouseMove: function(event, point) {
handleEvent(this, 'mousemove', event, point);
}
};
});
/*#*/ if (options.server) {

View file

@ -495,15 +495,16 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
var view = View._focused;
if (!view || !dragging)
return;
dragging = false;
var point = viewToProject(view, event);
curPoint = null;
if (tool) {
if (tool._onHandleEvent('mouseup', viewToProject(view, event),
event)) {
view.draw(true);
dragging = false;
if (view._onMouseUp)
view._onMouseUp(event, point);
// Cancel DOM-event if it was handled by our tool
if (tool && tool._onHandleEvent('mouseup', point, event))
DomEvent.stop(event);
}
}
// See mousedown() for an explanation of why we can always call this.
view.draw(true);
}
function selectstart(event) {