Sign up

Page Invaders

Score: 0 | Lives: 3

Custom options

















Login to edit GAME

Copy Default Code

          

<!--- PAGE INVADER 1.0 -->

<style>
   #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;
   }
   #message {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       position: absolute;
       display: none;
   }
   @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">Score: 0 | Lives: 3</div>
   <div id="message"></div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveLeftButton">←</button>
       <button id="moveRightButton">→</button>
       <button id="shootButton">Shoot</button>
   </div>
</div>


<script>
let canvasColor = '#000';
let playerColor = '#fff';
let enemyColor = '#ff0000';
let bulletColor = '#00ff00';
let borderColor = '#fff';
let watermarkColor = '#fff';

const watermarkBase64 = '';

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const playerWidth = 50;
const playerHeight = 30;
const bulletWidth = 5;
const bulletHeight = 10;
const enemyWidth = 40;
const enemyHeight = 30;
let playerX = (canvas.width - playerWidth) / 2;
let bullets = [];
let enemies = [];
let enemyBullets = [];
let leftPressed = false;
let rightPressed = false;
let shootPressed = false;
let score = 0;
let lives = 3;
let gameStarted = false;
let enemyDirection = 1; // 1 for right, -1 for left
let messageElement = document.getElementById('message');

function initEnemies() {
   enemies = [];
   for (let row = 0; row < 3; row++) {
       for (let col = 0; col < 8; col++) {
           let x = col * (enemyWidth + 10) + 30;
           let y = row * (enemyHeight + 10) + 30;
           enemies.push({ x: x, y: y, status: 1 });
       }
   }
}

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = true;
   if (e.key === 'ArrowRight') rightPressed = true;
   if (e.key === ' ') {
       shootPressed = true;
       e.preventDefault();  // Prevent space bar from scrolling the page
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = false;
   if (e.key === 'ArrowRight') rightPressed = false;
   if (e.key === ' ') shootPressed = false;
});

document.getElementById('moveLeftButton').addEventListener('mousedown', () => leftPressed = true);
document.getElementById('moveLeftButton').addEventListener('mouseup', () => leftPressed = false);
document.getElementById('moveRightButton').addEventListener('mousedown', () => rightPressed = true);
document.getElementById('moveRightButton').addEventListener('mouseup', () => rightPressed = false);
document.getElementById('shootButton').addEventListener('mousedown', () => shootPressed = true);
document.getElementById('shootButton').addEventListener('mouseup', () => shootPressed = false);

function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'playerColor':
           playerColor = color;
           break;
       case 'enemyColor':
           enemyColor = color;
           break;
       case 'bulletColor':
           bulletColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
       case 'watermarkColor':
           watermarkColor = color;
           break;
   }
   draw();
   saveColors();
}

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: ${playerColor} !important;
           }
           #startButton {
               background-color: ${playerColor} !important;
           }
           .player {
               background-color: ${playerColor} !important;
           }
           .enemy {
               background-color: ${enemyColor} !important;
           }
           .bullet {
               background-color: ${bulletColor} !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-2').innerHTML = trimmedCss;
document.getElementById('add-css-export-3').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;
   playerX = (canvas.width - playerWidth) / 2;
   draw();
}

function drawPlayer() {
   ctx.fillStyle = playerColor;
   ctx.beginPath();
   ctx.moveTo(playerX, canvas.height - playerHeight);
   ctx.lineTo(playerX + playerWidth / 2, canvas.height - playerHeight - 20);
   ctx.lineTo(playerX + playerWidth, canvas.height - playerHeight);
   ctx.closePath();
   ctx.fill();
}

function drawBullet(bullet) {
   ctx.fillStyle = bulletColor;
   ctx.fillRect(bullet.x, bullet.y, bulletWidth, bulletHeight);
}

function drawEnemies() {
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           ctx.fillStyle = enemyColor;
           ctx.beginPath();
           ctx.arc(enemy.x + enemyWidth / 2, enemy.y + enemyHeight / 2, enemyWidth / 2, 0, Math.PI * 2);
           ctx.closePath();
           ctx.fill();
       }
   });
}

function drawWatermark() {
   const img = new Image();
   img.src = watermarkBase64;
   img.onload = () => {
       ctx.drawImage(img, (canvas.width - img.width) / 2, (canvas.height - img.height) / 2);
       ctx.fillStyle = watermarkColor;
       ctx.globalAlpha = 0.6;
       ctx.fill();
       ctx.globalAlpha = 1.0;
   };
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPlayer();
   bullets.forEach(drawBullet);
   enemyBullets.forEach(drawBullet);
   drawEnemies();
   drawWatermark();
   document.getElementById('score').innerText = `Score: ${score} | Lives: ${lives}`;
}

