Sign up

Pong 404

   
0 - 0
           

Custom options

















Login to edit GAME

Copy Default Code

          

<style>
   #gameContainer {
       background-color: #ff0000 !important;
       border-color: #fff !important;
   }

   #score {
       color: #fff !important;
   }

   #startButton {
       background-color: #000 !important;
color: #fff !important;

   }

   .paddle {
       background-color: #fff !important;
   }

   .ball {
       background-color: #fff !important;
   }

   .centerLine {
       border-color: #fff !important;
   }

   #gameCanvas {
       background-color: #ff0000 !important;
       width: 100% !important;
       height: 500px !important;
   }

   canvas {
       background-color: #ff0000 !important;
   }

   #gameContainer {
       margin: 0;
       padding: 10px;
       display: flex;
       flex-direction: column;
       justify-content: center;
       align-items: center;
       background-color: #000;
       font-family: 'PixelFont', sans-serif;
       position: relative;
       border: 2px solid #fff;
   }

   #gameCanvas {
       background-color: #000;
       display: block;
   }

   #score {
       color: #fff;
       font-size: 24px;
       position: absolute;
       top: 20px;
       font-family: 'PixelFont', sans-serif;
   }

   #startButton {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       animation: blink 1s infinite;
       position: absolute;
   }

   @keyframes blink {
       50% {
           opacity: 0;
       }
   }

   #colorForm {
       position: relative;
       background: black;
       padding: 10px;
       border-radius: 0px;
   }

   #mobileControls {
       position: absolute;
       bottom: 10px;
       display: flex;
       gap: 10px;
   }

   #mobileControls button {
       padding: 10px;
       font-size: 18px;
       font-family: 'PixelFont', sans-serif;
   }
</style>

<div id="gameContainer">
   <div id="score">0 - 0</div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton" style="background:black !important; color: #fff !important;">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveUpButton">Up</button>
       <button id="moveDownButton">Down</button>
   </div>
</div>

<!--- GAME JS --->
<script>
let canvasColor = '#000';
let paddleColor = '#fff';
let textColor = '#fff';
let ballColor = '#fff';
let borderColor = '#fff';
let centerLineColor = '#fff';

const watermarkBase64 = ''; // Example Base64 string


function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'paddleColor':
           paddleColor = color;
           break;
       case 'textColor':
           textColor = color;
           break;
       case 'ballColor':
           ballColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
       case 'centerLineColor':
           centerLineColor = color;
           break;
   }
   draw();
   saveColors(); // Call saveColors after updating colors
}

function saveColors() {
   const canvasWidth = document.getElementById('canvasWidth').value || canvas.style.width;
   const canvasHeight = document.getElementById('canvasHeight').value || canvas.style.height;

   const css = `
       <style>
           #gameContainer {
               background-color: ${canvasColor} !important;
               border-color: ${borderColor} !important;
           }
           #score {
               color: ${textColor} !important;
           }
           #startButton {
                background-color: ${textColor} !important;
           }
           .paddle {
               background-color: ${paddleColor} !important;
           }
           .ball {
               background-color: ${ballColor} !important;
           }
           .centerLine {
               border-color: ${centerLineColor} !important;
           }
           #gameCanvas {
               background-color: ${canvasColor} !important;
               width: ${canvasWidth} !important;
               height: ${canvasHeight} !important;
           }
           canvas {
               background-color: ${canvasColor} !important;
               }
       </style>
   `;

   const trimmedCss = css.trim();
   document.getElementById('add-css').value = trimmedCss;
   document.getElementById('add-css-export').innerHTML = trimmedCss;
   
}

