GorkemsCafe/public/index.js

193 lines
4.5 KiB
JavaScript
Raw Normal View History

2023-09-26 04:40:05 -05:00
const canvas = document.querySelector('canvas');
const ctx = canvas.getContext('2d')
const socket = io()
ctx.imageSmoothingEnabled = false;
const speed = 2;
var frameCount = 10
var length = 0
let img = new Image();
let frameWidth = 23.5;
let frameHeight = 29;
let column = 0;
let row = 0;
let readyNow = false
let animationFrame = 0;
let pageVisible = true;
// let atPosition = true;
// img.src = 'demaSprite.png';
clickCoordinates = [100,100]
// document.getElementById("canvas").style.background = "url('baackground.png')";
// background.onload = function(){
// ctx.drawImage(background,0,0);
// }
// setInterval(player.animate, 50);
canvas.width = 32 * 28
canvas.height = 32 * 15
console.log(ctx);
const background1 = new Sprite({
position:{
x:0,
y:0
},
imageSrc: './img/baackground.png'
})
// const player = new Player(100,100,'Görkem')
const fPlayers = {}
socket.on('updatePlayers', (bPlayers) =>{
for(const id in bPlayers){
const bPlayer = bPlayers[id]
if(!fPlayers[id]){
fPlayers[id] = new Player({
position:{
x:bPlayer.x,
y:bPlayer.y
},
incrementX:0,
incrementY:0,
clickX:bPlayer.clickX,
clickY:bPlayer.clickY,
userId:id,
username:'Visitor',
message:'',
atPosition:true,
animationColumn:0,
imageSrc:'Down.png',
frames: 4,
center:true,
sprites:{
down:'Down.png',
up:'Up.png',
right:'Right.png',
left:'Left.png'
}
})
} else {
// if players already exist
fPlayers[id].clickX = bPlayer.clickX
fPlayers[id].clickY = bPlayer.clickY
fPlayers[id].message = bPlayer.message
fPlayers[id].username = bPlayer.username
//update player position without animation if tab is inactive
if (document.hidden) {
fPlayers[id].position.x = bPlayer.x
fPlayers[id].position.y = bPlayer.y
}
}
}
for (const id in fPlayers){
if(!bPlayers[id]){
delete fPlayers[id]
}
}
// console.log(fPlayers)
readyNow=true
})
// setInterval(animate, 60);
// player.draw()
// get cursor position function
function getCursorPosition(canvas, event) {
const rect = canvas.getBoundingClientRect()
const x = event.clientX - rect.left
const y = event.clientY - rect.top
// console.log("x: " + x + " y: " + y)
return [x,y]
}
// animate from point a to point b
let animationId
// setInterval(animate, 60);
function animate(){
ctx.imageSmoothingEnabled = false;
// console.log(pageVisible)
// ctx.clearRect(0,0,canvas.width,canvas.height);
background1.draw()
animationId = requestAnimationFrame(animate);
if(readyNow){
// ctx.drawImage(background,0,0);
for (const id in fPlayers){
const allfPlayer = fPlayers[id]
allfPlayer.draw()
allfPlayer.debug()
allfPlayer.update()
}
// fPlayer = fPlayers[socket.id]
// if(){}
// goToPosition(fPlayer,clickCoordinates)
// console.log(fPlayer.animationColumn)
// return [incrementX,incrementY]
}
// function goToPosition(fPlayer,clickCoordinates){
// }
}
animate()
canvas.addEventListener('mousedown', function(e) {
clickCoordinates = getCursorPosition(canvas, e)
// calculateIncrement(fPlayers[socket.id]);
fPlayers[socket.id].clickX = clickCoordinates[0]
fPlayers[socket.id].clickY = clickCoordinates[1]
socket.emit('clickPosition',clickCoordinates)
// length=2;
// animate(player.x,player.y,clickCoordinates[0],clickCoordinates[1],frameCount)
})
//
document.querySelector('#textInput').addEventListener('submit',(event)=>{
event.preventDefault() //do not refresh page whenform submited
var inputValue = document.querySelector('#input').value
if(inputValue.includes("/name")){
console.log('namechange')
fPlayers[socket.id].username = inputValue.replace("/name","")
socket.emit('username',fPlayers[socket.id].username)
}else{
fPlayers[socket.id].message=document.querySelector('#input').value
socket.emit('message',fPlayers[socket.id].message)
console.log('value sent')
fPlayers[socket.id].messageSent = true;
}
document.querySelector('#textInput').reset();
})