2018-07-18 16:23:04 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2019-01-15 16:20:22 +00:00
|
|
|
* @copyright 2019 Photon Storm Ltd.
|
2018-07-18 16:23:04 +00:00
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
|
|
|
var DOMElement = require('./DOMElement');
|
|
|
|
var GameObjectFactory = require('../GameObjectFactory');
|
|
|
|
|
|
|
|
/**
|
2019-04-09 22:29:14 +00:00
|
|
|
* Creates a new DOM Element Game Object and adds it to the parent DOM Container.
|
|
|
|
*
|
|
|
|
* The game must have been configured with the `dom.createContainer` property set to `true` for this to work.
|
2018-07-18 16:23:04 +00:00
|
|
|
*
|
2019-04-09 22:29:14 +00:00
|
|
|
* Note: This method will only be available if the DOM Element Game Object has been built into Phaser.
|
2018-07-18 16:23:04 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.GameObjectFactory#dom
|
2019-04-09 22:29:14 +00:00
|
|
|
* @since 3.17.0
|
2018-07-18 16:23:04 +00:00
|
|
|
*
|
2019-04-09 22:29:14 +00:00
|
|
|
* @param {number} x - The horizontal position of this DOM Element in the world.
|
|
|
|
* @param {number} y - The vertical position of this DOM Element in the world.
|
|
|
|
* @param {(HTMLElement|string)} [element] - An existing DOM element, or a string. If a string starting with a # it will do a `getElementById` look-up on the string (minus the hash). Without a hash, it represents the type of element to create, i.e. 'div'.
|
|
|
|
* @param {(string|any)} [style] - If a string, will be set directly as the elements `style` property value. If a plain object, will be iterated and the values transferred. In both cases the values replacing whatever CSS styles may have been previously set.
|
|
|
|
* @param {string} [innerText] - If given, will be set directly as the elements `innerText` property value, replacing whatever was there before.
|
2018-07-18 16:23:04 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.GameObjects.DOMElement} The Game Object that was created.
|
|
|
|
*/
|
2019-04-09 22:29:14 +00:00
|
|
|
GameObjectFactory.register('dom', function (x, y, element, style, innerText)
|
2018-07-18 16:23:04 +00:00
|
|
|
{
|
2019-05-07 15:39:46 +00:00
|
|
|
var gameObject = new DOMElement(this.scene, x, y, element, style, innerText);
|
|
|
|
|
|
|
|
this.displayList.add(gameObject);
|
|
|
|
this.updateList.add(gameObject);
|
|
|
|
|
|
|
|
return gameObject;
|
2018-07-18 16:23:04 +00:00
|
|
|
});
|