function updateCanvasSize() {
   const canvasWidth = document.getElementById('canvasWidth').value;
   const canvasHeight = document.getElementById('canvasHeight').value;

   if (canvasWidth) {
       canvas.style.width = canvasWidth;
   }
   if (canvasHeight) {
       canvas.style.height = canvasHeight;
   }
   canvas.width = canvas.offsetWidth;
   canvas.height = canvas.offsetHeight;
   draw(); // Redraw the canvas with the new size
}

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const paddleHeight = 100;
const paddleWidth = 10;
const ballRadius = 7;
let upPressed = false;
let downPressed = false;
let playerY = (canvas.height - paddleHeight) / 2;
let aiY = (canvas.height - paddleHeight) / 2;
let ballX = canvas.width / 2;
let ballY = canvas.height / 2;
let ballSpeedX = 3;
let ballSpeedY = 2;
let playerScore = 0;
let aiScore = 0;
let gameStarted = false;

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = true;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = true;
       e.preventDefault();
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = false;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = false;
       e.preventDefault();
   }
});

document.getElementById('moveUpButton').addEventListener('mousedown', () => {
   upPressed = true;
});
document.getElementById('moveUpButton').addEventListener('mouseup', () => {
   upPressed = false;
});
document.getElementById('moveDownButton').addEventListener('mousedown', () => {
   downPressed = true;
});
document.getElementById('moveDownButton').addEventListener('mouseup', () => {
   downPressed = false;
});

function drawPaddle(x, y) {
   ctx.fillStyle = paddleColor;
   ctx.fillRect(x, y, paddleWidth, paddleHeight);
}

function drawBall() {
   ctx.beginPath();
   ctx.arc(ballX, ballY, ballRadius, 0, Math.PI * 2);
   ctx.fillStyle = ballColor;
   ctx.fill();
   ctx.closePath();
}

function drawWatermark() {
   const img = new Image();
   img.src = watermarkBase64;
   img.onload = () => {
       const imgWidth = img.width * 2; // Increase size
       const imgHeight = img.height * 2; // Increase size
       const x = (canvas.width - imgWidth) / 2;
       const y = canvas.height - imgHeight - 10; // 10px from the bottom
       ctx.drawImage(img, x, y, imgWidth, imgHeight);
       canvas.addEventListener('click', (e) => {
           const rect = canvas.getBoundingClientRect();
           const mouseX = e.clientX - rect.left;
           const mouseY = e.clientY - rect.top;
           if (mouseX >= x && mouseX <= x + imgWidth && mouseY >= y && mouseY <= y + imgHeight) {
               window.open('https://errorarcade.webflow.io/', '_blank');
           }
       });
   };
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPaddle(0, playerY);
   drawPaddle(canvas.width - paddleWidth, aiY);
   drawBall();
   drawWatermark();

   // Draw center line
   ctx.beginPath();
   ctx.setLineDash([10, 8]);
   ctx.moveTo(canvas.width / 2, 0);
   ctx.lineTo(canvas.width / 2, canvas.height);
   ctx.strokeStyle = centerLineColor;
   ctx.stroke();
   ctx.closePath();

   document.getElementById('score').innerText = `${playerScore} - ${aiScore}`;
}

function movePaddle() {
   if (upPressed && playerY > 0) playerY -= 5;
   if (downPressed && playerY < canvas.height - paddleHeight) playerY += 5;
}

function moveBall() {
   ballX += ballSpeedX;
   ballY += ballSpeedY;

   if (ballY + ballSpeedY > canvas.height - ballRadius || ballY + ballSpeedY < ballRadius) {
       ballSpeedY = -ballSpeedY;
   }

   if (ballX + ballSpeedX > canvas.width - paddleWidth - ballRadius) {
       if (ballY > aiY && ballY < aiY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           playerScore++;
           resetBall();
       }
   } else if (ballX + ballSpeedX < paddleWidth + ballRadius) {
       if (ballY > playerY && ballY < playerY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           aiScore++;
           resetBall();
       }
   }

   // AI Movement with a chance to miss
   if (ballX > canvas.width / 2 && Math.random() > 0.1) {
       aiY = ballY - paddleHeight / 2;
   }
}

