From e7c4e3c990077d033b81547f49b17d9d6abb799c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 27 Jan 2016 13:10:04 +0100 Subject: [PATCH] Implement View#autoUpdate to control automatic updates. Closes #921 --- src/project/Project.js | 2 +- src/view/View.js | 28 ++++++++++++++++++++++++++-- 2 files changed, 27 insertions(+), 3 deletions(-) diff --git a/src/project/Project.js b/src/project/Project.js index bcf5d0ba..350c107d 100644 --- a/src/project/Project.js +++ b/src/project/Project.js @@ -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. diff --git a/src/view/View.js b/src/view/View.js index 9a9295dd..3db9ec1a 100644 --- a/src/view/View.js +++ b/src/view/View.js @@ -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,7 +227,8 @@ 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 - that.update(); + if (that._autoUpdate) + that.update(); }, this._element); this._requested = true; } @@ -354,7 +377,8 @@ var View = Base.extend(Emitter, /** @lends View# */{ delta: delta }); this._changed(); - this.requestUpdate(); + if (this._autoUpdate) + this.requestUpdate(); }, /**