@urso/core 0.8.20-dev → 0.9.0-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +20 -20
- package/README.md +227 -227
- package/build/js/index.js +77216 -2
- package/package.json +36 -50
- package/src/js/app.js +105 -104
- package/src/js/components/base/controller.js +76 -78
- package/src/js/components/debug/controller.js +39 -39
- package/src/js/components/debug/coords.js +23 -23
- package/src/js/components/debug/fps.js +36 -36
- package/src/js/components/debug/template.js +55 -55
- package/src/js/components/debug/timescale.js +60 -60
- package/src/js/components/deviceRotate/controller.js +95 -95
- package/src/js/components/editor/api.js +127 -127
- package/src/js/components/editor/controller.js +13 -13
- package/src/js/components/fullscreen/android.js +104 -104
- package/src/js/components/fullscreen/controller.js +76 -76
- package/src/js/components/fullscreen/desktop.js +49 -49
- package/src/js/components/fullscreen/ios.js +115 -115
- package/src/js/components/layersSwitcher/config.js +26 -26
- package/src/js/components/layersSwitcher/controller.js +36 -36
- package/src/js/components/loader/controller.js +66 -66
- package/src/js/components/loader/template.js +71 -71
- package/src/js/components/soundInitialPopup/controller.js +43 -43
- package/src/js/components/soundInitialPopup/template.js +110 -110
- package/src/js/components/stateDriven/controller.js +123 -123
- package/src/js/config/load.js +325 -194
- package/src/js/config/main.js +17 -17
- package/src/js/extra/browserEvents.js +57 -57
- package/src/js/extra/main.js +23 -25
- package/src/js/extra/pixiPatch.js +173 -171
- package/src/js/index.js +7 -7
- package/src/js/lib/cache.js +199 -125
- package/src/js/lib/composition.js +85 -85
- package/src/js/lib/device.js +1215 -1215
- package/src/js/lib/helper.js +678 -678
- package/src/js/lib/loader.js +216 -218
- package/src/js/lib/localData.js +29 -29
- package/src/js/lib/logger.js +69 -69
- package/src/js/lib/math.js +161 -161
- package/src/js/lib/objectPool.js +208 -208
- package/src/js/lib/time.js +19 -19
- package/src/js/lib/tween.js +153 -153
- package/src/js/modules/assets/baseModel.js +21 -21
- package/src/js/modules/assets/config.js +38 -38
- package/src/js/modules/assets/controller.js +65 -65
- package/src/js/modules/assets/models/atlas.js +19 -19
- package/src/js/modules/assets/models/audiosprite.js +28 -28
- package/src/js/modules/assets/models/bitmapFont.js +11 -11
- package/src/js/modules/assets/models/container.js +19 -19
- package/src/js/modules/assets/models/font.js +11 -11
- package/src/js/modules/assets/models/html.js +11 -11
- package/src/js/modules/assets/models/image.js +17 -17
- package/src/js/modules/assets/models/json.js +11 -11
- package/src/js/modules/assets/models/jsonAtlas.js +11 -11
- package/src/js/modules/assets/models/sound.js +17 -17
- package/src/js/modules/assets/models/spine.js +18 -17
- package/src/js/modules/assets/models/spineAtlas.js +11 -0
- package/src/js/modules/assets/service.js +564 -553
- package/src/js/modules/i18n/config.js +17 -17
- package/src/js/modules/i18n/controller.js +71 -71
- package/src/js/modules/instances/controller.js +357 -357
- package/src/js/modules/logic/config/sounds.js +23 -23
- package/src/js/modules/logic/controller.js +52 -52
- package/src/js/modules/logic/main.js +8 -8
- package/src/js/modules/logic/sounds.js +103 -103
- package/src/js/modules/objects/baseModel.js +205 -207
- package/src/js/modules/objects/cache.js +99 -99
- package/src/js/modules/objects/config.js +10 -10
- package/src/js/modules/objects/controller.js +139 -139
- package/src/js/modules/objects/find.js +58 -58
- package/src/js/modules/objects/models/bitmapText.js +56 -49
- package/src/js/modules/objects/models/button.js +208 -209
- package/src/js/modules/objects/models/buttonComposite.js +38 -38
- package/src/js/modules/objects/models/checkbox.js +100 -100
- package/src/js/modules/objects/models/collection.js +56 -54
- package/src/js/modules/objects/models/component.js +48 -48
- package/src/js/modules/objects/models/container.js +22 -22
- package/src/js/modules/objects/models/emitterFx.js +103 -114
- package/src/js/modules/objects/models/graphics.js +40 -40
- package/src/js/modules/objects/models/group.js +22 -22
- package/src/js/modules/objects/models/hitArea.js +187 -187
- package/src/js/modules/objects/models/image.js +36 -36
- package/src/js/modules/objects/models/imagesAnimation.js +115 -115
- package/src/js/modules/objects/models/mask.js +40 -40
- package/src/js/modules/objects/models/nineSlicePlane.js +32 -32
- package/src/js/modules/objects/models/slider.js +357 -357
- package/src/js/modules/objects/models/spine.js +354 -339
- package/src/js/modules/objects/models/text.js +70 -70
- package/src/js/modules/objects/models/toggle.js +186 -186
- package/src/js/modules/objects/models/world.js +22 -22
- package/src/js/modules/objects/pool.js +68 -68
- package/src/js/modules/objects/propertyAdapter.js +592 -592
- package/src/js/modules/objects/proxy.js +299 -298
- package/src/js/modules/objects/selector.js +136 -136
- package/src/js/modules/objects/service.js +255 -254
- package/src/js/modules/objects/styles.js +210 -210
- package/src/js/modules/observer/controller.js +168 -168
- package/src/js/modules/observer/events.js +51 -56
- package/src/js/modules/scenes/controller.js +126 -127
- package/src/js/modules/scenes/model.js +28 -28
- package/src/js/modules/scenes/pixiWrapper.js +359 -351
- package/src/js/modules/scenes/resolutions.js +173 -173
- package/src/js/modules/scenes/resolutionsConfig.js +73 -73
- package/src/js/modules/scenes/service.js +144 -146
- package/src/js/modules/soundManager/controller.js +103 -103
- package/src/js/modules/soundManager/soundSprite.js +314 -314
- package/src/js/modules/statesManager/action.js +97 -97
- package/src/js/modules/statesManager/all.js +23 -23
- package/src/js/modules/statesManager/configStates.js +77 -77
- package/src/js/modules/statesManager/controller.js +219 -219
- package/src/js/modules/statesManager/functionsStorage.js +83 -83
- package/src/js/modules/statesManager/helper.js +27 -27
- package/src/js/modules/statesManager/race.js +91 -91
- package/src/js/modules/statesManager/sequence.js +48 -48
- package/src/js/modules/template/controller.js +28 -28
- package/src/js/modules/template/model.js +11 -11
- package/src/js/modules/template/service.js +137 -137
- package/src/js/modules/template/types.js +50 -49
- package/src/js/modules/transport/baseConnectionType.js +25 -25
- package/src/js/modules/transport/config.js +13 -13
- package/src/js/modules/transport/connectionTypes/websocket.js +77 -77
- package/src/js/modules/transport/connectionTypes/xhr.js +47 -47
- package/src/js/modules/transport/controller.js +48 -48
- package/src/js/modules/transport/decorator.js +17 -17
- package/src/js/modules/transport/service.js +150 -150
- package/vite.config.js +31 -0
- package/.babelrc +0 -12
- package/build/js/index.js.LICENSE.txt +0 -227
- package/src/js/modules/objects/models/atlasImage.js +0 -52
- package/src/js/modules/objects/models/dragContainer.js +0 -665
- package/src/js/modules/objects/models/emitter.js +0 -69
- package/src/js/modules/objects/models/scrollbox.js +0 -67
- package/src/js/modules/objects/models/textInput.js +0 -68
- package/webpack.config.js +0 -47
package/package.json
CHANGED
|
@@ -1,50 +1,36 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@urso/core",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "HTML5 game engine",
|
|
5
|
-
"main": "build/js/index.js",
|
|
6
|
-
"author": "Megbrimef",
|
|
7
|
-
"license": "MIT",
|
|
8
|
-
"
|
|
9
|
-
|
|
10
|
-
"
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"pixi
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
"
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
"@babel/preset-env": "^7.12.11",
|
|
38
|
-
"babel-loader": "^8.2.2",
|
|
39
|
-
"copy-webpack-plugin": "^5.0.3",
|
|
40
|
-
"exports-loader": "^0.7.0",
|
|
41
|
-
"html-webpack-plugin": "^5.1.0",
|
|
42
|
-
"script-loader": "^0.7.2",
|
|
43
|
-
"source-map-loader": "^1.0.0",
|
|
44
|
-
"string-replace-loader": "^3.0.3",
|
|
45
|
-
"style-loader": "^0.23.1",
|
|
46
|
-
"webpack": "^5.93.0",
|
|
47
|
-
"webpack-cli": "^5.1.4",
|
|
48
|
-
"webpack-dev-server": "^5.0.4"
|
|
49
|
-
}
|
|
50
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@urso/core",
|
|
3
|
+
"version": "0.9.0-dev",
|
|
4
|
+
"description": "HTML5 game engine",
|
|
5
|
+
"main": "build/js/index.js",
|
|
6
|
+
"author": "Megbrimef",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"scripts": {
|
|
10
|
+
"dev": "vite",
|
|
11
|
+
"build:prod": "vite build",
|
|
12
|
+
"serve": "vite preview"
|
|
13
|
+
},
|
|
14
|
+
"repository": {
|
|
15
|
+
"type": "git",
|
|
16
|
+
"url": "git+https://github.com/megbrimef/urso.git"
|
|
17
|
+
},
|
|
18
|
+
"keywords": [
|
|
19
|
+
"game",
|
|
20
|
+
"engine"
|
|
21
|
+
],
|
|
22
|
+
"bugs": {
|
|
23
|
+
"url": "https://github.com/megbrimef/urso/issues"
|
|
24
|
+
},
|
|
25
|
+
"homepage": "https://github.com/megbrimef/urso#readme",
|
|
26
|
+
"dependencies": {
|
|
27
|
+
"@esotericsoftware/spine-pixi-v8": "^4.2.80",
|
|
28
|
+
"gsap": "^3.12.0",
|
|
29
|
+
"howler": "^2.2.4",
|
|
30
|
+
"pixi.js": "^8.9.1"
|
|
31
|
+
},
|
|
32
|
+
"devDependencies": {
|
|
33
|
+
"@vitejs/plugin-legacy": "^6.1.1",
|
|
34
|
+
"vite": "^6.3.5"
|
|
35
|
+
}
|
|
36
|
+
}
|
package/src/js/app.js
CHANGED
|
@@ -1,104 +1,105 @@
|
|
|
1
|
-
class App {
|
|
2
|
-
|
|
3
|
-
constructor() {
|
|
4
|
-
this.version = 'APP_VERSION';
|
|
5
|
-
|
|
6
|
-
this.setup = this.setup.bind(this);
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* global init
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
this.sayHello();
|
|
14
|
-
|
|
15
|
-
//helper must be first
|
|
16
|
-
Urso.helper = new Urso.Core.Lib.Helper(); //helper functions
|
|
17
|
-
|
|
18
|
-
//setup Instances
|
|
19
|
-
let instances = new Urso.Core.Modules.Instances.Controller();
|
|
20
|
-
Urso.getInstance = instances.getInstance;
|
|
21
|
-
Urso.getByPath = instances.getByPath;
|
|
22
|
-
Urso.getInstancesModes = instances.getModes;
|
|
23
|
-
Urso.addInstancesMode = instances.addMode;
|
|
24
|
-
Urso.removeInstancesMode = instances.removeMode;
|
|
25
|
-
|
|
26
|
-
//build from extendingChain and merge all into Urso.Game
|
|
27
|
-
Urso.Game = {};
|
|
28
|
-
for (let extention of Urso.config.extendingChain)
|
|
29
|
-
Urso.helper.mergeObjectsRecursive(Urso.Game, Urso.helper.recursiveGet(extention, window, {}), true);
|
|
30
|
-
|
|
31
|
-
//(!)important we must use only Urso.Game from our code
|
|
32
|
-
|
|
33
|
-
//observer pattern
|
|
34
|
-
Urso.observer = Urso.getInstance('Modules.Observer.Controller');
|
|
35
|
-
|
|
36
|
-
//Extra
|
|
37
|
-
Urso.browserEvents = Urso.getInstance('Extra.BrowserEvents');
|
|
38
|
-
this._addTimeouts();
|
|
39
|
-
|
|
40
|
-
//libs
|
|
41
|
-
Urso.cache = Urso.getInstance('Lib.Cache'); //all assets cache
|
|
42
|
-
Urso.device = Urso.getByPath('Lib.Device'); //all device info
|
|
43
|
-
Urso.loader = Urso.getInstance('Lib.Loader'); //assets loader class
|
|
44
|
-
Urso.localData = Urso.getInstance('Lib.LocalData'); //local data storage
|
|
45
|
-
Urso.logger = Urso.getInstance('Lib.Logger'); //logger
|
|
46
|
-
Urso.math = Urso.getInstance('Lib.Math'); //math functions
|
|
47
|
-
Urso.time = Urso.getInstance('Lib.Time'); //time functions
|
|
48
|
-
Urso.tween = Urso.getInstance('Lib.Tween'); //tween lib
|
|
49
|
-
|
|
50
|
-
//Modules
|
|
51
|
-
Urso.assets = Urso.getInstance('Modules.Assets.Controller');
|
|
52
|
-
Urso.i18n = Urso.getInstance('Modules.I18n.Controller');
|
|
53
|
-
Urso.transport = Urso.getInstance('Modules.Transport.Controller');
|
|
54
|
-
Urso.logic = Urso.getInstance('Modules.Logic.Controller');
|
|
55
|
-
Urso.objects = Urso.getInstance('Modules.Objects.Controller');
|
|
56
|
-
Urso.scenes = Urso.getInstance('Modules.Scenes.Controller');
|
|
57
|
-
|
|
58
|
-
Urso.
|
|
59
|
-
Urso.
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
Urso.assets.
|
|
71
|
-
Urso.
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
Urso.
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
|
|
1
|
+
class App {
|
|
2
|
+
|
|
3
|
+
constructor() {
|
|
4
|
+
this.version = 'APP_VERSION';
|
|
5
|
+
|
|
6
|
+
this.setup = this.setup.bind(this);
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* global init
|
|
11
|
+
*/
|
|
12
|
+
async setup() {
|
|
13
|
+
this.sayHello();
|
|
14
|
+
|
|
15
|
+
//helper must be first
|
|
16
|
+
Urso.helper = new Urso.Core.Lib.Helper(); //helper functions
|
|
17
|
+
|
|
18
|
+
//setup Instances
|
|
19
|
+
let instances = new Urso.Core.Modules.Instances.Controller();
|
|
20
|
+
Urso.getInstance = instances.getInstance;
|
|
21
|
+
Urso.getByPath = instances.getByPath;
|
|
22
|
+
Urso.getInstancesModes = instances.getModes;
|
|
23
|
+
Urso.addInstancesMode = instances.addMode;
|
|
24
|
+
Urso.removeInstancesMode = instances.removeMode;
|
|
25
|
+
|
|
26
|
+
//build from extendingChain and merge all into Urso.Game
|
|
27
|
+
Urso.Game = {};
|
|
28
|
+
for (let extention of Urso.config.extendingChain)
|
|
29
|
+
Urso.helper.mergeObjectsRecursive(Urso.Game, Urso.helper.recursiveGet(extention, window, {}), true);
|
|
30
|
+
|
|
31
|
+
//(!)important we must use only Urso.Game from our code
|
|
32
|
+
|
|
33
|
+
//observer pattern
|
|
34
|
+
Urso.observer = Urso.getInstance('Modules.Observer.Controller');
|
|
35
|
+
|
|
36
|
+
//Extra
|
|
37
|
+
Urso.browserEvents = Urso.getInstance('Extra.BrowserEvents');
|
|
38
|
+
this._addTimeouts();
|
|
39
|
+
|
|
40
|
+
//libs
|
|
41
|
+
Urso.cache = Urso.getInstance('Lib.Cache'); //all assets cache
|
|
42
|
+
Urso.device = Urso.getByPath('Lib.Device'); //all device info
|
|
43
|
+
Urso.loader = Urso.getInstance('Lib.Loader'); //assets loader class
|
|
44
|
+
Urso.localData = Urso.getInstance('Lib.LocalData'); //local data storage
|
|
45
|
+
Urso.logger = Urso.getInstance('Lib.Logger'); //logger
|
|
46
|
+
Urso.math = Urso.getInstance('Lib.Math'); //math functions
|
|
47
|
+
Urso.time = Urso.getInstance('Lib.Time'); //time functions
|
|
48
|
+
Urso.tween = Urso.getInstance('Lib.Tween'); //tween lib
|
|
49
|
+
|
|
50
|
+
//Modules
|
|
51
|
+
Urso.assets = Urso.getInstance('Modules.Assets.Controller');
|
|
52
|
+
Urso.i18n = Urso.getInstance('Modules.I18n.Controller');
|
|
53
|
+
Urso.transport = Urso.getInstance('Modules.Transport.Controller');
|
|
54
|
+
Urso.logic = Urso.getInstance('Modules.Logic.Controller');
|
|
55
|
+
Urso.objects = Urso.getInstance('Modules.Objects.Controller');
|
|
56
|
+
Urso.scenes = Urso.getInstance('Modules.Scenes.Controller');
|
|
57
|
+
await Urso.scenes.init();
|
|
58
|
+
Urso.soundManager = Urso.getInstance('Modules.SoundManager.Controller');
|
|
59
|
+
Urso.statesManager = Urso.getInstance('Modules.StatesManager.Controller');
|
|
60
|
+
Urso.template = Urso.getInstance('Modules.Template.Controller');
|
|
61
|
+
|
|
62
|
+
//set title
|
|
63
|
+
document.title = Urso.config.title;
|
|
64
|
+
|
|
65
|
+
//device type mode
|
|
66
|
+
Urso.addInstancesMode(!Urso.helper.mobileAndTabletCheck() ? 'desktop' : 'mobile');
|
|
67
|
+
|
|
68
|
+
//App.run
|
|
69
|
+
Urso.device.whenReady(() => {
|
|
70
|
+
Urso.assets.updateQuality();
|
|
71
|
+
Urso.assets.checkWebPSupport();
|
|
72
|
+
Urso.getInstance('App').run();
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* log engine name and its version
|
|
78
|
+
*/
|
|
79
|
+
sayHello() {
|
|
80
|
+
console.log(`%c ${String.fromCodePoint(0x1F43B)} Urso ${this.version} `, 'background: #222; color: #bada55');
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* run default scene
|
|
85
|
+
*/
|
|
86
|
+
run() {
|
|
87
|
+
Urso.logic.do('run');
|
|
88
|
+
Urso.scenes.display(Urso.config.defaultScene);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* add Urso.setTimeout && Urso.clearTimeout functions. It will helps to manage time
|
|
93
|
+
*/
|
|
94
|
+
_addTimeouts() {
|
|
95
|
+
Urso.setTimeout = (callback, delay) => {
|
|
96
|
+
return gsap.delayedCall(delay / 1000, callback);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
Urso.clearTimeout = (tween) => {
|
|
100
|
+
tween.kill();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
export default App;
|
|
@@ -1,78 +1,76 @@
|
|
|
1
|
-
class ComponentsBaseController {
|
|
2
|
-
|
|
3
|
-
constructor(options) {
|
|
4
|
-
this._templateName = 'Template';
|
|
5
|
-
this._inputValidation(options);
|
|
6
|
-
|
|
7
|
-
this.common = {
|
|
8
|
-
find: null, //find functions inside component object in scene
|
|
9
|
-
findAll: null,
|
|
10
|
-
findOne: null,
|
|
11
|
-
object: null //link to component object in scene
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
this.options = options;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* function for the component input params validation
|
|
19
|
-
* must return as a result input structure
|
|
20
|
-
* @returns {object}
|
|
21
|
-
* @example
|
|
22
|
-
* return {
|
|
23
|
-
* param1Name: 'number',
|
|
24
|
-
* param2Name: 'string'
|
|
25
|
-
* }
|
|
26
|
-
*/
|
|
27
|
-
_requiredOptionsModel() {
|
|
28
|
-
//
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
_inputValidation(options) {
|
|
32
|
-
//input options validation
|
|
33
|
-
let optionsModel = this._requiredOptionsModel();
|
|
34
|
-
|
|
35
|
-
if (optionsModel)
|
|
36
|
-
for (let optionKey in optionsModel) {
|
|
37
|
-
if (!options || typeof options[optionKey] !== optionsModel[optionKey])
|
|
38
|
-
Urso.logger.error('Component params model error', this);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
loadUpdate() {
|
|
43
|
-
//todo
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
assetsMount() {
|
|
47
|
-
let template = this.getInstance(this._templateName, this.options);
|
|
48
|
-
return { styles: template.styles, assets: template.assets };
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
objectsMount() {
|
|
52
|
-
let template = this.getInstance(this._templateName, this.options);
|
|
53
|
-
return template.objects;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
create() {
|
|
57
|
-
//main template was created, we can start access to our objects
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* @param {Number} deltaTime - time from last update call
|
|
62
|
-
*/
|
|
63
|
-
update(deltaTime) {
|
|
64
|
-
//TODO
|
|
65
|
-
//calls every browser cycle
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
_subscribeOnce() {
|
|
69
|
-
//will contains only this.addListener
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
destroy() {
|
|
73
|
-
//component will destroy after this function call
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
module.exports = ComponentsBaseController;
|
|
1
|
+
export default class ComponentsBaseController {
|
|
2
|
+
|
|
3
|
+
constructor(options) {
|
|
4
|
+
this._templateName = 'Template';
|
|
5
|
+
this._inputValidation(options);
|
|
6
|
+
|
|
7
|
+
this.common = {
|
|
8
|
+
find: null, //find functions inside component object in scene
|
|
9
|
+
findAll: null,
|
|
10
|
+
findOne: null,
|
|
11
|
+
object: null //link to component object in scene
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
this.options = options;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* function for the component input params validation
|
|
19
|
+
* must return as a result input structure
|
|
20
|
+
* @returns {object}
|
|
21
|
+
* @example
|
|
22
|
+
* return {
|
|
23
|
+
* param1Name: 'number',
|
|
24
|
+
* param2Name: 'string'
|
|
25
|
+
* }
|
|
26
|
+
*/
|
|
27
|
+
_requiredOptionsModel() {
|
|
28
|
+
//
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
_inputValidation(options) {
|
|
32
|
+
//input options validation
|
|
33
|
+
let optionsModel = this._requiredOptionsModel();
|
|
34
|
+
|
|
35
|
+
if (optionsModel)
|
|
36
|
+
for (let optionKey in optionsModel) {
|
|
37
|
+
if (!options || typeof options[optionKey] !== optionsModel[optionKey])
|
|
38
|
+
Urso.logger.error('Component params model error', this);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
loadUpdate() {
|
|
43
|
+
//todo
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
assetsMount() {
|
|
47
|
+
let template = this.getInstance(this._templateName, this.options);
|
|
48
|
+
return { styles: template.styles, assets: template.assets };
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
objectsMount() {
|
|
52
|
+
let template = this.getInstance(this._templateName, this.options);
|
|
53
|
+
return template.objects;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
create() {
|
|
57
|
+
//main template was created, we can start access to our objects
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* @param {Number} deltaTime - time from last update call
|
|
62
|
+
*/
|
|
63
|
+
update(deltaTime) {
|
|
64
|
+
//TODO
|
|
65
|
+
//calls every browser cycle
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
_subscribeOnce() {
|
|
69
|
+
//will contains only this.addListener
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
destroy() {
|
|
73
|
+
//component will destroy after this function call
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
}
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
class ComponentsDebugController extends ComponentsBaseController {
|
|
4
|
-
constructor(params) {
|
|
5
|
-
super(params);
|
|
6
|
-
|
|
7
|
-
this._logicBlocks = [
|
|
8
|
-
'coords', 'fps', 'timescale' /*'renderStats', 'resolution'*/ //TODO
|
|
9
|
-
];
|
|
10
|
-
|
|
11
|
-
this._visible = true;
|
|
12
|
-
this._comObject = false;
|
|
13
|
-
this._created;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
create() {
|
|
17
|
-
this._created = true;
|
|
18
|
-
|
|
19
|
-
this._comObject = this.common.findOne('^debugContainer');
|
|
20
|
-
this._show(true);
|
|
21
|
-
|
|
22
|
-
Urso.helper.logicBlocksDo(this, 'create');
|
|
23
|
-
return true;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
update() {
|
|
27
|
-
if (!this._created)
|
|
28
|
-
return;
|
|
29
|
-
|
|
30
|
-
Urso.helper.logicBlocksDo(this, 'update');
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
_show(visMode) {
|
|
34
|
-
this._visible = (typeof visMode !== 'undefined') ? visMode : !this._visible;
|
|
35
|
-
this._comObject.visible = this._visible;
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
|
|
1
|
+
import ComponentsBaseController from './../base/controller';
|
|
2
|
+
|
|
3
|
+
class ComponentsDebugController extends ComponentsBaseController {
|
|
4
|
+
constructor(params) {
|
|
5
|
+
super(params);
|
|
6
|
+
|
|
7
|
+
this._logicBlocks = [
|
|
8
|
+
'coords', 'fps', 'timescale' /*'renderStats', 'resolution'*/ //TODO
|
|
9
|
+
];
|
|
10
|
+
|
|
11
|
+
this._visible = true;
|
|
12
|
+
this._comObject = false;
|
|
13
|
+
this._created;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
create() {
|
|
17
|
+
this._created = true;
|
|
18
|
+
|
|
19
|
+
this._comObject = this.common.findOne('^debugContainer');
|
|
20
|
+
this._show(true);
|
|
21
|
+
|
|
22
|
+
Urso.helper.logicBlocksDo(this, 'create');
|
|
23
|
+
return true;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
update() {
|
|
27
|
+
if (!this._created)
|
|
28
|
+
return;
|
|
29
|
+
|
|
30
|
+
Urso.helper.logicBlocksDo(this, 'update');
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
_show(visMode) {
|
|
34
|
+
this._visible = (typeof visMode !== 'undefined') ? visMode : !this._visible;
|
|
35
|
+
this._comObject.visible = this._visible;
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export default ComponentsDebugController;
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
class ComponentsDebugCoords {
|
|
2
|
-
|
|
3
|
-
constructor() {
|
|
4
|
-
this._coordsText;
|
|
5
|
-
|
|
6
|
-
this.create = this.create.bind(this);
|
|
7
|
-
this.update = this.update.bind(this);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
create() {
|
|
11
|
-
this._coordsText = this.common.findOne('^debugCoords')
|
|
12
|
-
this.update();
|
|
13
|
-
return true;
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
update() {
|
|
17
|
-
let coords = Urso.scenes.getMouseCoords();
|
|
18
|
-
this._coordsText.text = 'x:' + Math.floor(coords.x) + '; y:' + Math.floor(coords.y);
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
|
|
1
|
+
class ComponentsDebugCoords {
|
|
2
|
+
|
|
3
|
+
constructor() {
|
|
4
|
+
this._coordsText;
|
|
5
|
+
|
|
6
|
+
this.create = this.create.bind(this);
|
|
7
|
+
this.update = this.update.bind(this);
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
create() {
|
|
11
|
+
this._coordsText = this.common.findOne('^debugCoords')
|
|
12
|
+
this.update();
|
|
13
|
+
return true;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
update() {
|
|
17
|
+
let coords = Urso.scenes.getMouseCoords();
|
|
18
|
+
this._coordsText.text = 'x:' + Math.floor(coords.x) + '; y:' + Math.floor(coords.y);
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export default ComponentsDebugCoords;
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
class ComponentsDebugFps {
|
|
2
|
-
|
|
3
|
-
constructor() {
|
|
4
|
-
this._coordsText;
|
|
5
|
-
|
|
6
|
-
this.create = this.create.bind(this);
|
|
7
|
-
this.update = this.update.bind(this);
|
|
8
|
-
|
|
9
|
-
this.lastUpdateTime = 0;
|
|
10
|
-
this.frames = 0;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
create() {
|
|
14
|
-
this._coordsText = this.common.findOne('^debugFps')
|
|
15
|
-
this.update();
|
|
16
|
-
return true;
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
update() {
|
|
20
|
-
const currentTime = Urso.time.get();
|
|
21
|
-
this.frames++;
|
|
22
|
-
|
|
23
|
-
if (currentTime - this.lastUpdateTime < 1000)
|
|
24
|
-
return;
|
|
25
|
-
|
|
26
|
-
const fps = Math.round(1000 * this.frames / (currentTime - this.lastUpdateTime));
|
|
27
|
-
this.lastUpdateTime = currentTime;
|
|
28
|
-
this.frames = 0;
|
|
29
|
-
|
|
30
|
-
const fpsData = Urso.scenes.getFpsData();
|
|
31
|
-
this._coordsText.text = `fps: ${fps}, sceneFps: ${fpsData.fps}, limit: ${fpsData.limit}`;
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
1
|
+
class ComponentsDebugFps {
|
|
2
|
+
|
|
3
|
+
constructor() {
|
|
4
|
+
this._coordsText;
|
|
5
|
+
|
|
6
|
+
this.create = this.create.bind(this);
|
|
7
|
+
this.update = this.update.bind(this);
|
|
8
|
+
|
|
9
|
+
this.lastUpdateTime = 0;
|
|
10
|
+
this.frames = 0;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
create() {
|
|
14
|
+
this._coordsText = this.common.findOne('^debugFps')
|
|
15
|
+
this.update();
|
|
16
|
+
return true;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
update() {
|
|
20
|
+
const currentTime = Urso.time.get();
|
|
21
|
+
this.frames++;
|
|
22
|
+
|
|
23
|
+
if (currentTime - this.lastUpdateTime < 1000)
|
|
24
|
+
return;
|
|
25
|
+
|
|
26
|
+
const fps = Math.round(1000 * this.frames / (currentTime - this.lastUpdateTime));
|
|
27
|
+
this.lastUpdateTime = currentTime;
|
|
28
|
+
this.frames = 0;
|
|
29
|
+
|
|
30
|
+
const fpsData = Urso.scenes.getFpsData();
|
|
31
|
+
this._coordsText.text = `fps: ${fps}, sceneFps: ${fpsData.fps}, limit: ${fpsData.limit}`;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export default ComponentsDebugFps;
|