function resetBall() {
   ballX = canvas.width / 2;
   ballY = canvas.height / 2;
   ballSpeedX = -ballSpeedX;
   ballSpeedY = (Math.random() - 0.5) * 4;
}

function update() {
   if (!gameStarted) return;

   if (playerScore >= 3 || aiScore >= 3) {
       alert(`Game Over! ${playerScore >= 3 ? 'Player' : 'AI'} Wins!`);
       playerScore = 0;
       aiScore = 0;
       resetBall();
       gameStarted = false;
       document.getElementById('startButton').style.display = 'block';
   }

   movePaddle();
   moveBall();
   draw();
}

const startButton = document.getElementById('startButton');
startButton.addEventListener('click', () => {
   gameStarted = true;
   startButton.style.display = 'none';
   setInterval(update, 1000 / 60);
});

// Show mobile controls if on a mobile device and set default canvas size
if (/Mobi|Android/i.test(navigator.userAgent)) {
   document.getElementById('mobileControls').style.display = 'flex';
   canvas.style.width = '100%';
   canvas.style.height = '500px';
} else {
   canvas.style.width = '100%';
   canvas.style.height = '500px';
}
canvas.width = canvas.offsetWidth;
canvas.height = canvas.offsetHeight;
draw(); // Initial draw to reflect default size
</script>

Copy CUSTOM Code

          

<style>
   #gameContainer {
       background-color: #ff0000 !important;
       border-color: #fff !important;
   }

   #score {
       color: #fff !important;
   }

   #startButton {
       background-color: #000 !important;
color: #fff !important;

   }

   .paddle {
       background-color: #fff !important;
   }

   .ball {
       background-color: #fff !important;
   }

   .centerLine {
       border-color: #fff !important;
   }

   #gameCanvas {
       background-color: #ff0000 !important;
       width: 100% !important;
       height: 500px !important;
   }

   canvas {
       background-color: #ff0000 !important;
   }

   #gameContainer {
       margin: 0;
       padding: 10px;
       display: flex;
       flex-direction: column;
       justify-content: center;
       align-items: center;
       background-color: #000;
       font-family: 'PixelFont', sans-serif;
       position: relative;
       border: 2px solid #fff;
   }

   #gameCanvas {
       background-color: #000;
       display: block;
   }

   #score {
       color: #fff;
       font-size: 24px;
       position: absolute;
       top: 20px;
       font-family: 'PixelFont', sans-serif;
   }

   #startButton {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       animation: blink 1s infinite;
       position: absolute;
   }

   @keyframes blink {
       50% {
           opacity: 0;
       }
   }

   #colorForm {
       position: relative;
       background: black;
       padding: 10px;
       border-radius: 0px;
   }

   #mobileControls {
       position: absolute;
       bottom: 10px;
       display: flex;
       gap: 10px;
   }

   #mobileControls button {
       padding: 10px;
       font-size: 18px;
       font-family: 'PixelFont', sans-serif;
   }
</style>

<div id="gameContainer">
   <div id="score">0 - 0</div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton" style="background:black !important; color: #fff !important;">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveUpButton">Up</button>
       <button id="moveDownButton">Down</button>
   </div>
</div>

<!--- GAME JS --->
<script>
let canvasColor = '#000';
let paddleColor = '#fff';
let textColor = '#fff';
let ballColor = '#fff';
let borderColor = '#fff';
let centerLineColor = '#fff';

const watermarkBase64 = ''; // Example Base64 string


function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'paddleColor':
           paddleColor = color;
           break;
       case 'textColor':
           textColor = color;
           break;
       case 'ballColor':
           ballColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
       case 'centerLineColor':
           centerLineColor = color;
           break;
   }
   draw();
   saveColors(); // Call saveColors after updating colors
}

