mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
parent
b56d18d6a4
commit
e7c4e3c990
2 changed files with 27 additions and 3 deletions
|
@ -93,7 +93,7 @@ var Project = PaperScopeItem.extend(/** @lends Project# */{
|
|||
// (via view.requestUpdate()), which handles the smooth updates.
|
||||
this._needsUpdate = true;
|
||||
var view = this._view;
|
||||
if (view && !view._requested)
|
||||
if (view && !view._requested && view._autoUpdate)
|
||||
view.requestUpdate();
|
||||
}
|
||||
// Have project keep track of changed items so they can be iterated.
|
||||
|
|
|
@ -107,6 +107,8 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
|||
// Count the installed native and virtual item events,
|
||||
// see #_countItemEvent():
|
||||
this._itemEvents = { native: {}, virtual: {} };
|
||||
// Do not set _autoUpdate on Node.js by default:
|
||||
this._autoUpdate = !paper.agent.node;
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -161,6 +163,26 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
|||
_time: 0,
|
||||
_count: 0,
|
||||
|
||||
/**
|
||||
* Controls whether the view is automatically updated in the next animation
|
||||
* frame on changes, or whether you prefer to manually call
|
||||
* {@link #update()} or {@link #requestUpdate()} after changes.
|
||||
* Note that this is `true` by default, except for Node.js, where manual
|
||||
* updates make more sense.
|
||||
*
|
||||
* @bean
|
||||
* @type Boolean
|
||||
*/
|
||||
getAutoUpdate: function() {
|
||||
return this._autoUpdate;
|
||||
},
|
||||
|
||||
setAutoUpdate: function(autoUpdate) {
|
||||
this._autoUpdate = autoUpdate;
|
||||
if (autoUpdate)
|
||||
this.requestUpdate();
|
||||
},
|
||||
|
||||
/**
|
||||
* Updates the view if there are changes. Note that when using built-in
|
||||
* event hanlders for interaction, animation and load events, this method is
|
||||
|
@ -205,6 +227,7 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
|||
}
|
||||
// Even if we're not animating, update the view now since this
|
||||
// might have been a request for a single redraw after a change
|
||||
if (that._autoUpdate)
|
||||
that.update();
|
||||
}, this._element);
|
||||
this._requested = true;
|
||||
|
@ -354,6 +377,7 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
|||
delta: delta
|
||||
});
|
||||
this._changed();
|
||||
if (this._autoUpdate)
|
||||
this.requestUpdate();
|
||||
},
|
||||
|
||||
|
|
Loading…
Reference in a new issue