Clean up mouse handling code.

This commit is contained in:
Jürg Lehni 2013-03-05 14:57:41 -08:00
parent 31c06b4a61
commit 7ca22cd260

View file

@ -282,9 +282,7 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
this._element.height = size.height; this._element.height = size.height;
// Update _viewSize but don't notify of change. // Update _viewSize but don't notify of change.
this._viewSize.set(size.width, size.height, true); this._viewSize.set(size.width, size.height, true);
// Force recalculation this._bounds = null; // Force recalculation
this._bounds = null;
this._redrawNeeded = true;
// Call onResize handler on any size change // Call onResize handler on any size change
this.fire('resize', { this.fire('resize', {
size: size, size: size,
@ -571,7 +569,6 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
// Injection scope for mouse events on the browser // Injection scope for mouse events on the browser
/*#*/ if (options.browser) { /*#*/ if (options.browser) {
var tool, var tool,
curPoint,
prevFocus, prevFocus,
tempFocus, tempFocus,
dragging = false; dragging = false;
@ -603,15 +600,15 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
function mousedown(event) { function mousedown(event) {
// Get the view from the event, and store a reference to the view that // Get the view from the event, and store a reference to the view that
// should receive keyboard input. // should receive keyboard input.
var view = View._focused = getView(event); var view = View._focused = getView(event),
curPoint = viewToProject(view, event); point = viewToProject(view, event);
dragging = true; dragging = true;
// Always first call the view's mouse handlers, as required by // Always first call the view's mouse handlers, as required by
// CanvasView, and then handle the active tool, if any. // CanvasView, and then handle the active tool, if any.
if (view._onMouseDown) if (view._onMouseDown)
view._onMouseDown(event, curPoint); view._onMouseDown(event, point);
if (tool = view._scope._tool) if (tool = view._scope._tool)
tool._onHandleEvent('mousedown', curPoint, event); tool._onHandleEvent('mousedown', point, event);
// In the end we always call draw(), but pass checkRedraw = true, so we // In the end we always call draw(), but pass checkRedraw = true, so we
// only redraw the view if anything has changed in the above calls. // only redraw the view if anything has changed in the above calls.
view.draw(true); view.draw(true);
@ -640,15 +637,10 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
if (view._onMouseMove) if (view._onMouseMove)
view._onMouseMove(event, point); view._onMouseMove(event, point);
if (tool = view._scope._tool) { if (tool = view._scope._tool) {
var onlyMove = !!(!tool.onMouseDrag && tool.onMouseMove); // If there's no onMouseDrag, fire onMouseMove while dragging too.
if (dragging && !onlyMove) { if (tool._onHandleEvent(dragging && tool.responds('mousedrag')
if ((curPoint = point || curPoint) ? 'mousedrag' : 'mousemove', point, event))
&& tool._onHandleEvent('mousedrag', curPoint, event))
DomEvent.stop(event);
} else if ((!dragging || onlyMove)
&& tool._onHandleEvent('mousemove', point, event)) {
DomEvent.stop(event); DomEvent.stop(event);
}
} }
view.draw(true); view.draw(true);
} }