function movePlayer() {
   if (leftPressed && playerX > 0) playerX -= 5;
   if (rightPressed && playerX < canvas.width - playerWidth) playerX += 5;
}

function moveBullets() {
   bullets.forEach(bullet => bullet.y -= 5);
   bullets = bullets.filter(bullet => bullet.y > 0);

   enemyBullets.forEach(bullet => bullet.y += 5);
   enemyBullets = enemyBullets.filter(bullet => bullet.y < canvas.height);
}

function shootBullet() {
   if (shootPressed) {
       bullets.push({ x: playerX + playerWidth / 2 - bulletWidth / 2, y: canvas.height - playerHeight - 20 });
       shootPressed = false;
   }
}

function enemyShoot() {
   enemies.forEach(enemy => {
       if (enemy.status === 1 && Math.random() < 0.01) {
           enemyBullets.push({ x: enemy.x + enemyWidth / 2 - bulletWidth / 2, y: enemy.y + enemyHeight });
       }
   });
}

function moveEnemies() {
   let moveDown = false;
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           enemy.x += enemyDirection * 2;
           if (enemy.x + enemyWidth > canvas.width || enemy.x < 0) {
               moveDown = true;
           }
       }
   });
   if (moveDown) {
       enemies.forEach(enemy => {
           enemy.y += 10;
       });
       enemyDirection *= -1;
   }
}

function detectCollisions() {
   bullets.forEach(bullet => {
       enemies.forEach(enemy => {
           if (enemy.status === 1 && bullet.x > enemy.x && bullet.x < enemy.x + enemyWidth && bullet.y > enemy.y && bullet.y < enemy.y + enemyHeight) {
               enemy.status = 0;
               bullet.y = -10;
               score++;
           }
       });
   });

   enemyBullets.forEach(bullet => {
       if (bullet.x > playerX && bullet.x < playerX + playerWidth && bullet.y > canvas.height - playerHeight - 20) {
           bullet.y = canvas.height + 10;
           lives--;
           if (lives <= 0) {
               gameOver();
           }
       }
   });

   enemies.forEach(enemy => {
       if (enemy.status === 1 && enemy.y + enemyHeight > canvas.height - playerHeight - 10 && enemy.x + enemyWidth > playerX && enemy.x < playerX + playerWidth) {
           lives--;
           enemy.status = 0;
           if (lives <= 0) {
               gameOver();
           }
       }
   });
}

function gameOver() {
   messageElement.innerText = 'Game Over!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

function winGame() {
   messageElement.innerText = 'You Win!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

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

   if (enemies.every(enemy => enemy.status === 0)) {
       winGame();
   }

   movePlayer();
   moveBullets();
   shootBullet();
   enemyShoot();
   moveEnemies();
   detectCollisions();
   draw();
}

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

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;
playerX = (canvas.width - playerWidth) / 2;
draw();
</script>

Copy CUSTOM Code

          

<!--- PAGE INVADER 1.0 -->

<style>
   #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;
   }
   #message {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       position: absolute;
       display: none;
   }
   @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">Score: 0 | Lives: 3</div>
   <div id="message"></div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveLeftButton">←</button>
       <button id="moveRightButton">→</button>
       <button id="shootButton">Shoot</button>
   </div>
</div>


<script>
let canvasColor = '#000';
let playerColor = '#fff';
let enemyColor = '#ff0000';
let bulletColor = '#00ff00';
let borderColor = '#fff';
let watermarkColor = '#fff';

const watermarkBase64 = '';

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const playerWidth = 50;
const playerHeight = 30;
const bulletWidth = 5;
const bulletHeight = 10;
const enemyWidth = 40;
const enemyHeight = 30;
let playerX = (canvas.width - playerWidth) / 2;
let bullets = [];
let enemies = [];
let enemyBullets = [];
let leftPressed = false;
let rightPressed = false;
let shootPressed = false;
let score = 0;
let lives = 3;
let gameStarted = false;
let enemyDirection = 1; // 1 for right, -1 for left
let messageElement = document.getElementById('message');

function initEnemies() {
   enemies = [];
   for (let row = 0; row < 3; row++) {
       for (let col = 0; col < 8; col++) {
           let x = col * (enemyWidth + 10) + 30;
           let y = row * (enemyHeight + 10) + 30;
           enemies.push({ x: x, y: y, status: 1 });
       }
   }
}

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = true;
   if (e.key === 'ArrowRight') rightPressed = true;
   if (e.key === ' ') {
       shootPressed = true;
       e.preventDefault();  // Prevent space bar from scrolling the page
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = false;
   if (e.key === 'ArrowRight') rightPressed = false;
   if (e.key === ' ') shootPressed = false;
});

