App
Description:
A record representing an application singleton instance.
frame
Type: Readonly Field.
Description:
The current passed frame number.
Signature:
const frame: integer
bufferSize
Type: Readonly Field.
Description:
The size of the main frame buffer texture used for rendering.
Signature:
const bufferSize: Size
visualSize
Type: Readonly Field.
Description:
The logic visual size of the screen. The visual size only changes when application window size changes. And it won't be affacted by the view buffer scaling factor.
Signature:
const visualSize: Size
devicePixelRatio
Type: Readonly Field.
Description:
The ratio of the pixel density displayed by the device Can be calculated as the size of the rendering buffer divided by the size of the application window.
Signature:
const devicePixelRatio: number
App.Platform
Type: Enumeration.
Description:
An enumerated type representing the platform the game engine is running on.
Signature:
enum Platform
"Windows"
"Android"
"macOS"
"iOS"
"Linux"
"Unknown"
end
platform
Type: Readonly Field.
Description:
The platform the game engine is running on.
Signature:
const platform: Platform
version
Type: Readonly Field.
Description:
The version string of the game engine. Should be in format of "v0.0.0.0".
Signature:
const version: string
deps
Type: Readonly Field.
Description:
The dependencies of the game engine.
Signature:
const deps: string
deltaTime
Type: Readonly Field.
Description:
The time in seconds since the last frame update.
Signature:
const deltaTime: number
elapsedTime
Type: Readonly Field.
Description:
The elapsed time since current frame was started, in seconds.
Signature:
const elapsedTime: number
totalTime
Type: Readonly Field.
Description:
The total time the game engine has been running until last frame ended, in seconds. Should be a contant number when invoked in a same frame for multiple times.
Signature:
const totalTime: number
runningTime
Type: Readonly Field.
Description:
The total time the game engine has been running until this field being accessed, in seconds. Should be a increasing number when invoked in a same frame for multiple times.
Signature:
const runningTime: number
rand
Type: Readonly Field.
Description:
A random number generated by a random number engine based on Mersenne Twister algorithm. So that the random number generated by a same seed should be consistent on every platform.
Signature:
const rand: integer
maxFPS
Type: Readonly Field.
Description:
The maximum valid frames per second the game engine is allowed to run at. The max FPS is being inferred by the device screen max refresh rate.
Signature:
const maxFPS: integer
debugging
Type: Readonly Field.
Description:
Whether the game engine is running in debug mode.
Signature:
const debugging: boolean
testNames
Type: Readonly Field.
Description:
An array of test names of engine included C++ tests.
Signature:
const testNames: {string}
locale
Type: Field.
Description:
The system locale string, in format like: zh-Hans
, en
.
Signature:
locale: string
themeColor
Type: Field.
Description:
A theme color for Dora SSR.
Signature:
themeColor: Color
seed
Type: Field.
Description:
A random number seed.
Signature:
seed: integer
targetFPS
Type: Field.
Description:
The target frames per second the game engine is supposed to run at.
Only works when fpsLimited
is set to true.
Signature:
targetFPS: integer
fpsLimited
Type: Field.
Description:
Whether the game engine is limiting the frames per second.
Set fpsLimited
to true, will make engine run in a busy loop to track the precise frame time to switch to the next frame. And this behavior can lead to 100% CPU usage. This is usually common practice on Windows PCs for better CPU usage occupation. But it also results in extra heat and power consumption.
Signature:
fpsLimited: boolean
idled
Type: Field.
Description:
Whether the game engine is currently idled.
Set idled
to true, will make game logic thread use a sleep time and going idled for next frame to come. Due to the imprecision in sleep time. This idled state may cause game engine over slept for a few frames to lost.
idled
state can reduce some CPU usage.
Signature:
idled: boolean
fullScreen
Type: Field.
Description:
Whether the game engine is running in full screen mode. It is not available to set this property on platform Android and iOS.
Signature:
fullScreen: boolean
alwaysOnTop
Type: Field.
Description:
Whether the game engine window is always on top. It is not available to set this property on platform Android and iOS.
Signature:
alwaysOnTop: boolean
winSize
Type: Field.
Description:
The application window size. May differ from visual size due to the different DPIs of display devices. It is not available to set this property on platform Android and iOS.
Signature:
winSize: Size
winPosition
Type: Field.
Description:
The application window position. It is not available to set this property on platform Android and iOS.
Signature:
winPosition: Vec2
runTest
Type: Function.
Description:
A function that runs an specific C++ test included in the engine.
Signature:
runTest: function(self: App, name: string): boolean
Parameters:
Parameter | Type | Description |
---|---|---|
name | string | The name of the test to run. |
Returns:
Return Type | Description |
---|---|
boolean | Whether the test ran successfully. |
openURL
Type: Function.
Description:
A function that opens a URL in the system default browser.
Signature:
openURL: function(self: App, url: string)
Parameters:
Parameter | Type | Description |
---|---|---|
url | string | The URL to open. |
install
Type: Function.
Description:
A function used for self updating the game engine.
Signature:
install: function(self: App, path: string)
Parameters:
Parameter | Type | Description |
---|---|---|
path | string | The path to the new engine file. |
saveLog
Type: Function.
Description:
A function used for save all the log to a file.
Signature:
saveLog: function(self: App, path: string): boolean
Parameters:
Parameter | Type | Description |
---|---|---|
path | string | The path to save the log file. |
Returns:
Return Type | Description |
---|---|
boolean | Whether the log file was saved successfully. |
openFileDialog
Type: Function.
Description:
A function that opens a file dialog. Only works on Windows, macOS and Linux.
Signature:
openFileDialog: function(self: App, folderOnly: boolean, callback: function(path: string))
Parameters:
Parameter | Type | Description |
---|---|---|
folderOnly | boolean | Whether the file dialog is only for selecting folders. |
callback | function | The callback function to be called when the file dialog is closed. The callback function should accept a string parameter which is the path of the selected file or folder. Get empty string if the user canceled the dialog. |
shutdown
Type: Function.
Description:
A function that shuts down the game engine. It is not working and acts as a dummy function for platform Android and iOS to follow the specification of how mobile platform applications should operate.
Signature:
shutdown: function(self: App)