added debug logic
This commit is contained in:
parent
29923b57df
commit
745e4be984
@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<Login />
|
||||
<Game />
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
|
@ -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>
|
||||
|
||||
|
@ -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 = [
|
||||
|
@ -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>
|
Loading…
x
Reference in New Issue
Block a user