function saveColors() {
   const canvasWidth = document.getElementById('canvasWidth').value || canvas.style.width;
   const canvasHeight = document.getElementById('canvasHeight').value || canvas.style.height;

   const css = `
       <style>
           #gameContainer {
               background-color: ${canvasColor} !important;
               border-color: ${borderColor} !important;
           }
           #score {
               color: ${textColor} !important;
           }
           #startButton {
                background-color: ${textColor} !important;
           }
           .paddle {
               background-color: ${paddleColor} !important;
           }
           .ball {
               background-color: ${ballColor} !important;
           }
           .centerLine {
               border-color: ${centerLineColor} !important;
           }
           #gameCanvas {
               background-color: ${canvasColor} !important;
               width: ${canvasWidth} !important;
               height: ${canvasHeight} !important;
           }
           canvas {
               background-color: ${canvasColor} !important;
               }
       </style>
   `;

   const trimmedCss = css.trim();
   document.getElementById('add-css').value = trimmedCss;
   document.getElementById('add-css-export').innerHTML = trimmedCss;
   
}

function updateCanvasSize() {
   const canvasWidth = document.getElementById('canvasWidth').value;
   const canvasHeight = document.getElementById('canvasHeight').value;

   if (canvasWidth) {
       canvas.style.width = canvasWidth;
   }
   if (canvasHeight) {
       canvas.style.height = canvasHeight;
   }
   canvas.width = canvas.offsetWidth;
   canvas.height = canvas.offsetHeight;
   draw(); // Redraw the canvas with the new size
}

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const paddleHeight = 100;
const paddleWidth = 10;
const ballRadius = 7;
let upPressed = false;
let downPressed = false;
let playerY = (canvas.height - paddleHeight) / 2;
let aiY = (canvas.height - paddleHeight) / 2;
let ballX = canvas.width / 2;
let ballY = canvas.height / 2;
let ballSpeedX = 3;
let ballSpeedY = 2;
let playerScore = 0;
let aiScore = 0;
let gameStarted = false;

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = true;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = true;
       e.preventDefault();
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = false;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = false;
       e.preventDefault();
   }
});

document.getElementById('moveUpButton').addEventListener('mousedown', () => {
   upPressed = true;
});
document.getElementById('moveUpButton').addEventListener('mouseup', () => {
   upPressed = false;
});
document.getElementById('moveDownButton').addEventListener('mousedown', () => {
   downPressed = true;
});
document.getElementById('moveDownButton').addEventListener('mouseup', () => {
   downPressed = false;
});

function drawPaddle(x, y) {
   ctx.fillStyle = paddleColor;
   ctx.fillRect(x, y, paddleWidth, paddleHeight);
}

function drawBall() {
   ctx.beginPath();
   ctx.arc(ballX, ballY, ballRadius, 0, Math.PI * 2);
   ctx.fillStyle = ballColor;
   ctx.fill();
   ctx.closePath();
}

function drawWatermark() {
   const img = new Image();
   img.src = watermarkBase64;
   img.onload = () => {
       const imgWidth = img.width * 2; // Increase size
       const imgHeight = img.height * 2; // Increase size
       const x = (canvas.width - imgWidth) / 2;
       const y = canvas.height - imgHeight - 10; // 10px from the bottom
       ctx.drawImage(img, x, y, imgWidth, imgHeight);
       canvas.addEventListener('click', (e) => {
           const rect = canvas.getBoundingClientRect();
           const mouseX = e.clientX - rect.left;
           const mouseY = e.clientY - rect.top;
           if (mouseX >= x && mouseX <= x + imgWidth && mouseY >= y && mouseY <= y + imgHeight) {
               window.open('https://errorarcade.webflow.io/', '_blank');
           }
       });
   };
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPaddle(0, playerY);
   drawPaddle(canvas.width - paddleWidth, aiY);
   drawBall();
   drawWatermark();

   // Draw center line
   ctx.beginPath();
   ctx.setLineDash([10, 8]);
   ctx.moveTo(canvas.width / 2, 0);
   ctx.lineTo(canvas.width / 2, canvas.height);
   ctx.strokeStyle = centerLineColor;
   ctx.stroke();
   ctx.closePath();

   document.getElementById('score').innerText = `${playerScore} - ${aiScore}`;
}

