Always use View.focused in handlers without caching view locally, as it can be modified elsewhere.

This commit is contained in:
Jürg Lehni 2011-06-21 00:42:39 +01:00
parent e0f13dd3a0
commit fc32a6757a

View file

@ -371,25 +371,24 @@ var View = this.View = Base.extend({
*/
onResize: null
}, new function() { // Injection scope for mouse handlers
var view,
tool,
var tool,
timer,
curPoint,
dragging = false;
function viewToArtwork(event) {
function viewToArtwork(view, event) {
return view.viewToArtwork(DomEvent.getOffset(event, view._canvas));
}
function mousemove(event) {
DomEvent.stop(event);
var view = View.focused;
if (!view || !(tool = view._scope.tool))
return;
// If the event was triggered by a touch screen device, prevent the
// default behaviour, as it will otherwise scroll the page:
if (event && event.targetTouches)
DomEvent.preventDefault(event);
var point = event && viewToArtwork(event);
var point = event && viewToArtwork(view, event);
var onlyMove = !!(!tool.onMouseDrag && tool.onMouseMove);
if (dragging && !onlyMove) {
curPoint = point || curPoint;
@ -404,6 +403,7 @@ var View = this.View = Base.extend({
}
function mouseup(event) {
var view = View.focused;
if (!view || !dragging)
return;
dragging = false;
@ -411,9 +411,8 @@ var View = this.View = Base.extend({
if (tool) {
if (timer != null)
timer = clearInterval(timer);
if (tool.onHandleEvent('mouseup', viewToArtwork(event), event))
if (tool.onHandleEvent('mouseup', viewToArtwork(view, event), event))
view.draw(true);
DomEvent.stop(event);
}
}
@ -439,14 +438,14 @@ var View = this.View = Base.extend({
return {
_createEvents: function() {
var that = this;
var view = this;
function mousedown(event) {
// Tell the Key class which view should receive keyboard input.
view = View.focused = that;
View.focused = view;
if (!(tool = view._scope.tool))
return;
curPoint = viewToArtwork(event);
curPoint = viewToArtwork(view, event);
if (tool.onHandleEvent('mousedown', curPoint, event))
view.draw(true);
if (tool.eventInterval != null)