mirror of
https://github.com/photonstorm/phaser
synced 2025-01-11 12:48:50 +00:00
Merge pull request #6 from photonstorm/master
fuse with master + cleanup
This commit is contained in:
commit
641251a338
14 changed files with 78 additions and 68 deletions
|
@ -54,7 +54,7 @@ The following features are now deprecated and will be removed in a future versio
|
||||||
|
|
||||||
My thanks to the following for helping with the Phaser 3 Examples, Docs and TypeScript definitions, either by reporting errors, fixing them or helping author the docs:
|
My thanks to the following for helping with the Phaser 3 Examples, Docs and TypeScript definitions, either by reporting errors, fixing them or helping author the docs:
|
||||||
|
|
||||||
@JasonHK @supertommy
|
@JasonHK @supertommy @majalon @samme
|
||||||
|
|
||||||
## Version 3.22 - Kohaku - January 15th 2020
|
## Version 3.22 - Kohaku - January 15th 2020
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ Grab the source and join the fun!
|
||||||
|
|
||||||
> 15th January 2020
|
> 15th January 2020
|
||||||
|
|
||||||
We're excited to announce the release of Phaser 3.22, the first of many in the year 2020. The main focus of 3.22 is all the work we've done on Matter Physics integration. Matter has been supported in Phaser since the first release, yet there were lots of things we wanted to do with it to make development life easier. 3.22 brings all of these to the front, including powerful new visual debugging options such as rendering contacts, velocity, the broadphase grid, sensors, joints and more. Matter also now has 100% JSDoc and TypeScripy coverage and I spent a long time rebuilding the TypeScript defs by hand, in order to make them as accurate as possible.
|
We're excited to announce the release of Phaser 3.22, the first of many in the year 2020. The main focus of 3.22 is all the work we've done on Matter Physics integration. Matter has been supported in Phaser since the first release, yet there were lots of things we wanted to do with it to make development life easier. 3.22 brings all of these to the front, including powerful new visual debugging options such as rendering contacts, velocity, the broadphase grid, sensors, joints and more. Matter also now has 100% JSDoc and TypeScript coverage and I spent a long time rebuilding the TypeScript defs by hand, in order to make them as accurate as possible.
|
||||||
|
|
||||||
As well as docs and defs there are stacks of handy new methods, including intersection tests such as `intersectPoint`, `intersectRay`, `overlap` and more. New Body level collision callbacks allow you to filter collided pairs a lot more quickly now, combined with new collision events and data type defs to give you all the information you need when resolving. There are now functions to create bodies from SVG data, JSON data or Physics Editor data directly, new Body alignment features and of course bug fixes.
|
As well as docs and defs there are stacks of handy new methods, including intersection tests such as `intersectPoint`, `intersectRay`, `overlap` and more. New Body level collision callbacks allow you to filter collided pairs a lot more quickly now, combined with new collision events and data type defs to give you all the information you need when resolving. There are now functions to create bodies from SVG data, JSON data or Physics Editor data directly, new Body alignment features and of course bug fixes.
|
||||||
|
|
||||||
|
|
|
@ -225,8 +225,8 @@ var Transform = {
|
||||||
/**
|
/**
|
||||||
* The angle of this Game Object in radians.
|
* The angle of this Game Object in radians.
|
||||||
*
|
*
|
||||||
* Phaser uses a right-hand clockwise rotation system, where 0 is right, 90 is down, 180/-180 is left
|
* Phaser uses a right-hand clockwise rotation system, where 0 is right, PI/2 is down, +-PI is left
|
||||||
* and -90 is up.
|
* and -PI/2 is up.
|
||||||
*
|
*
|
||||||
* If you prefer to work in degrees, see the `angle` property instead.
|
* If you prefer to work in degrees, see the `angle` property instead.
|
||||||
*
|
*
|
||||||
|
|
|
@ -28,19 +28,16 @@ var TextStyle = require('../TextStyle');
|
||||||
* applying gradient fills to the text, or strokes, shadows and more. You can also use custom fonts
|
* applying gradient fills to the text, or strokes, shadows and more. You can also use custom fonts
|
||||||
* loaded externally, such as Google or TypeKit Web fonts.
|
* loaded externally, such as Google or TypeKit Web fonts.
|
||||||
*
|
*
|
||||||
* **Important:** If the font you wish to use has a space or digit in its name, such as
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
||||||
* 'Press Start 2P' or 'Roboto Condensed', then you _must_ put the font name in quotes, either
|
* special characters, either when creating the Text object, or when setting the font via `setFont`
|
||||||
* when creating the Text object, or when setting the font via `setFont` or `setFontFamily`. I.e.:
|
* or `setFontFamily`, e.g.:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* this.add.text(0, 0, 'Hello World', { fontFamily: '"Roboto Condensed"' });
|
* this.add.text(0, 0, 'Hello World', { fontFamily: 'Georgia, "Goudy Bookletter 1911", Times, serif' });
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
|
||||||
* quoted properly, too:
|
|
||||||
*
|
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* this.add.text(0, 0, 'Hello World', { fontFamily: 'Verdana, "Times New Roman", Tahoma, serif' });
|
* this.add.text(0, 0, 'Hello World', { font: '"Press Start 2P"' });
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* You can only display fonts that are currently loaded and available to the browser: therefore fonts must
|
* You can only display fonts that are currently loaded and available to the browser: therefore fonts must
|
||||||
|
@ -82,6 +79,8 @@ var TextStyle = require('../TextStyle');
|
||||||
* @param {number} y - The vertical position of this Game Object in the world.
|
* @param {number} y - The vertical position of this Game Object in the world.
|
||||||
* @param {(string|string[])} text - The text this Text object will display.
|
* @param {(string|string[])} text - The text this Text object will display.
|
||||||
* @param {Phaser.Types.GameObjects.Text.TextStyle} style - The text style configuration object.
|
* @param {Phaser.Types.GameObjects.Text.TextStyle} style - The text style configuration object.
|
||||||
|
*
|
||||||
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
||||||
*/
|
*/
|
||||||
var Text = new Class({
|
var Text = new Class({
|
||||||
|
|
||||||
|
@ -644,18 +643,18 @@ var Text = new Class({
|
||||||
* If an object is given, the `fontFamily`, `fontSize` and `fontStyle`
|
* If an object is given, the `fontFamily`, `fontSize` and `fontStyle`
|
||||||
* properties of that object are set.
|
* properties of that object are set.
|
||||||
*
|
*
|
||||||
* **Important:** If the font you wish to use has a space or digit in its name, such as
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
||||||
* 'Press Start 2P' or 'Roboto Condensed', then you _must_ put the font name in quotes:
|
* special characters:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* Text.setFont('"Roboto Condensed"');
|
* Text.setFont('"Press Start 2P"');
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
||||||
* quoted properly, too:
|
* quoted properly, too:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* Text.setFont('Verdana, "Times New Roman", Tahoma, serif');
|
* Text.setFont('Georgia, "Goudy Bookletter 1911", Times, serif');
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* @method Phaser.GameObjects.Text#setFont
|
* @method Phaser.GameObjects.Text#setFont
|
||||||
|
@ -664,6 +663,8 @@ var Text = new Class({
|
||||||
* @param {string} font - The font family or font settings to set.
|
* @param {string} font - The font family or font settings to set.
|
||||||
*
|
*
|
||||||
* @return {this} This Text object.
|
* @return {this} This Text object.
|
||||||
|
*
|
||||||
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
||||||
*/
|
*/
|
||||||
setFont: function (font)
|
setFont: function (font)
|
||||||
{
|
{
|
||||||
|
@ -673,18 +674,18 @@ var Text = new Class({
|
||||||
/**
|
/**
|
||||||
* Set the font family.
|
* Set the font family.
|
||||||
*
|
*
|
||||||
* **Important:** If the font you wish to use has a space or digit in its name, such as
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
||||||
* 'Press Start 2P' or 'Roboto Condensed', then you _must_ put the font name in quotes:
|
* special characters:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* Text.setFont('"Roboto Condensed"');
|
* Text.setFont('"Press Start 2P"');
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
||||||
* quoted properly, too:
|
* quoted properly, too:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
* Text.setFont('Verdana, "Times New Roman", Tahoma, serif');
|
* Text.setFont('Georgia, "Goudy Bookletter 1911", Times, serif');
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* @method Phaser.GameObjects.Text#setFontFamily
|
* @method Phaser.GameObjects.Text#setFontFamily
|
||||||
|
@ -693,6 +694,8 @@ var Text = new Class({
|
||||||
* @param {string} family - The font family.
|
* @param {string} family - The font family.
|
||||||
*
|
*
|
||||||
* @return {this} This Text object.
|
* @return {this} This Text object.
|
||||||
|
*
|
||||||
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
||||||
*/
|
*/
|
||||||
setFontFamily: function (family)
|
setFontFamily: function (family)
|
||||||
{
|
{
|
||||||
|
|
|
@ -8,19 +8,18 @@ var Video = require('./Video');
|
||||||
var GameObjectFactory = require('../GameObjectFactory');
|
var GameObjectFactory = require('../GameObjectFactory');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new Image Game Object and adds it to the Scene.
|
* Creates a new Video Game Object and adds it to the Scene.
|
||||||
*
|
*
|
||||||
* Note: This method will only be available if the Image Game Object has been built into Phaser.
|
* Note: This method will only be available if the Video Game Object has been built into Phaser.
|
||||||
*
|
*
|
||||||
* @method Phaser.GameObjects.GameObjectFactory#video
|
* @method Phaser.GameObjects.GameObjectFactory#video
|
||||||
* @since 3.20.0
|
* @since 3.20.0
|
||||||
*
|
*
|
||||||
* @param {number} x - The horizontal position of this Game Object in the world.
|
* @param {number} x - The horizontal position of this Game Object in the world.
|
||||||
* @param {number} y - The vertical position of this Game Object in the world.
|
* @param {number} y - The vertical position of this Game Object in the world.
|
||||||
* @param {string} texture - The key of the Texture this Game Object will use to render with, as stored in the Texture Manager.
|
* @param {string} [key] - Optional key of the Video this Game Object will play, as stored in the Video Cache.
|
||||||
* @param {(string|integer)} [frame] - An optional frame from the Texture this Game Object is rendering with.
|
|
||||||
*
|
*
|
||||||
* @return {Phaser.GameObjects.Image} The Game Object that was created.
|
* @return {Phaser.GameObjects.Video} The Game Object that was created.
|
||||||
*/
|
*/
|
||||||
GameObjectFactory.register('video', function (x, y, key)
|
GameObjectFactory.register('video', function (x, y, key)
|
||||||
{
|
{
|
||||||
|
|
|
@ -423,7 +423,7 @@ var Vector2 = new Class({
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Right-hand normalize (make unit length) this Vector.
|
* Rotate this Vector to its perpendicular, in the positive direction.
|
||||||
*
|
*
|
||||||
* @method Phaser.Math.Vector2#normalizeRightHand
|
* @method Phaser.Math.Vector2#normalizeRightHand
|
||||||
* @since 3.0.0
|
* @since 3.0.0
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
/**
|
/**
|
||||||
* Linear easing (no variation).
|
* Linear easing (no variation).
|
||||||
*
|
*
|
||||||
* @function Phaser.Math.Easing.Linear.Linear
|
* @function Phaser.Math.Easing.Linear
|
||||||
* @since 3.0.0
|
* @since 3.0.0
|
||||||
*
|
*
|
||||||
* @param {number} v - The value to be tweened.
|
* @param {number} v - The value to be tweened.
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
/**
|
/**
|
||||||
* Stepped easing.
|
* Stepped easing.
|
||||||
*
|
*
|
||||||
* @function Phaser.Math.Easing.Stepped.Stepped
|
* @function Phaser.Math.Easing.Stepped
|
||||||
* @since 3.0.0
|
* @since 3.0.0
|
||||||
*
|
*
|
||||||
* @param {number} v - The value to be tweened.
|
* @param {number} v - The value to be tweened.
|
||||||
|
|
|
@ -15,7 +15,7 @@ var IsPlainObject = require('../../utils/object/IsPlainObject');
|
||||||
* @classdesc
|
* @classdesc
|
||||||
* An Arcade Physics Group object.
|
* An Arcade Physics Group object.
|
||||||
*
|
*
|
||||||
* All Game Objects created by this Group will automatically be given dynamic Arcade Physics bodies.
|
* All Game Objects created by or added to this Group will automatically be given dynamic Arcade Physics bodies, if they have no body.
|
||||||
*
|
*
|
||||||
* Its static counterpart is {@link Phaser.Physics.Arcade.StaticGroup}.
|
* Its static counterpart is {@link Phaser.Physics.Arcade.StaticGroup}.
|
||||||
*
|
*
|
||||||
|
|
|
@ -15,7 +15,7 @@ var IsPlainObject = require('../../utils/object/IsPlainObject');
|
||||||
* @classdesc
|
* @classdesc
|
||||||
* An Arcade Physics Static Group object.
|
* An Arcade Physics Static Group object.
|
||||||
*
|
*
|
||||||
* All Game Objects created by this Group will automatically be given static Arcade Physics bodies.
|
* All Game Objects created by or added to this Group will automatically be given static Arcade Physics bodies, if they have no body.
|
||||||
*
|
*
|
||||||
* Its dynamic counterpart is {@link Phaser.Physics.Arcade.Group}.
|
* Its dynamic counterpart is {@link Phaser.Physics.Arcade.Group}.
|
||||||
*
|
*
|
||||||
|
|
|
@ -14,12 +14,7 @@ var NOOP = require('../utils/NOOP');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @classdesc
|
* @classdesc
|
||||||
* The sound manager is responsible for playing back audio via Web Audio API or HTML Audio tag as fallback.
|
* Base class for other Sound Manager classes.
|
||||||
* The audio file type and the encoding of those files are extremely important.
|
|
||||||
*
|
|
||||||
* Not all browsers can play all audio formats.
|
|
||||||
*
|
|
||||||
* There is a good guide to what's supported [here](https://developer.mozilla.org/en-US/Apps/Fundamentals/Audio_and_video_delivery/Cross-browser_audio_basics#Audio_Codec_Support).
|
|
||||||
*
|
*
|
||||||
* @class BaseSoundManager
|
* @class BaseSoundManager
|
||||||
* @extends Phaser.Events.EventEmitter
|
* @extends Phaser.Events.EventEmitter
|
||||||
|
@ -28,6 +23,10 @@ var NOOP = require('../utils/NOOP');
|
||||||
* @since 3.0.0
|
* @since 3.0.0
|
||||||
*
|
*
|
||||||
* @param {Phaser.Game} game - Reference to the current game instance.
|
* @param {Phaser.Game} game - Reference to the current game instance.
|
||||||
|
*
|
||||||
|
* @see Phaser.Sound.HTML5AudioSoundManager
|
||||||
|
* @see Phaser.Sound.NoAudioSoundManager
|
||||||
|
* @see Phaser.Sound.WebAudioSoundManager
|
||||||
*/
|
*/
|
||||||
var BaseSoundManager = new Class({
|
var BaseSoundManager = new Class({
|
||||||
|
|
||||||
|
@ -266,8 +265,9 @@ var BaseSoundManager = new Class({
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enables playing audio sprite sound on the fly without the need to keep a reference to it.
|
* Adds a new audio sprite sound to the sound manager and plays it.
|
||||||
* Sound will auto destroy once its playback ends.
|
* The sprite will be automatically removed (destroyed) once playback ends.
|
||||||
|
* This lets you play a new sound on the fly without the need to keep a reference to it.
|
||||||
*
|
*
|
||||||
* @method Phaser.Sound.BaseSoundManager#playAudioSprite
|
* @method Phaser.Sound.BaseSoundManager#playAudioSprite
|
||||||
* @listens Phaser.Sound.Events#COMPLETE
|
* @listens Phaser.Sound.Events#COMPLETE
|
||||||
|
|
|
@ -13,7 +13,7 @@ var HTML5AudioSound = require('./HTML5AudioSound');
|
||||||
/**
|
/**
|
||||||
* HTML5 Audio implementation of the Sound Manager.
|
* HTML5 Audio implementation of the Sound Manager.
|
||||||
*
|
*
|
||||||
* Note: To play multiple instances of the same HTML5 Audio sound, you need to provide an `instances` value when
|
* To play multiple instances of the same HTML5 Audio sound, you need to provide an `instances` value when
|
||||||
* loading the sound with the Loader:
|
* loading the sound with the Loader:
|
||||||
*
|
*
|
||||||
* ```javascript
|
* ```javascript
|
||||||
|
@ -22,6 +22,10 @@ var HTML5AudioSound = require('./HTML5AudioSound');
|
||||||
* });
|
* });
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
|
* Not all browsers can play all audio formats.
|
||||||
|
*
|
||||||
|
* There is a good guide to what's supported: [Cross-browser audio basics: Audio codec support](https://developer.mozilla.org/en-US/Apps/Fundamentals/Audio_and_video_delivery/Cross-browser_audio_basics#Audio_Codec_Support).
|
||||||
|
*
|
||||||
* @class HTML5AudioSoundManager
|
* @class HTML5AudioSoundManager
|
||||||
* @extends Phaser.Sound.BaseSoundManager
|
* @extends Phaser.Sound.BaseSoundManager
|
||||||
* @memberof Phaser.Sound
|
* @memberof Phaser.Sound
|
||||||
|
|
|
@ -13,10 +13,10 @@ var NOOP = require('../../utils/NOOP');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @classdesc
|
* @classdesc
|
||||||
* No audio implementation of the sound manager. It is used if audio has been
|
* No-audio implementation of the Sound Manager. It is used if audio has been
|
||||||
* disabled in the game config or the device doesn't support any audio.
|
* disabled in the game config or the device doesn't support any audio.
|
||||||
*
|
*
|
||||||
* It represents a graceful degradation of sound manager logic that provides
|
* It represents a graceful degradation of Sound Manager logic that provides
|
||||||
* minimal functionality and prevents Phaser projects that use audio from
|
* minimal functionality and prevents Phaser projects that use audio from
|
||||||
* breaking on devices that don't support any audio playback technologies.
|
* breaking on devices that don't support any audio playback technologies.
|
||||||
*
|
*
|
||||||
|
|
|
@ -13,7 +13,11 @@ var WebAudioSound = require('./WebAudioSound');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @classdesc
|
* @classdesc
|
||||||
* Web Audio API implementation of the sound manager.
|
* Web Audio API implementation of the Sound Manager.
|
||||||
|
*
|
||||||
|
* Not all browsers can play all audio formats.
|
||||||
|
*
|
||||||
|
* There is a good guide to what's supported: [Cross-browser audio basics: Audio codec support](https://developer.mozilla.org/en-US/Apps/Fundamentals/Audio_and_video_delivery/Cross-browser_audio_basics#Audio_Codec_Support).
|
||||||
*
|
*
|
||||||
* @class WebAudioSoundManager
|
* @class WebAudioSoundManager
|
||||||
* @extends Phaser.Sound.BaseSoundManager
|
* @extends Phaser.Sound.BaseSoundManager
|
||||||
|
|
Loading…
Reference in a new issue