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