メインコンテンツまでスキップ

ホットリロード

複雑なプロジェクトで反復的な作業を行う場合、スクリプトを変更するたびにページ全体をリフレッシュする必要があると手間取ることもあります。特に、コードをテストするまでに時間がかかる場合は不便です。そこで、コードのホットスワップを利用することができます。

ホットスワップの使い方

ホットスワップはスクリプトごとに有効になっており、使用するには swap() メソッドを実装する必要があります。

MyScript.prototype.swap = function(old) {
// recover state here
};

swap 関数があるスクリプトがコードエディターで変更されると、起動しているすべてのアプリケーションはスクリプトをリロードし、スクリプトをスクリプトレジストリに追加します。その後、古いスクリプトと交換するために新しいスクリプトインスタンスを作成し、そのプロセスの間に各インスタンスで swap メソッドを呼び出します。スクリプトの initialize メソッドは再度呼び出されません。代わりに、古いスクリプトインスタンスが swap メソッドに渡され、開発者が古いスクリプトの状態を新しいスクリプトにコピーすることを確認する必要があります。宣言されたスクリプト属性は自動的に新しいスクリプトインスタンスにコピーされます。また、古いインスタンスからすべてのイベントリスナーを削除し、新しいインスタンスに再度設定することが重要です。

以下に例を示します。

var Rotator = pc.createScript('rotator');

Rotator.attributes.add('xSpeed', { type: 'number', default: 10 });

Rotator.prototype.initialize = function () {
// listen for enable event and call method
this.on('enable', this._onEnable);

this.ySpeed = 0;
};

Rotator.prototype.swap = function (old) {
// xSpeed is an attribute and so is automatically copied

// copy the ySpeed property from the old script instance to the new one
this.ySpeed = old.ySpeed;

// remove the old event listener
old.off('enable', old._onEnable);
// add a new event listener
this.on('enable', this._onEnable);
};

Rotator.prototype._onEnable = function () {
// when enabled randomize the speed
this.ySpeed = pc.math.random(0, 10);
}

Rotator.prototype.update = function (dt) {
this.entity.rotate(this.xSpeed * dt, this.ySpeed * dt, 0);
};

update メソッド内のロジックを変更してコードを保存してみてください。起動中のアプリケーションは、新しい rotator スクリプトインスタンスと交換して、新しいロジックで作動し続けます。

swap メソッドはスクリプトインスタンスの実行状態にかかわらず、呼び出されるため、エラーによって無効になった場合でも、swap メソッドで再度有効にできます。