document.getElementById('moveLeftButton').addEventListener('mousedown', () => leftPressed = true);
document.getElementById('moveLeftButton').addEventListener('mouseup', () => leftPressed = false);
document.getElementById('moveRightButton').addEventListener('mousedown', () => rightPressed = true);
document.getElementById('moveRightButton').addEventListener('mouseup', () => rightPressed = false);
document.getElementById('shootButton').addEventListener('mousedown', () => shootPressed = true);
document.getElementById('shootButton').addEventListener('mouseup', () => shootPressed = false);

function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'playerColor':
           playerColor = color;
           break;
       case 'enemyColor':
           enemyColor = color;
           break;
       case 'bulletColor':
           bulletColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
       case 'watermarkColor':
           watermarkColor = color;
           break;
   }
   draw();
   saveColors();
}

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: ${playerColor} !important;
           }
           #startButton {
               background-color: ${playerColor} !important;
           }
           .player {
               background-color: ${playerColor} !important;
           }
           .enemy {
               background-color: ${enemyColor} !important;
           }
           .bullet {
               background-color: ${bulletColor} !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-2').innerHTML = trimmedCss;
document.getElementById('add-css-export-3').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;
   playerX = (canvas.width - playerWidth) / 2;
   draw();
}

function drawPlayer() {
   ctx.fillStyle = playerColor;
   ctx.beginPath();
   ctx.moveTo(playerX, canvas.height - playerHeight);
   ctx.lineTo(playerX + playerWidth / 2, canvas.height - playerHeight - 20);
   ctx.lineTo(playerX + playerWidth, canvas.height - playerHeight);
   ctx.closePath();
   ctx.fill();
}

function drawBullet(bullet) {
   ctx.fillStyle = bulletColor;
   ctx.fillRect(bullet.x, bullet.y, bulletWidth, bulletHeight);
}

function drawEnemies() {
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           ctx.fillStyle = enemyColor;
           ctx.beginPath();
           ctx.arc(enemy.x + enemyWidth / 2, enemy.y + enemyHeight / 2, enemyWidth / 2, 0, Math.PI * 2);
           ctx.closePath();
           ctx.fill();
       }
   });
}

function drawWatermark() {
   const img = new Image();
   img.src = watermarkBase64;
   img.onload = () => {
       ctx.drawImage(img, (canvas.width - img.width) / 2, (canvas.height - img.height) / 2);
       ctx.fillStyle = watermarkColor;
       ctx.globalAlpha = 0.6;
       ctx.fill();
       ctx.globalAlpha = 1.0;
   };
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPlayer();
   bullets.forEach(drawBullet);
   enemyBullets.forEach(drawBullet);
   drawEnemies();
   drawWatermark();
   document.getElementById('score').innerText = `Score: ${score} | Lives: ${lives}`;
}

function movePlayer() {
   if (leftPressed && playerX > 0) playerX -= 5;
   if (rightPressed && playerX < canvas.width - playerWidth) playerX += 5;
}

function moveBullets() {
   bullets.forEach(bullet => bullet.y -= 5);
   bullets = bullets.filter(bullet => bullet.y > 0);

   enemyBullets.forEach(bullet => bullet.y += 5);
   enemyBullets = enemyBullets.filter(bullet => bullet.y < canvas.height);
}

function shootBullet() {
   if (shootPressed) {
       bullets.push({ x: playerX + playerWidth / 2 - bulletWidth / 2, y: canvas.height - playerHeight - 20 });
       shootPressed = false;
   }
}

function enemyShoot() {
   enemies.forEach(enemy => {
       if (enemy.status === 1 && Math.random() < 0.01) {
           enemyBullets.push({ x: enemy.x + enemyWidth / 2 - bulletWidth / 2, y: enemy.y + enemyHeight });
       }
   });
}

function moveEnemies() {
   let moveDown = false;
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           enemy.x += enemyDirection * 2;
           if (enemy.x + enemyWidth > canvas.width || enemy.x < 0) {
               moveDown = true;
           }
       }
   });
   if (moveDown) {
       enemies.forEach(enemy => {
           enemy.y += 10;
       });
       enemyDirection *= -1;
   }
}

