2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2018-01-17 15:22:16 +00:00
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var Factory = require('./Factory');
|
|
|
|
var GetFastValue = require('../../utils/object/GetFastValue');
|
|
|
|
var GetValue = require('../../utils/object/GetValue');
|
|
|
|
var MatterAttractors = require('./lib/plugins/MatterAttractors');
|
|
|
|
var MatterLib = require('./lib/core/Matter');
|
|
|
|
var MatterWrap = require('./lib/plugins/MatterWrap');
|
|
|
|
var Merge = require('../../utils/object/Merge');
|
|
|
|
var Plugin = require('./lib/core/Plugin');
|
2018-05-10 16:14:33 +00:00
|
|
|
var PluginManager = require('../../plugins/PluginManager');
|
2018-01-17 15:22:16 +00:00
|
|
|
var World = require('./World');
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @class MatterPhysics
|
|
|
|
* @memberOf Phaser.Physics.Matter
|
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Scene} scene - [description]
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
var MatterPhysics = new Class({
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
|
|
|
function MatterPhysics (scene)
|
|
|
|
{
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @name Phaser.Physics.Matter.MatterPhysics#scene
|
|
|
|
* @type {Phaser.Scene}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
this.scene = scene;
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @name Phaser.Physics.Matter.MatterPhysics#systems
|
|
|
|
* @type {Phaser.Scenes.Systems}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
this.systems = scene.sys;
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @name Phaser.Physics.Matter.MatterPhysics#config
|
|
|
|
* @type {object}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
this.config = this.getConfig();
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @name Phaser.Physics.Matter.MatterPhysics#world
|
|
|
|
* @type {Phaser.Physics.Matter.World}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
this.world;
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @name Phaser.Physics.Matter.MatterPhysics#add
|
|
|
|
* @type {Phaser.Physics.Matter.Factory}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
this.add;
|
2018-04-13 16:12:17 +00:00
|
|
|
|
|
|
|
// Matter plugins
|
|
|
|
|
|
|
|
if (GetValue(this.config, 'plugins.attractors', false))
|
|
|
|
{
|
|
|
|
Plugin.register(MatterAttractors);
|
|
|
|
Plugin.use(MatterLib, MatterAttractors);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GetValue(this.config, 'plugins.wrap', false))
|
|
|
|
{
|
|
|
|
Plugin.register(MatterWrap);
|
|
|
|
Plugin.use(MatterLib, MatterWrap);
|
|
|
|
}
|
|
|
|
|
2018-04-17 01:34:07 +00:00
|
|
|
scene.sys.events.once('boot', this.boot, this);
|
2018-04-13 16:12:17 +00:00
|
|
|
scene.sys.events.on('start', this.start, this);
|
|
|
|
},
|
|
|
|
|
2018-04-17 01:34:07 +00:00
|
|
|
/**
|
|
|
|
* This method is called automatically, only once, when the Scene is first created.
|
|
|
|
* Do not invoke it directly.
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#boot
|
|
|
|
* @private
|
|
|
|
* @since 3.5.1
|
|
|
|
*/
|
|
|
|
boot: function ()
|
|
|
|
{
|
|
|
|
this.world = new World(this.scene, this.config);
|
|
|
|
this.add = new Factory(this.world);
|
2018-04-17 11:25:45 +00:00
|
|
|
|
|
|
|
this.systems.events.once('destroy', this.destroy, this);
|
2018-04-17 01:34:07 +00:00
|
|
|
},
|
|
|
|
|
2018-04-13 16:12:17 +00:00
|
|
|
/**
|
|
|
|
* This method is called automatically by the Scene when it is starting up.
|
|
|
|
* It is responsible for creating local systems, properties and listening for Scene events.
|
|
|
|
* Do not invoke it directly.
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#start
|
|
|
|
* @private
|
2018-04-15 11:44:47 +00:00
|
|
|
* @since 3.5.0
|
2018-04-13 16:12:17 +00:00
|
|
|
*/
|
|
|
|
start: function ()
|
|
|
|
{
|
2018-04-17 01:34:07 +00:00
|
|
|
if (!this.world)
|
|
|
|
{
|
|
|
|
this.world = new World(this.scene, this.config);
|
|
|
|
this.add = new Factory(this.world);
|
|
|
|
}
|
2018-04-13 16:12:17 +00:00
|
|
|
|
|
|
|
var eventEmitter = this.systems.events;
|
|
|
|
|
|
|
|
eventEmitter.on('update', this.world.update, this.world);
|
|
|
|
eventEmitter.on('postupdate', this.world.postUpdate, this.world);
|
|
|
|
eventEmitter.once('shutdown', this.shutdown, this);
|
2018-01-17 15:22:16 +00:00
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#getConfig
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {object} [description]
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
getConfig: function ()
|
|
|
|
{
|
|
|
|
var gameConfig = this.systems.game.config.physics;
|
|
|
|
var sceneConfig = this.systems.settings.physics;
|
|
|
|
|
|
|
|
var config = Merge(
|
|
|
|
GetFastValue(sceneConfig, 'matter', {}),
|
|
|
|
GetFastValue(gameConfig, 'matter', {})
|
|
|
|
);
|
|
|
|
|
|
|
|
return config;
|
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#enableAttractorPlugin
|
|
|
|
* @since 3.0.0
|
2018-03-27 14:15:05 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.MatterPhysics} This Matter Physics instance.
|
2018-02-12 13:48:38 +00:00
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
enableAttractorPlugin: function ()
|
|
|
|
{
|
|
|
|
Plugin.register(MatterAttractors);
|
|
|
|
Plugin.use(MatterLib, MatterAttractors);
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#enableWrapPlugin
|
|
|
|
* @since 3.0.0
|
2018-03-27 14:15:05 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.MatterPhysics} This Matter Physics instance.
|
2018-02-12 13:48:38 +00:00
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
enableWrapPlugin: function ()
|
|
|
|
{
|
|
|
|
Plugin.register(MatterWrap);
|
|
|
|
Plugin.use(MatterLib, MatterWrap);
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#pause
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.World} The Matter World object.
|
|
|
|
*/
|
|
|
|
pause: function ()
|
|
|
|
{
|
|
|
|
return this.world.pause();
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#resume
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.World} The Matter World object.
|
|
|
|
*/
|
|
|
|
resume: function ()
|
|
|
|
{
|
|
|
|
return this.world.resume();
|
|
|
|
},
|
|
|
|
|
2018-03-27 14:15:05 +00:00
|
|
|
/**
|
|
|
|
* Sets the Matter Engine to run at fixed timestep of 60Hz and enables `autoUpdate`.
|
|
|
|
* If you have set a custom `getDelta` function then this will override it.
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#set60Hz
|
|
|
|
* @since 3.4.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.MatterPhysics} This Matter Physics instance.
|
|
|
|
*/
|
|
|
|
set60Hz: function ()
|
|
|
|
{
|
|
|
|
this.world.getDelta = this.world.update60Hz;
|
|
|
|
this.world.autoUpdate = true;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the Matter Engine to run at fixed timestep of 30Hz and enables `autoUpdate`.
|
|
|
|
* If you have set a custom `getDelta` function then this will override it.
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#set30Hz
|
|
|
|
* @since 3.4.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Physics.Matter.MatterPhysics} This Matter Physics instance.
|
|
|
|
*/
|
|
|
|
set30Hz: function ()
|
|
|
|
{
|
|
|
|
this.world.getDelta = this.world.update30Hz;
|
|
|
|
this.world.autoUpdate = true;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Manually advances the physics simulation by one iteration.
|
|
|
|
*
|
|
|
|
* You can optionally pass in the `delta` and `correction` values to be used by Engine.update.
|
|
|
|
* If undefined they use the Matter defaults of 60Hz and no correction.
|
|
|
|
*
|
|
|
|
* Calling `step` directly bypasses any checks of `enabled` or `autoUpdate`.
|
|
|
|
*
|
|
|
|
* It also ignores any custom `getDelta` functions, as you should be passing the delta
|
|
|
|
* value in to this call.
|
|
|
|
*
|
|
|
|
* You can adjust the number of iterations that Engine.update performs internally.
|
|
|
|
* Use the Scene Matter Physics config object to set the following properties:
|
|
|
|
*
|
|
|
|
* positionIterations (defaults to 6)
|
|
|
|
* velocityIterations (defaults to 4)
|
|
|
|
* constraintIterations (defaults to 2)
|
|
|
|
*
|
|
|
|
* Adjusting these values can help performance in certain situations, depending on the physics requirements
|
|
|
|
* of your game.
|
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#step
|
|
|
|
* @since 3.4.0
|
|
|
|
*
|
|
|
|
* @param {number} [delta=16.666] - [description]
|
|
|
|
* @param {number} [correction=1] - [description]
|
|
|
|
*/
|
|
|
|
step: function (delta, correction)
|
|
|
|
{
|
|
|
|
this.world.step(delta, correction);
|
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
2018-04-13 16:12:17 +00:00
|
|
|
* The Scene that owns this plugin is shutting down.
|
|
|
|
* We need to kill and reset all internal properties as well as stop listening to Scene events.
|
2018-02-12 13:48:38 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#shutdown
|
2018-04-13 16:12:17 +00:00
|
|
|
* @private
|
2018-02-12 13:48:38 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
shutdown: function ()
|
|
|
|
{
|
2018-04-13 16:12:17 +00:00
|
|
|
var eventEmitter = this.systems.events;
|
|
|
|
|
|
|
|
eventEmitter.off('update', this.world.update, this.world);
|
|
|
|
eventEmitter.off('postupdate', this.world.postUpdate, this.world);
|
|
|
|
eventEmitter.off('shutdown', this.shutdown, this);
|
2018-04-17 01:34:07 +00:00
|
|
|
|
|
|
|
this.add.destroy();
|
|
|
|
this.world.destroy();
|
|
|
|
|
|
|
|
this.add = null;
|
|
|
|
this.world = null;
|
2018-01-17 15:22:16 +00:00
|
|
|
},
|
|
|
|
|
2018-02-12 13:48:38 +00:00
|
|
|
/**
|
2018-04-13 16:12:17 +00:00
|
|
|
* The Scene that owns this plugin is being destroyed.
|
|
|
|
* We need to shutdown and then kill off all external references.
|
2018-02-12 13:48:38 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Physics.Matter.MatterPhysics#destroy
|
2018-04-13 16:12:17 +00:00
|
|
|
* @private
|
2018-02-12 13:48:38 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-17 15:22:16 +00:00
|
|
|
destroy: function ()
|
|
|
|
{
|
2018-04-13 16:12:17 +00:00
|
|
|
this.shutdown();
|
|
|
|
|
|
|
|
this.scene.sys.events.off('start', this.start, this);
|
|
|
|
|
|
|
|
this.scene = null;
|
|
|
|
this.systems = null;
|
2018-01-17 15:22:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2018-01-18 05:18:09 +00:00
|
|
|
PluginManager.register('MatterPhysics', MatterPhysics, 'matterPhysics');
|
2018-01-17 15:22:16 +00:00
|
|
|
|
|
|
|
module.exports = MatterPhysics;
|