Minor improvements

This commit is contained in:
2024-09-20 20:34:16 +02:00
parent 1a7546ba4f
commit 32cc613333
8 changed files with 98 additions and 99 deletions

View File

@ -35,12 +35,10 @@
</template>
<script setup lang="ts">
import config from '@/config'
import 'phaser'
import { watch, ref, onBeforeUnmount, onBeforeMount } from 'vue'
import { ref, onBeforeUnmount } from 'vue'
import { Game, Scene } from 'phavuer'
import { useGameStore } from '@/stores/game'
import { useZoneStore } from '@/stores/zone'
import { useZoneEditorStore } from '@/stores/zoneEditor'
import Hud from '@/components/gui/Hud.vue'
import Zone from '@/components/zone/Zone.vue'
@ -79,7 +77,7 @@ const createGame = (game: Phaser.Game) => {
})
}
const preloadScene = (scene: Phaser.Scene) => {
const preloadScene = async (scene: Phaser.Scene) => {
/**
* Create loading bar
*/
@ -102,13 +100,13 @@ const preloadScene = (scene: Phaser.Scene) => {
})
loadingText.setOrigin(0.5, 0.5)
scene.load.on('progress', function (value: any) {
scene.load.on(Phaser.Loader.Events.PROGRESS, function (value: any) {
progressBar.clear()
progressBar.fillStyle(0x368f8b, 1)
progressBar.fillRect(width / 2 - 180 + 10, height / 2 + 10, 300 * value, 30)
})
scene.load.on('complete', function () {
scene.load.on(Phaser.Loader.Events.COMPLETE, function() {
progressBar.destroy()
progressBox.destroy()
loadingText.destroy()
@ -116,10 +114,8 @@ const preloadScene = (scene: Phaser.Scene) => {
})
/**
* Load the assets into the Phaser scene
* Load the base assets into the Phaser scene
*/
loadAssets(scene)
scene.load.image('BLOCK', '/assets/zone/bt_tile.png')
scene.load.image('TELEPORT', '/assets/zone/tp_tile.png')
scene.load.image('blank_tile', '/assets/zone/blank_tile.png')
@ -129,14 +125,19 @@ const preloadScene = (scene: Phaser.Scene) => {
'character',
''
)
/**
* Load the assets into the Phaser scene
*/
await loadAssets(scene)
}
const createScene = (scene: Phaser.Scene) => {
const createScene = async (scene: Phaser.Scene) => {
/**
* Create sprite animations
* This is done here because phaser forces us to
*/
gameStore.assets.forEach((asset) => {
if (asset.group !== 'sprite_animations') return
scene.anims.create({
key: asset.key,
frameRate: 7,
@ -144,7 +145,7 @@ const createScene = (scene: Phaser.Scene) => {
frames: scene.anims.generateFrameNumbers(asset.key, { start: 0, end: 4 }),
repeat: -1
})
})
});
}
onBeforeUnmount(() => {