mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Always use View.focused in handlers without caching view locally, as it can be modified elsewhere.
This commit is contained in:
parent
e0f13dd3a0
commit
fc32a6757a
1 changed files with 9 additions and 10 deletions
|
@ -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)
|
||||
|
|
Loading…
Reference in a new issue