function detectCollisions() {
   bullets.forEach(bullet => {
       enemies.forEach(enemy => {
           if (enemy.status === 1 && bullet.x > enemy.x && bullet.x < enemy.x + enemyWidth && bullet.y > enemy.y && bullet.y < enemy.y + enemyHeight) {
               enemy.status = 0;
               bullet.y = -10;
               score++;
           }
       });
   });

   enemyBullets.forEach(bullet => {
       if (bullet.x > playerX && bullet.x < playerX + playerWidth && bullet.y > canvas.height - playerHeight - 20) {
           bullet.y = canvas.height + 10;
           lives--;
           if (lives <= 0) {
               gameOver();
           }
       }
   });

   enemies.forEach(enemy => {
       if (enemy.status === 1 && enemy.y + enemyHeight > canvas.height - playerHeight - 10 && enemy.x + enemyWidth > playerX && enemy.x < playerX + playerWidth) {
           lives--;
           enemy.status = 0;
           if (lives <= 0) {
               gameOver();
           }
       }
   });
}

function gameOver() {
   messageElement.innerText = 'Game Over!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

function winGame() {
   messageElement.innerText = 'You Win!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

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

   if (enemies.every(enemy => enemy.status === 0)) {
       winGame();
   }

   movePlayer();
   moveBullets();
   shootBullet();
   enemyShoot();
   moveEnemies();
   detectCollisions();
   draw();
}

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

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;
playerX = (canvas.width - playerWidth) / 2;
draw();
</script>

PRO GAMER

Copy CUSTOM Code

        

<!--- PAGE INVADER 1.0 -->

<style>
   #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;
   }
   #message {
       color: #fff;
       font-size: 24px;
       font-family: 'PixelFont', sans-serif;
       position: absolute;
       display: none;
   }
   @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">Score: 0 | Lives: 3</div>
   <div id="message"></div>
   <canvas id="gameCanvas"></canvas>
   <button id="startButton">START</button>
   <div id="mobileControls" style="display: none;">
       <button id="moveLeftButton">←</button>
       <button id="moveRightButton">→</button>
       <button id="shootButton">Shoot</button>
   </div>
</div>


<script>
let canvasColor = '#000';
let playerColor = '#fff';
let enemyColor = '#ff0000';
let bulletColor = '#00ff00';
let borderColor = '#fff';

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const playerWidth = 50;
const playerHeight = 30;
const bulletWidth = 5;
const bulletHeight = 10;
const enemyWidth = 40;
const enemyHeight = 30;
let playerX = (canvas.width - playerWidth) / 2;
let bullets = [];
let enemies = [];
let enemyBullets = [];
let leftPressed = false;
let rightPressed = false;
let shootPressed = false;
let score = 0;
let lives = 3;
let gameStarted = false;
let enemyDirection = 1; // 1 for right, -1 for left
let messageElement = document.getElementById('message');

function initEnemies() {
   enemies = [];
   for (let row = 0; row < 3; row++) {
       for (let col = 0; col < 8; col++) {
           let x = col * (enemyWidth + 10) + 30;
           let y = row * (enemyHeight + 10) + 30;
           enemies.push({ x: x, y: y, status: 1 });
       }
   }
}

document.addEventListener('keydown', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = true;
   if (e.key === 'ArrowRight') rightPressed = true;
   if (e.key === ' ') {
       shootPressed = true;
       e.preventDefault();  // Prevent space bar from scrolling the page
   }
});
document.addEventListener('keyup', (e) => {
   if (e.key === 'ArrowLeft') leftPressed = false;
   if (e.key === 'ArrowRight') rightPressed = false;
   if (e.key === ' ') shootPressed = false;
});

document.getElementById('moveLeftButton').addEventListener('mousedown', () => leftPressed = true);
document.getElementById('moveLeftButton').addEventListener('mouseup', () => leftPressed = false);
document.getElementById('moveRightButton').addEventListener('mousedown', () => rightPressed = true);
document.getElementById('moveRightButton').addEventListener('mouseup', () => rightPressed = false);
document.getElementById('shootButton').addEventListener('mousedown', () => shootPressed = true);
document.getElementById('shootButton').addEventListener('mouseup', () => shootPressed = false);

function updateColor(element, color) {
   switch (element) {
       case 'canvasColor':
           canvasColor = color;
           document.getElementById('gameContainer').style.backgroundColor = color;
           break;
       case 'playerColor':
           playerColor = color;
           break;
       case 'enemyColor':
           enemyColor = color;
           break;
       case 'bulletColor':
           bulletColor = color;
           break;
       case 'borderColor':
           borderColor = color;
           document.getElementById('gameContainer').style.borderColor = color;
           break;
   }
   draw();
   saveColors();
}

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: ${playerColor} !important;
           }
           #startButton {
               background-color: ${playerColor} !important;
           }
           .player {
               background-color: ${playerColor} !important;
           }
           .enemy {
               background-color: ${enemyColor} !important;
           }
           .bullet {
               background-color: ${bulletColor} !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-2').innerHTML = trimmedCss;
   document.getElementById('add-css-export-3').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;
   playerX = (canvas.width - playerWidth) / 2;
   draw();
}

