From 745e4be9847f1e4dc8faa8f1ccd3afd9abd96695 Mon Sep 17 00:00:00 2001 From: root <root@xanax.lol> Date: Wed, 1 May 2024 20:11:31 +0200 Subject: [PATCH] added debug logic --- src/App.vue | 2 +- src/components/Game.vue | 9 ++++- src/components/World.vue | 4 ++ src/components/player/Player.vue | 69 ++++++++++++-------------------- 4 files changed, 38 insertions(+), 46 deletions(-) diff --git a/src/App.vue b/src/App.vue index 0dfe2f8..974f8ec 100644 --- a/src/App.vue +++ b/src/App.vue @@ -1,5 +1,5 @@ <template> - <Login /> + <Game /> </template> <script setup lang="ts"> diff --git a/src/components/Game.vue b/src/components/Game.vue index d0c530c..eaf4e7f 100644 --- a/src/components/Game.vue +++ b/src/components/Game.vue @@ -26,6 +26,11 @@ const gameConfig = { } const preload = (scene) => { + /** + * @TODO + * Write logic that downloads all assets from out websocket server in base64 format + * Don't forget to check how intensive that operation is for performance + */ scene.load.image('tiles', '/assets/tiles/default.png'); scene.textures.addBase64('player', '') } @@ -40,7 +45,9 @@ const create = (scene) => { }); // set camera to center - // cam.centerOn(0, 0); + cam.centerOn(0, 0); + + scene.add.grid(0, 0, 800, 600, 64, 32, 0, 0, 0xff00ff, 0.5).setOrigin(0, 0); } </script> diff --git a/src/components/World.vue b/src/components/World.vue index 20c31d9..faeb4fa 100644 --- a/src/components/World.vue +++ b/src/components/World.vue @@ -24,6 +24,10 @@ const map = new Phaser.Tilemaps.Tilemap(scene, mapData); const tileset = map.addTilesetImage('default', 'tiles'); const layer = map.createBlankLayer('layer', tileset, -config.tile_size.x + width / 2, height / 2 - (config.tile_size.x * tileSizeWidth * 0.25)); +const tilemapLayer = t => { + +} + const game = useGame(); const data = [ diff --git a/src/components/player/Player.vue b/src/components/player/Player.vue index f92d42a..62dbecd 100644 --- a/src/components/player/Player.vue +++ b/src/components/player/Player.vue @@ -1,5 +1,5 @@ <template> - <Sprite ref="player" texture="player" :x="playerX" :y="playerY" /> + <Sprite ref="sprite" texture="player" :x :y /> </template> <script setup> @@ -13,54 +13,35 @@ import config from '@/config.js' * so the map is 640x320 */ +// const props = defineProps({ +// x: Number, +// y: Number +// }) const scene = useScene() -const player = ref(); -const playerX = ref(0) -const playerY = ref(0) -// W,S,A,D -// Listen for keydown events -scene.input.keyboard.on('keydown', function (event) { - // Check which key was pressed - switch (event.code) { - case 'KeyW': // Move up and to the left - playerX.value -= config.tile_size.x / 2; - playerY.value -= config.tile_size.y / 2; - break; - case 'KeyS': // Move down and to the right - playerX.value += config.tile_size.x / 2; - playerY.value += config.tile_size.y / 2; - break; - case 'KeyA': // Move down and to the left - playerX.value -= config.tile_size.x / 2; - playerY.value += config.tile_size.y / 2; - break; - case 'KeyD': // Move up and to the right - playerX.value += config.tile_size.x / 2; - playerY.value -= config.tile_size.y / 2; - break; - } -}); +const x = ref(0); +const y = ref(0); + +const sprite = v => { + v.object.add.graphics({ lineStyle: { color: 0xffff00, width: 2, alpha: 0.5 } }); +} scene.input.on('pointerdown', function (pointer) { - // Convert pointer coordinates to tile coordinates - const tileX = Math.floor(pointer.x / config.tile_size.x); - const tileY = Math.floor(pointer.y / config.tile_size.y); - - // Convert tile coordinates to world coordinates (center of the tile) - const worldX = tileX * config.tile_size.x + config.tile_size.x / 2; - const worldY = tileY * config.tile_size.y + config.tile_size.y / 2; - - // Update the sprite's position - playerX.value = gridToScreen(tileX, tileY, config.tile_size).screenX; - playerY.value = gridToScreen(tileX, tileY, config.tile_size).screenY; + const { x: mapX, y: mapY } = getTileCoordinates(pointer.x, pointer.y); + x.value = mapX * config.tile_size.x; + y.value = mapY * config.tile_size.y; + sprite.value.x = x.value; + sprite.value.y = y.value; }); -function gridToScreen(x, y, tileSize) { - // Convert grid coordinates to isometric screen coordinates - const screenX = (x - y) * tileSize.x / 2; - const screenY = (x + y) * tileSize.y / 2; - - return { screenX, screenY }; +// a function that translates click coordinates to map tile coordinates +function getTileCoordinates(x, y) { + const tileWidth = config.tile_size.x; + const tileHeight = config.tile_size.y; + const mapWidth = 10; + const mapHeight = 10; + const mapX = Math.floor((x - tileWidth / 2) / tileWidth); + const mapY = Math.floor((y - tileHeight / 2) / tileHeight); + return { x: mapX, y: mapY }; } </script> \ No newline at end of file