2022-03-18 17:46:08 +01:00
|
|
|
.. _doc_html5_shell_classref:
|
|
|
|
|
|
|
|
HTML5 shell class reference
|
|
|
|
===========================
|
|
|
|
|
|
|
|
Projects exported for the Web expose the :js:class:`Engine` class to the JavaScript environment, that allows
|
|
|
|
fine control over the engine's start-up process.
|
|
|
|
|
|
|
|
This API is built in an asynchronous manner and requires basic understanding
|
|
|
|
of `Promises <https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Using_promises>`__.
|
|
|
|
|
|
|
|
Engine
|
|
|
|
------
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `Engine` class provides methods for loading and starting exported projects on the Web. For default export
|
|
|
|
settings, this is already part of the exported HTML page. To understand practical use of the `Engine` class,
|
2023-01-12 19:29:11 +01:00
|
|
|
see `Custom HTML page for Web export <doc_customizing_html5_shell>`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Static Methods
|
|
|
|
^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
+---------+-----------------------------------------------------------------------------------------------+
|
|
|
|
| Promise | :js:attr:`load <Engine.load>` **(** string basePath **)** |
|
|
|
|
+---------+-----------------------------------------------------------------------------------------------+
|
|
|
|
| void | :js:attr:`unload <Engine.unload>` **(** **)** |
|
|
|
|
+---------+-----------------------------------------------------------------------------------------------+
|
|
|
|
| boolean | :js:attr:`isWebGLAvailable <Engine.isWebGLAvailable>` **(** *[ number majorVersion=1 ]* **)** |
|
|
|
|
+---------+-----------------------------------------------------------------------------------------------+
|
|
|
|
|
|
|
|
Instance Methods
|
|
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| Promise | :js:attr:`init <Engine.prototype.init>` **(** *[ string basePath ]* **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| Promise | :js:attr:`preloadFile <Engine.prototype.preloadFile>` **(** string\|ArrayBuffer file *[, string path ]* **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| Promise | :js:attr:`start <Engine.prototype.start>` **(** EngineConfig override **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| Promise | :js:attr:`startGame <Engine.prototype.startGame>` **(** EngineConfig override **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| void | :js:attr:`copyToFS <Engine.prototype.copyToFS>` **(** string path, ArrayBuffer buffer **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| void | :js:attr:`requestQuit <Engine.prototype.requestQuit>` **(** **)** |
|
|
|
|
+---------+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
|
|
|
|
.. js:class:: Engine( initConfig )
|
|
|
|
|
|
|
|
Create a new Engine instance with the given configuration.
|
|
|
|
|
|
|
|
:param EngineConfig initConfig:
|
|
|
|
The initial config for this instance.
|
|
|
|
|
|
|
|
**Static Methods**
|
|
|
|
|
|
|
|
.. js:function:: load( basePath )
|
|
|
|
|
|
|
|
Load the engine from the specified base path.
|
|
|
|
|
|
|
|
:param string basePath:
|
|
|
|
Base path of the engine to load.
|
|
|
|
|
|
|
|
:return:
|
|
|
|
A Promise that resolves once the engine is loaded.
|
|
|
|
|
|
|
|
:rtype: Promise
|
|
|
|
|
|
|
|
.. js:function:: unload( )
|
|
|
|
|
|
|
|
Unload the engine to free memory.
|
|
|
|
|
|
|
|
This method will be called automatically depending on the configuration. See :js:attr:`unloadAfterInit`.
|
|
|
|
|
|
|
|
.. js:function:: isWebGLAvailable( [ majorVersion=1 ] )
|
|
|
|
|
|
|
|
Check whether WebGL is available. Optionally, specify a particular version of WebGL to check for.
|
|
|
|
|
|
|
|
:param number majorVersion:
|
|
|
|
The major WebGL version to check for.
|
|
|
|
|
|
|
|
:return:
|
|
|
|
If the given major version of WebGL is available.
|
|
|
|
|
|
|
|
:rtype: boolean
|
|
|
|
|
|
|
|
**Instance Methods**
|
|
|
|
|
|
|
|
.. js:function:: prototype.init( [ basePath ] )
|
|
|
|
|
|
|
|
Initialize the engine instance. Optionally, pass the base path to the engine to load it,
|
|
|
|
if it hasn't been loaded yet. See :js:meth:`Engine.load`.
|
|
|
|
|
|
|
|
:param string basePath:
|
|
|
|
Base path of the engine to load.
|
|
|
|
|
|
|
|
:return:
|
2023-01-12 19:43:03 +01:00
|
|
|
A `Promise` that resolves once the engine is loaded and initialized.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:rtype: Promise
|
|
|
|
|
|
|
|
.. js:function:: prototype.preloadFile( file [, path ] )
|
|
|
|
|
|
|
|
Load a file so it is available in the instance's file system once it runs. Must be called **before** starting the
|
|
|
|
instance.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If not provided, the `path` is derived from the URL of the loaded file.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:param string\|ArrayBuffer file:
|
|
|
|
The file to preload.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If a `string` the file will be loaded from that path.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If an `ArrayBuffer` or a view on one, the buffer will used as the content of the file.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:param string path:
|
2023-01-12 19:43:03 +01:00
|
|
|
Path by which the file will be accessible. Required, if `file` is not a string.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:return:
|
|
|
|
A Promise that resolves once the file is loaded.
|
|
|
|
|
|
|
|
:rtype: Promise
|
|
|
|
|
|
|
|
.. js:function:: prototype.start( override )
|
|
|
|
|
|
|
|
Start the engine instance using the given override configuration (if any).
|
|
|
|
:js:meth:`startGame <Engine.prototype.startGame>` can be used in typical cases instead.
|
|
|
|
|
|
|
|
This will initialize the instance if it is not initialized. For manual initialization, see :js:meth:`init <Engine.prototype.init>`.
|
|
|
|
The engine must be loaded beforehand.
|
|
|
|
|
|
|
|
Fails if a canvas cannot be found on the page, or not specified in the configuration.
|
|
|
|
|
|
|
|
:param EngineConfig override:
|
|
|
|
An optional configuration override.
|
|
|
|
|
|
|
|
:return:
|
|
|
|
Promise that resolves once the engine started.
|
|
|
|
|
|
|
|
:rtype: Promise
|
|
|
|
|
|
|
|
.. js:function:: prototype.startGame( override )
|
|
|
|
|
|
|
|
Start the game instance using the given configuration override (if any).
|
|
|
|
|
|
|
|
This will initialize the instance if it is not initialized. For manual initialization, see :js:meth:`init <Engine.prototype.init>`.
|
|
|
|
|
|
|
|
This will load the engine if it is not loaded, and preload the main pck.
|
|
|
|
|
|
|
|
This method expects the initial config (or the override) to have both the :js:attr:`executable` and :js:attr:`mainPack`
|
|
|
|
properties set (normally done by the editor during export).
|
|
|
|
|
|
|
|
:param EngineConfig override:
|
|
|
|
An optional configuration override.
|
|
|
|
|
|
|
|
:return:
|
|
|
|
Promise that resolves once the game started.
|
|
|
|
|
|
|
|
:rtype: Promise
|
|
|
|
|
|
|
|
.. js:function:: prototype.copyToFS( path, buffer )
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Create a file at the specified `path` with the passed as `buffer` in the instance's file system.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:param string path:
|
|
|
|
The location where the file will be created.
|
|
|
|
|
|
|
|
:param ArrayBuffer buffer:
|
|
|
|
The content of the file.
|
|
|
|
|
|
|
|
.. js:function:: prototype.requestQuit( )
|
|
|
|
|
|
|
|
Request that the current instance quit.
|
|
|
|
|
|
|
|
This is akin the user pressing the close button in the window manager, and will
|
|
|
|
have no effect if the engine has crashed, or is stuck in a loop.
|
|
|
|
|
|
|
|
Engine configuration
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
An object used to configure the Engine instance based on godot export options, and to override those in custom HTML
|
|
|
|
templates if needed.
|
|
|
|
|
|
|
|
Properties
|
|
|
|
^^^^^^^^^^
|
|
|
|
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| type | name |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| boolean | :js:attr:`unloadAfterInit` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| HTMLCanvasElement | :js:attr:`canvas` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| string | :js:attr:`executable` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| string | :js:attr:`mainPack` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| string | :js:attr:`locale` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| number | :js:attr:`canvasResizePolicy` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| Array.<string> | :js:attr:`args` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| function | :js:attr:`onExecute` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| function | :js:attr:`onExit` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| function | :js:attr:`onProgress` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| function | :js:attr:`onPrint` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
| function | :js:attr:`onPrintError` |
|
|
|
|
+-------------------+-------------------------------+
|
|
|
|
|
|
|
|
.. js:attribute:: EngineConfig
|
|
|
|
|
|
|
|
The Engine configuration object. This is just a typedef, create it like a regular object, e.g.:
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
`const MyConfig = { executable: 'godot', unloadAfterInit: false }`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Property Descriptions**
|
|
|
|
|
|
|
|
.. js:attribute:: unloadAfterInit
|
|
|
|
|
|
|
|
Whether the unload the engine automatically after the instance is initialized.
|
|
|
|
|
|
|
|
:type: boolean
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `true`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: canvas
|
|
|
|
|
|
|
|
The HTML DOM Canvas object to use.
|
|
|
|
|
|
|
|
By default, the first canvas element in the document will be used is none is specified.
|
|
|
|
|
|
|
|
:type: HTMLCanvasElement
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `null`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: executable
|
|
|
|
|
|
|
|
The name of the WASM file without the extension. (Set by Godot Editor export process).
|
|
|
|
|
|
|
|
:type: string
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `""`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: mainPack
|
|
|
|
|
|
|
|
An alternative name for the game pck to load. The executable name is used otherwise.
|
|
|
|
|
|
|
|
:type: string
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `null`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: locale
|
|
|
|
|
|
|
|
Specify a language code to select the proper localization for the game.
|
|
|
|
|
|
|
|
The browser locale will be used if none is specified. See complete list of
|
2023-01-12 19:29:11 +01:00
|
|
|
`supported locales <doc_locales>`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:type: string
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `null`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: canvasResizePolicy
|
|
|
|
|
|
|
|
The canvas resize policy determines how the canvas should be resized by Godot.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
`0` means Godot won't do any resizing. This is useful if you want to control the canvas size from
|
2022-03-18 17:46:08 +01:00
|
|
|
javascript code in your template.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
`1` means Godot will resize the canvas on start, and when changing window size via engine functions.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
`2` means Godot will adapt the canvas size to match the whole browser window.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:type: number
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `2`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:attribute:: args
|
|
|
|
|
|
|
|
The arguments to be passed as command line arguments on startup.
|
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
See `command line tutorial <doc_command_line_tutorial>`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
**Note**: :js:meth:`startGame <Engine.prototype.startGame>` will always add the `--main-pack` argument.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:type: Array.<string>
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
:value: `[]`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. js:function:: onExecute( path, args )
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
A callback function for handling Godot's `OS.execute` calls.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This is for example used in the Web Editor template to switch between project manager and editor, and for running the game.
|
|
|
|
|
|
|
|
:param string path:
|
|
|
|
The path that Godot's wants executed.
|
|
|
|
|
|
|
|
:param Array.<string> args:
|
|
|
|
The arguments of the "command" to execute.
|
|
|
|
|
|
|
|
.. js:function:: onExit( status_code )
|
|
|
|
|
|
|
|
A callback function for being notified when the Godot instance quits.
|
|
|
|
|
|
|
|
**Note**: This function will not be called if the engine crashes or become unresponsive.
|
|
|
|
|
|
|
|
:param number status_code:
|
|
|
|
The status code returned by Godot on exit.
|
|
|
|
|
|
|
|
.. js:function:: onProgress( current, total )
|
|
|
|
|
|
|
|
A callback function for displaying download progress.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The function is called once per frame while downloading files, so the usage of `requestAnimationFrame()`
|
2022-03-18 17:46:08 +01:00
|
|
|
is not necessary.
|
|
|
|
|
|
|
|
If the callback function receives a total amount of bytes as 0, this means that it is impossible to calculate.
|
|
|
|
Possible reasons include:
|
|
|
|
|
|
|
|
- Files are delivered with server-side chunked compression
|
|
|
|
- Files are delivered with server-side compression on Chromium
|
|
|
|
- Not all file downloads have started yet (usually on servers without multi-threading)
|
|
|
|
|
|
|
|
:param number current:
|
|
|
|
The current amount of downloaded bytes so far.
|
|
|
|
|
|
|
|
:param number total:
|
|
|
|
The total amount of bytes to be downloaded.
|
|
|
|
|
|
|
|
.. js:function:: onPrint( [ ...var_args ] )
|
|
|
|
|
|
|
|
A callback function for handling the standard output stream. This method should usually only be used in debug pages.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
By default, `console.log()` is used.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:param * var_args:
|
|
|
|
A variadic number of arguments to be printed.
|
|
|
|
|
|
|
|
.. js:function:: onPrintError( [ ...var_args ] )
|
|
|
|
|
|
|
|
A callback function for handling the standard error stream. This method should usually only be used in debug pages.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
By default, `console.error()` is used.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
:param * var_args:
|
|
|
|
A variadic number of arguments to be printed as errors.
|
|
|
|
|