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;
|
2023-09-27 05:56:42 -05:00
|
|
|
let debugMode = false;
|
2023-09-26 10:40:27 -05:00
|
|
|
let timeoutHandle;
|
2023-09-26 04:40:05 -05:00
|
|
|
|
2023-09-28 10:03:39 -05:00
|
|
|
|
|
|
|
|
2023-09-26 04:40:05 -05:00
|
|
|
// 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);
|
|
|
|
|
2023-09-26 06:57:39 -05:00
|
|
|
canvas.width = 32 * 21 //672
|
|
|
|
canvas.height = 32 * 12 //384
|
2023-09-26 04:40:05 -05:00
|
|
|
|
|
|
|
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
|
2023-09-26 11:03:59 -05:00
|
|
|
|
2023-09-26 04:40:05 -05:00
|
|
|
//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()
|
2023-09-26 11:15:58 -05:00
|
|
|
if(debugMode) allfPlayer.debug()
|
2023-09-26 04:40:05 -05:00
|
|
|
allfPlayer.update()
|
2023-09-28 10:03:39 -05:00
|
|
|
// allfPlayer.message()
|
2023-09-26 04:40:05 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
2023-09-26 11:03:59 -05:00
|
|
|
if(inputValue.includes("/name ")){
|
2023-09-26 04:40:05 -05:00
|
|
|
console.log('namechange')
|
2023-09-26 11:03:59 -05:00
|
|
|
fPlayers[socket.id].username = inputValue.replace("/name ","")
|
2023-09-26 04:40:05 -05:00
|
|
|
socket.emit('username',fPlayers[socket.id].username)
|
2023-09-26 11:15:58 -05:00
|
|
|
}else if(inputValue==='/debug'){
|
|
|
|
if(debugMode) {debugMode=false;}else{debugMode=true;}
|
|
|
|
|
2023-09-26 04:40:05 -05:00
|
|
|
}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();
|
|
|
|
})
|