player component work

This commit is contained in:
root 2024-04-27 23:45:06 +02:00
parent 8234981968
commit 518da6be8d
4 changed files with 24 additions and 14 deletions

6
package-lock.json generated
View File

@ -2488,9 +2488,9 @@
} }
}, },
"node_modules/caniuse-lite": { "node_modules/caniuse-lite": {
"version": "1.0.30001612", "version": "1.0.30001613",
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001612.tgz", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001613.tgz",
"integrity": "sha512-lFgnZ07UhaCcsSZgWW0K5j4e69dK1u/ltrL9lTUiFOwNHs12S3UMIEYgBV0Z6C6hRDev7iRnMzzYmKabYdXF9g==", "integrity": "sha512-BNjJULJfOONQERivfxte7alLfeLW4QnwHvNW4wEcLEbXfV6VSCYvr+REbf2Sojv8tC1THpjPXBxWgDbq4NtLWg==",
"dev": true, "dev": true,
"funding": [ "funding": [
{ {

View File

@ -1,5 +1,5 @@
<template> <template>
<Login /> <Game />
</template> </template>
<script setup lang="ts"> <script setup lang="ts">

View File

@ -10,7 +10,7 @@
<script setup lang="ts"> <script setup lang="ts">
import 'phaser'; import 'phaser';
import { Game, Scene, useGame } from 'phavuer' import { Game, Scene } from 'phavuer'
import World from '@/components/World.vue' import World from '@/components/World.vue'
const gameConfig = { const gameConfig = {
@ -20,6 +20,7 @@ const gameConfig = {
autoCenter: Phaser.Scale.CENTER_BOTH, autoCenter: Phaser.Scale.CENTER_BOTH,
}, },
type: Phaser.CANVAS, type: Phaser.CANVAS,
physics: { default: 'arcade' },
pixelArt: true, pixelArt: true,
width: 1200, width: 1200,
height: 800, height: 800,
@ -27,7 +28,7 @@ const gameConfig = {
const preload = (scene) => { const preload = (scene) => {
scene.load.image('tiles', '/assets/tiles/default.png'); scene.load.image('tiles', '/assets/tiles/default.png');
scene.textures.addBase64('text', '') scene.textures.addBase64('player', '')
} }
const create = (scene) => { const create = (scene) => {
@ -38,6 +39,9 @@ const create = (scene) => {
cam.scrollX -= (p.x - p.prevPosition.x) / cam.zoom; cam.scrollX -= (p.x - p.prevPosition.x) / cam.zoom;
cam.scrollY -= (p.y - p.prevPosition.y) / cam.zoom; cam.scrollY -= (p.y - p.prevPosition.y) / cam.zoom;
}); });
// set camera to center
cam.centerOn(0, 0);
} }
</script> </script>

View File

@ -1,20 +1,26 @@
<template> <template>
<Image texture="text" :x="x" :y="y" /> <Image ref="player" texture="player" :x="x" :y="y">
<Body
:enable="true"
:collideWorldBounds="true" />
</Image>
</template> </template>
<script setup> <script setup>
import { Image, useScene } from 'phavuer' import { Image, useScene, Body } from 'phavuer'
import { ref } from 'vue' import { ref } from 'vue'
const scene = useScene() const scene = useScene()
const player = ref();
let x = ref(0) let x = ref(0)
let y = ref(0) let y = ref(0)
// on press "W" move up // W,S,A,D
const keyObj = scene.input.keyboard.addKey('W'); scene.input.keyboard.on('keydown', function (event) {
var isDown = keyObj.isDown; if (event.key === 'a') x.value -= 10
var isUp = keyObj.isUp; if (event.key === 'd') x.value += 10
console.log(isDown, isUp) if (event.key === 'w') y.value -= 10
if (event.key === 's') y.value += 10
});
</script> </script>