function movePaddle() {
   if (upPressed && playerY > 0) playerY -= 5;
   if (downPressed && playerY < canvas.height - paddleHeight) playerY += 5;
}

function moveBall() {
   ballX += ballSpeedX;
   ballY += ballSpeedY;

   if (ballY + ballSpeedY > canvas.height - ballRadius || ballY + ballSpeedY < ballRadius) {
       ballSpeedY = -ballSpeedY;
   }

   if (ballX + ballSpeedX > canvas.width - paddleWidth - ballRadius) {
       if (ballY > aiY && ballY < aiY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           playerScore++;
           resetBall();
       }
   } else if (ballX + ballSpeedX < paddleWidth + ballRadius) {
       if (ballY > playerY && ballY < playerY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           aiScore++;
           resetBall();
       }
   }

   // AI Movement with a chance to miss
   if (ballX > canvas.width / 2 && Math.random() > 0.1) {
       aiY = ballY - paddleHeight / 2;
   }
}

function resetBall() {
   ballX = canvas.width / 2;
   ballY = canvas.height / 2;
   ballSpeedX = -ballSpeedX;
   ballSpeedY = (Math.random() - 0.5) * 4;
}

function update() {
   if (!gameStarted) return;

   if (playerScore >= 3 || aiScore >= 3) {
       alert(`Game Over! ${playerScore >= 3 ? 'Player' : 'AI'} Wins!`);
       playerScore = 0;
       aiScore = 0;
       resetBall();
       gameStarted = false;
       document.getElementById('startButton').style.display = 'block';
   }

   movePaddle();
   moveBall();
   draw();
}

const startButton = document.getElementById('startButton');
startButton.addEventListener('click', () => {
   gameStarted = true;
   startButton.style.display = 'none';
   setInterval(update, 1000 / 60);
});

// Show mobile controls if on a mobile device and set default canvas size
if (/Mobi|Android/i.test(navigator.userAgent)) {
   document.getElementById('mobileControls').style.display = 'flex';
   canvas.style.width = '100%';
   canvas.style.height = '500px';
} else {
   canvas.style.width = '100%';
   canvas.style.height = '500px';
}
canvas.width = canvas.offsetWidth;
canvas.height = canvas.offsetHeight;
draw(); // Initial draw to reflect default size
</script>

PRO GAMER

Copy CUSTOM Code

        

<style>
   #gameContainer {
       background-color: #ff0000 !important;
       border-color: #fff !important;
   }

   #score {
       color: #fff !important;
   }

   #startButton {
       background-color: #000 !important;
color: #fff !important;

   }

   .paddle {
       background-color: #fff !important;
   }

   .ball {
       background-color: #fff !important;
   }

   .centerLine {
       border-color: #fff !important;
   }

   #gameCanvas {
       background-color: #ff0000 !important;
       width: 100% !important;
       height: 500px !important;
   }

   canvas {
       background-color: #ff0000 !important;
   }

   #gameContainer {
       margin: 0;
       padding: 10px;
       display: flex;
       flex-direction: column;
       justify-content: center;
       align-items: center;
       background-color: #000;
       font-family: 'PixelFont', sans-serif;
       position: relative;
       border: 2px solid #fff;
   }

   #gameCanvas {
       background-color: #000;
       display: block;
   }

   #score {
       color: #fff;
       font-size: 24px;
       position: absolute;
       top: 20px;
       font-family: 'PixelFont', sans-serif;
   }

   #startButton {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       animation: blink 1s infinite;
       position: absolute;
   }

   @keyframes blink {
       50% {
           opacity: 0;
       }
   }

   #colorForm {
       position: relative;
       background: black;
       padding: 10px;
       border-radius: 0px;
   }

   #mobileControls {
       position: absolute;
       bottom: 10px;
       display: flex;
       gap: 10px;
   }

   #mobileControls button {
       padding: 10px;
       font-size: 18px;
       font-family: 'PixelFont', sans-serif;
   }
