<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>
<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>
<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>
You can keep your changes by saving your game to the dashboard, and copy them again later.