diff --git a/package-lock.json b/package-lock.json
index 8bef8a0..c59d3f9 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -2488,9 +2488,9 @@
       }
     },
     "node_modules/caniuse-lite": {
-      "version": "1.0.30001612",
-      "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001612.tgz",
-      "integrity": "sha512-lFgnZ07UhaCcsSZgWW0K5j4e69dK1u/ltrL9lTUiFOwNHs12S3UMIEYgBV0Z6C6hRDev7iRnMzzYmKabYdXF9g==",
+      "version": "1.0.30001613",
+      "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001613.tgz",
+      "integrity": "sha512-BNjJULJfOONQERivfxte7alLfeLW4QnwHvNW4wEcLEbXfV6VSCYvr+REbf2Sojv8tC1THpjPXBxWgDbq4NtLWg==",
       "dev": true,
       "funding": [
         {
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 1f43669..6bc907b 100644
--- a/src/components/Game.vue
+++ b/src/components/Game.vue
@@ -10,7 +10,7 @@
 
 <script setup lang="ts">
 import 'phaser';
-import { Game, Scene, useGame } from 'phavuer'
+import { Game, Scene } from 'phavuer'
 import World from '@/components/World.vue'
 
 const gameConfig = {
@@ -20,6 +20,7 @@ const gameConfig = {
     autoCenter: Phaser.Scale.CENTER_BOTH,
   },
   type: Phaser.CANVAS,
+  physics: { default: 'arcade' },
   pixelArt: true,
   width: 1200,
   height: 800,
@@ -27,7 +28,7 @@ const gameConfig = {
 
 const preload = (scene) => {
   scene.load.image('tiles', '/assets/tiles/default.png');
-  scene.textures.addBase64('text', '')
+  scene.textures.addBase64('player', '')
 }
 
 const create = (scene) => {
@@ -38,6 +39,9 @@ const create = (scene) => {
     cam.scrollX -= (p.x - p.prevPosition.x) / cam.zoom;
     cam.scrollY -= (p.y - p.prevPosition.y) / cam.zoom;
   });
+
+  // set camera to center
+  cam.centerOn(0, 0);
 }
 </script>
 
diff --git a/src/components/player/Player.vue b/src/components/player/Player.vue
index e70e51f..8c818c4 100644
--- a/src/components/player/Player.vue
+++ b/src/components/player/Player.vue
@@ -1,20 +1,26 @@
 <template>
-  <Image texture="text" :x="x" :y="y" />
+  <Image ref="player" texture="player" :x="x" :y="y">
+    <Body
+      :enable="true"
+      :collideWorldBounds="true"  />
+  </Image>
 </template>
 
 <script setup>
-import { Image, useScene } from 'phavuer'
+import { Image, useScene, Body } from 'phavuer'
 import { ref } from 'vue'
 
 const scene = useScene()
 
+const player = ref();
 let x = ref(0)
 let y = ref(0)
 
-// on press "W" move up
-const keyObj = scene.input.keyboard.addKey('W');
-var isDown = keyObj.isDown;
-var isUp = keyObj.isUp;
-console.log(isDown, isUp)
-
+// W,S,A,D
+scene.input.keyboard.on('keydown', function (event) {
+  if (event.key === 'a') x.value -= 10
+  if (event.key === 'd') x.value += 10
+  if (event.key === 'w') y.value -= 10
+  if (event.key === 's') y.value += 10
+});
 </script>
\ No newline at end of file