</style>

<div id="gameContainer">
   <div id="score">0 - 0</div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton" style="background:black !important; color: #fff !important;">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveUpButton">Up</button>
       <button id="moveDownButton">Down</button>
   </div>
</div>

<!--- GAME JS --->
<script>
let canvasColor = '#000';
let paddleColor = '#fff';
let textColor = '#fff';
let ballColor = '#fff';
let borderColor = '#fff';
let centerLineColor = '#fff';

const watermarkBase64 = ''; // Example Base64 string


function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'paddleColor':
           paddleColor = color;
           break;
       case 'textColor':
           textColor = color;
           break;
       case 'ballColor':
           ballColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
       case 'centerLineColor':
           centerLineColor = color;
           break;
   }
   draw();
   saveColors(); // Call saveColors after updating colors
}

function saveColors() {
   const canvasWidth = document.getElementById('canvasWidth').value || canvas.style.width;
   const canvasHeight = document.getElementById('canvasHeight').value || canvas.style.height;

   const css = `
       <style>
           #gameContainer {
               background-color: ${canvasColor} !important;
               border-color: ${borderColor} !important;
           }
           #score {
               color: ${textColor} !important;
           }
           #startButton {
                background-color: ${textColor} !important;
           }
           .paddle {
               background-color: ${paddleColor} !important;
           }
           .ball {
               background-color: ${ballColor} !important;
           }
           .centerLine {
               border-color: ${centerLineColor} !important;
           }
           #gameCanvas {
               background-color: ${canvasColor} !important;
               width: ${canvasWidth} !important;
               height: ${canvasHeight} !important;
           }
           canvas {
               background-color: ${canvasColor} !important;
               }
       </style>
   `;

   const trimmedCss = css.trim();
   document.getElementById('add-css').value = trimmedCss;
   document.getElementById('add-css-export').innerHTML = trimmedCss;
   
}

function updateCanvasSize() {
   const canvasWidth = document.getElementById('canvasWidth').value;
   const canvasHeight = document.getElementById('canvasHeight').value;

   if (canvasWidth) {
       canvas.style.width = canvasWidth;
   }
   if (canvasHeight) {
       canvas.style.height = canvasHeight;
   }
   canvas.width = canvas.offsetWidth;
   canvas.height = canvas.offsetHeight;
   draw(); // Redraw the canvas with the new size
}

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const paddleHeight = 100;
const paddleWidth = 10;
const ballRadius = 7;
let upPressed = false;
let downPressed = false;
let playerY = (canvas.height - paddleHeight) / 2;
let aiY = (canvas.height - paddleHeight) / 2;
let ballX = canvas.width / 2;
let ballY = canvas.height / 2;
let ballSpeedX = 3;
let ballSpeedY = 2;
let playerScore = 0;
let aiScore = 0;
let gameStarted = false;

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = true;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = true;
       e.preventDefault();
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowUp') {
       upPressed = false;
       e.preventDefault();
   }
   if (e.key === 'ArrowDown') {
       downPressed = false;
       e.preventDefault();
   }
});

document.getElementById('moveUpButton').addEventListener('mousedown', () => {
   upPressed = true;
});
document.getElementById('moveUpButton').addEventListener('mouseup', () => {
   upPressed = false;
});
document.getElementById('moveDownButton').addEventListener('mousedown', () => {
   downPressed = true;
});
document.getElementById('moveDownButton').addEventListener('mouseup', () => {
   downPressed = false;
});

function drawPaddle(x, y) {
   ctx.fillStyle = paddleColor;
   ctx.fillRect(x, y, paddleWidth, paddleHeight);
}

function drawBall() {
   ctx.beginPath();
   ctx.arc(ballX, ballY, ballRadius, 0, Math.PI * 2);
   ctx.fillStyle = ballColor;
   ctx.fill();
   ctx.closePath();
}