function drawPlayer() {
   ctx.fillStyle = playerColor;
   ctx.beginPath();
   ctx.moveTo(playerX, canvas.height - playerHeight);
   ctx.lineTo(playerX + playerWidth / 2, canvas.height - playerHeight - 20);
   ctx.lineTo(playerX + playerWidth, canvas.height - playerHeight);
   ctx.closePath();
   ctx.fill();
}

function drawBullet(bullet) {
   ctx.fillStyle = bulletColor;
   ctx.fillRect(bullet.x, bullet.y, bulletWidth, bulletHeight);
}

function drawEnemies() {
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           ctx.fillStyle = enemyColor;
           ctx.beginPath();
           ctx.arc(enemy.x + enemyWidth / 2, enemy.y + enemyHeight / 2, enemyWidth / 2, 0, Math.PI * 2);
           ctx.closePath();
           ctx.fill();
       }
   });
}

function draw() {
   ctx.clearRect(0, 0, canvas.width, canvas.height);
   ctx.fillStyle = canvasColor;
   ctx.fillRect(0, 0, canvas.width, canvas.height);
   drawPlayer();
   bullets.forEach(drawBullet);
   enemyBullets.forEach(drawBullet);
   drawEnemies();
   document.getElementById('score').innerText = `Score: ${score} | Lives: ${lives}`;
}

function movePlayer() {
   if (leftPressed && playerX > 0) playerX -= 5;
   if (rightPressed && playerX < canvas.width - playerWidth) playerX += 5;
}

function moveBullets() {
   bullets.forEach(bullet => bullet.y -= 5);
   bullets = bullets.filter(bullet => bullet.y > 0);

   enemyBullets.forEach(bullet => bullet.y += 5);
   enemyBullets = enemyBullets.filter(bullet => bullet.y < canvas.height);
}

function shootBullet() {
   if (shootPressed) {
       bullets.push({ x: playerX + playerWidth / 2 - bulletWidth / 2, y: canvas.height - playerHeight - 20 });
       shootPressed = false;
   }
}

function enemyShoot() {
   enemies.forEach(enemy => {
       if (enemy.status === 1 && Math.random() < 0.01) {
           enemyBullets.push({ x: enemy.x + enemyWidth / 2 - bulletWidth / 2, y: enemy.y + enemyHeight });
       }
   });
}

function moveEnemies() {
   let moveDown = false;
   enemies.forEach(enemy => {
       if (enemy.status === 1) {
           enemy.x += enemyDirection * 2;
           if (enemy.x + enemyWidth > canvas.width || enemy.x < 0) {
               moveDown = true;
           }
       }
   });
   if (moveDown) {
       enemies.forEach(enemy => {
           enemy.y += 10;
       });
       enemyDirection *= -1;
   }
}

function detectCollisions() {
   bullets.forEach(bullet => {
       enemies.forEach(enemy => {
           if (enemy.status === 1 && bullet.x > enemy.x && bullet.x < enemy.x + enemyWidth && bullet.y > enemy.y && bullet.y < enemy.y + enemyHeight) {
               enemy.status = 0;
               bullet.y = -10;
               score++;
           }
       });
   });

   enemyBullets.forEach(bullet => {
       if (bullet.x > playerX && bullet.x < playerX + playerWidth && bullet.y > canvas.height - playerHeight - 20) {
           bullet.y = canvas.height + 10;
           lives--;
           if (lives <= 0) {
               gameOver();
           }
       }
   });

   enemies.forEach(enemy => {
       if (enemy.status === 1 && enemy.y + enemyHeight > canvas.height - playerHeight - 10 && enemy.x + enemyWidth > playerX && enemy.x < playerX + playerWidth) {
           lives--;
           enemy.status = 0;
           if (lives <= 0) {
               gameOver();
           }
       }
   });
}

function gameOver() {
   messageElement.innerText = 'Game Over!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

function winGame() {
   messageElement.innerText = 'You Win!';
   messageElement.style.display = 'block';
   gameStarted = false;
   setTimeout(() => {
       document.location.reload();
   }, 3000);
}

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

   if (enemies.every(enemy => enemy.status === 0)) {
       winGame();
   }

   movePlayer();
   moveBullets();
   shootBullet();
   enemyShoot();
   moveEnemies();
   detectCollisions();
   draw();
}

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

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;
playerX = (canvas.width - playerWidth) / 2;
draw();

</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.