forked from noxious/client
105 lines
5.1 KiB
Vue
105 lines
5.1 KiB
Vue
<template>
|
|
<Notifications />
|
|
<div class="game-container">
|
|
<div class="top-ui">
|
|
<Hud />
|
|
</div>
|
|
|
|
<Game :config="gameConfig" class="game" @create="bootGame">
|
|
<Scene name="main" @preload="preloadScene" @create="bootScene">
|
|
<World />
|
|
</Scene>
|
|
</Game>
|
|
|
|
<div class="bottom-ui">
|
|
<Chat />
|
|
<Menubar />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import 'phaser';
|
|
import { Game, Scene } from 'phavuer'
|
|
import World from '@/components/World.vue'
|
|
import Pointer = Phaser.Input.Pointer
|
|
import { useSocketStore } from '@/stores/socket'
|
|
import Hud from '@/components/game/Hud.vue'
|
|
import Chat from '@/components/game/Chat.vue'
|
|
import Menubar from '@/components/game/Menu.vue'
|
|
import { onUnmounted } from 'vue'
|
|
|
|
const socket = useSocketStore();
|
|
|
|
onUnmounted(() => {
|
|
socket.disconnectSocket();
|
|
})
|
|
|
|
const gameConfig = {
|
|
name: 'New Quest',
|
|
width: window.innerWidth,
|
|
height: window.innerHeight,
|
|
type: Phaser.WEBGL,
|
|
pixelArt: true,
|
|
}
|
|
|
|
const bootGame = (game: Phaser.Game) => {
|
|
window.addEventListener('resize', () => {
|
|
game.scale.resize(window.innerWidth, window.innerHeight);
|
|
});
|
|
}
|
|
|
|
const preloadScene = (scene: Phaser.Scene) => {
|
|
/**
|
|
* @TODO
|
|
* Write logic that downloads all assets from out websocket or http server in base64 format
|
|
* Don't forget to check how intensive that operation is with sockets for performance
|
|
*/
|
|
scene.load.image('tiles', '/assets/tiles/default.png');
|
|
scene.load.image('waypoint', '/assets/waypoint.png');
|
|
scene.textures.addBase64('player', '')
|
|
}
|
|
|
|
const bootScene = (scene: Phaser.Scene) => {
|
|
// Camera drag system
|
|
let cam = scene.cameras.main;
|
|
scene.input.on("pointermove", function (pointer: Pointer) {
|
|
if (!pointer.isDown) return;
|
|
cam.scrollX -= (pointer.x - pointer.prevPosition.x) / cam.zoom;
|
|
cam.scrollY -= (pointer.y - pointer.prevPosition.y) / cam.zoom;
|
|
});
|
|
|
|
// const grid = scene.add.grid(0, 0, window.innerWidth, window.innerHeight, 64, 32, 0, 0, 0xff0000, 0.5).setOrigin(0, 0);
|
|
//
|
|
// window.addEventListener('resize', () => {
|
|
// grid.setSize(window.innerWidth, window.innerHeight);
|
|
// });
|
|
}
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.game-container {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
height: 100vh;
|
|
padding:30px;
|
|
position: relative;
|
|
}
|
|
.top-ui, .bottom-ui {
|
|
display: flex;
|
|
position: absolute;
|
|
left: 0;
|
|
right: 0;
|
|
margin: 0 2rem;
|
|
}
|
|
.top-ui {
|
|
top: 3rem;
|
|
}
|
|
.bottom-ui {
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
bottom: 6.25rem;
|
|
height: 6.25rem;
|
|
}
|
|
</style> |