function drawWatermark() {
   const img = new Image();
   img.src = watermarkBase64;
   img.onload = () => {
       const imgWidth = img.width * 2; // Increase size
       const imgHeight = img.height * 2; // Increase size
       const x = (canvas.width - imgWidth) / 2;
       const y = canvas.height - imgHeight - 10; // 10px from the bottom
       ctx.drawImage(img, x, y, imgWidth, imgHeight);
       canvas.addEventListener('click', (e) => {
           const rect = canvas.getBoundingClientRect();
           const mouseX = e.clientX - rect.left;
           const mouseY = e.clientY - rect.top;
           if (mouseX >= x && mouseX <= x + imgWidth && mouseY >= y && mouseY <= y + imgHeight) {
               window.open('https://errorarcade.webflow.io/', '_blank');
           }
       });
   };
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPaddle(0, playerY);
   drawPaddle(canvas.width - paddleWidth, aiY);
   drawBall();
   drawWatermark();

   // Draw center line
   ctx.beginPath();
   ctx.setLineDash([10, 8]);
   ctx.moveTo(canvas.width / 2, 0);
   ctx.lineTo(canvas.width / 2, canvas.height);
   ctx.strokeStyle = centerLineColor;
   ctx.stroke();
   ctx.closePath();

   document.getElementById('score').innerText = `${playerScore} - ${aiScore}`;
}

function movePaddle() {
   if (upPressed && playerY > 0) playerY -= 5;
   if (downPressed && playerY < canvas.height - paddleHeight) playerY += 5;
}

function moveBall() {
   ballX += ballSpeedX;
   ballY += ballSpeedY;

   if (ballY + ballSpeedY > canvas.height - ballRadius || ballY + ballSpeedY < ballRadius) {
       ballSpeedY = -ballSpeedY;
   }

   if (ballX + ballSpeedX > canvas.width - paddleWidth - ballRadius) {
       if (ballY > aiY && ballY < aiY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           playerScore++;
           resetBall();
       }
   } else if (ballX + ballSpeedX < paddleWidth + ballRadius) {
       if (ballY > playerY && ballY < playerY + paddleHeight) {
           ballSpeedX = -ballSpeedX;
           // Add some randomness to the ball speed
           ballSpeedY += (Math.random() - 0.5) * 2;
       } else {
           aiScore++;
           resetBall();
       }
   }

   // AI Movement with a chance to miss
   if (ballX > canvas.width / 2 && Math.random() > 0.1) {
       aiY = ballY - paddleHeight / 2;
   }
}

function resetBall() {
   ballX = canvas.width / 2;
   ballY = canvas.height / 2;
   ballSpeedX = -ballSpeedX;
   ballSpeedY = (Math.random() - 0.5) * 4;
}

function update() {
   if (!gameStarted) return;

   if (playerScore >= 3 || aiScore >= 3) {
       alert(`Game Over! ${playerScore >= 3 ? 'Player' : 'AI'} Wins!`);
       playerScore = 0;
       aiScore = 0;
       resetBall();
       gameStarted = false;
       document.getElementById('startButton').style.display = 'block';
   }

   movePaddle();
   moveBall();
   draw();
}

const startButton = document.getElementById('startButton');
startButton.addEventListener('click', () => {
   gameStarted = true;
   startButton.style.display = 'none';
   setInterval(update, 1000 / 60);
});

// Show mobile controls if on a mobile device and set default canvas size
if (/Mobi|Android/i.test(navigator.userAgent)) {
   document.getElementById('mobileControls').style.display = 'flex';
   canvas.style.width = '100%';
   canvas.style.height = '500px';
} else {
   canvas.style.width = '100%';
   canvas.style.height = '500px';
}
canvas.width = canvas.offsetWidth;
canvas.height = canvas.offsetHeight;
draw(); // Initial draw to reflect default size
</script>

Add this game (Admin only)

Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.

Save Your edits

You can keep your changes by saving your game to the dashboard, and copy them again later.

Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.