GorkemsCafe/public/index.js
2024-02-27 21:20:39 +03:00

269 lines
7.1 KiB
JavaScript

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 debugMode = false;
let timeoutHandle;
//preload images to avoid firefox NS_BINDING_ABORTED errorr
const characters = ["Green","Red","Orange","Blue"];
characters.forEach((char) => {
new Image().src = 'characterSprites/'+ char +'/Down.png';
new Image().src = 'characterSprites/'+ char +'/Up.png';
new Image().src = 'characterSprites/'+ char +'/Left.png';
new Image().src = 'characterSprites/'+ char +'/Right.png';
});
//emoji picker code
// 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);
// }
if(!localStorage.getItem('username')){
localStorage.setItem('username','Visitor')
}
// setInterval(player.animate, 50);
canvas.width = 32 * 21 //672
canvas.height = 32 * 12 //384
console.log(ctx);
const room1 = new Sprite({
position:{
x:0,
y:0
},
imageSrc: './img/baackground.png'
})
socket.on('disconnect',(reason)=>{
console.log(reason);
if (confirm("Kicked to due inactivity, click OK to refresh page") == true) {
window.location.reload();
}
})
// 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:'',
skin:bPlayer.skin,
message:'',
atPosition:true,
isCharacter2D:true,
animationColumn:0,
imageSrc:'characterSprites/' + bPlayer.skin + '/Down.png',
frames: 7,
center:true,
sprites:spriteFunction(bPlayer.skin)
})
// console.log(fPlayers[id])
fPlayers[id].username = localStorage.getItem('username')
socket.emit('username',fPlayers[id].username);
} 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
if(fPlayers[id].skin!=bPlayer.skin){spriteFunctionUpdate(fPlayers[id],bPlayer.skin)}
// console.log(fPlayers[id].skin)
// console.log(bPlayer.skin)
// fPlayers[id].sprites = spriteFunction(bPlayer.skin)
// console.log(fPlayers[id])
//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);
room1.draw()
animationId = requestAnimationFrame(animate);
if(readyNow){
// ctx.drawImage(background,0,0);
for (const id in fPlayers){
const allfPlayer = fPlayers[id]
allfPlayer.draw()
if(debugMode) allfPlayer.debug()
allfPlayer.update()
// allfPlayer.message()
}
// 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 ? event.preventDefault() : event.returnValue = false; //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 ","")
localStorage.setItem('username',fPlayers[socket.id].username);
socket.emit('username',fPlayers[socket.id].username)
}else if(inputValue==='/debug'){
if(debugMode) {debugMode=false;}else{debugMode=true;}
}else if(inputValue.includes("/dino ")){
console.log(inputValue.slice(6,7));
var newSkin = "";
switch(inputValue.slice(6,7)) {
case '1':
newSkin = "Green";
break;
case '2':
newSkin = "Red";
break;
case '3':
newSkin = "Orange";
break;
case '4':
newSkin = "Blue";
break;
default:
newSkin = "Green";
}
socket.emit('skin',newSkin);
}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();
})
function spriteFunction(skin) {
return {
down:'characterSprites/' + skin + '/Down.png',
up:'characterSprites/' + skin + '/Up.png',
right:'characterSprites/' + skin + '/Right.png',
left:'characterSprites/' + skin + '/Left.png'
};
}
function spriteFunctionUpdate(obj,skin) {
obj.Down.src='characterSprites/' + skin + '/Down.png';
obj.Up.src='characterSprites/' + skin + '/Up.png';
obj.Left.src='characterSprites/' + skin + '/Left.png';
obj.Right.src='characterSprites/' + skin + '/Right.png';
}