Flatlogic Bot d0003a5a53 final
2025-09-17 16:23:37 +00:00

277 lines
30 KiB
JavaScript

const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
const scoreEl = document.getElementById('score');
const livesEl = document.getElementById('lives');
const gameOverScreen = document.getElementById('gameOverScreen');
const finalScoreEl = document.getElementById('finalScore');
const restartButton = document.getElementById('restartButton');
let score = 0;
let lives = 3;
let gameObjects = [];
let particles = [];
let blade = [];
let lastSpawnTime = 0;
let spawnInterval = 1000;
let gameOver = false;
// Placeholder for image data
const logoImages = {};
const bugImage = {};
// Set canvas dimensions
canvas.width = Math.min(window.innerWidth * 0.9, 1200);
canvas.height = Math.min(window.innerHeight * 0.9, 800);
// --- Base64 Image Data ---
logoImages['python'] = new Image();
logoImages['python'].src = '';
logoImages['javascript'] = new Image();
logoImages['javascript'].src = '';
logoImages['java'] = new Image();
logoImages['java'].src = '';
logoImages['cplusplus'] = new Image();
logoImages['cplusplus'].src = '';
logoImages['rust'] = new Image();
logoImages['rust'].src = '';
logoImages['go'] = new Image();
logoImages['go'].src = '';
bugImage.img = new Image();
bugImage.img.src = '';
// --- Game Object Classes ---
class GameObject {
constructor(x, y, radius, image) {
this.x = x;
this.y = y;
this.radius = radius;
this.image = image;
this.vx = (Math.random() - 0.5) * 4; // Reduced horizontal speed
this.vy = -Math.random() * 10 - 10; // Reduced initial upward velocity
this.gravity = 0.2; // Reduced gravity
this.rotation = 0;
this.rotationSpeed = (Math.random() - 0.5) * 0.1; // Reduced rotation speed
this.isSliced = false;
}
update() {
this.vy += this.gravity;
this.x += this.vx;
this.y += this.vy;
this.rotation += this.rotationSpeed;
// Bounce off left and right walls
if ((this.x - this.radius < 0 && this.vx < 0) || (this.x + this.radius > canvas.width && this.vx > 0)) {
this.vx *= -1;
}
}
draw() {
ctx.save();
ctx.translate(this.x, this.y);
ctx.rotate(this.rotation);
ctx.drawImage(this.image, -this.radius, -this.radius, this.radius * 2, this.radius * 2);
ctx.restore();
}
}
class Particle {
constructor(x, y) {
this.x = x;
this.y = y;
this.vx = (Math.random() - 0.5) * 5;
this.vy = (Math.random() - 0.5) * 5;
this.alpha = 1;
this.size = Math.random() * 5 + 2;
}
update() {
this.x += this.vx;
this.y += this.vy;
this.alpha -= 0.03;
}
draw() {
ctx.fillStyle = `rgba(255, 255, 0, ${this.alpha})`;
ctx.fillRect(this.x, this.y, this.size, this.size);
}
}
// --- Game Logic ---
function spawnObject() {
const radius = Math.random() * 20 + 40; // Random size
const x = Math.random() * canvas.width;
const y = canvas.height + radius;
let obj;
if (Math.random() < 0.2) { // 20% chance of being a bug
obj = new GameObject(x, y, radius, bugImage.img);
obj.isBug = true;
} else {
const logoNames = Object.keys(logoImages);
const randomLogo = logoNames[Math.floor(Math.random() * logoNames.length)];
obj = new GameObject(x, y, radius, logoImages[randomLogo]);
obj.isBug = false;
}
gameObjects.push(obj);
}
function sliceObject(obj, angle) {
obj.isSliced = true;
score += obj.isBug ? 0 : 10;
if (obj.isBug) {
lives--;
if(lives <= 0) {
gameOver = true;
}
}
// Create two halves
const createHalf = (rotationOffset) => {
const half = new GameObject(obj.x, obj.y, obj.radius, obj.image);
half.vy = obj.vy;
half.vx = obj.vx + (Math.random() - 0.5) * 5;
half.rotation = obj.rotation + rotationOffset;
half.isSliced = true; // Prevent re-slicing
return half;
};
const half1 = createHalf(-0.5);
const half2 = createHalf(0.5);
gameObjects.push(half1, half2);
// Create particles
for (let i = 0; i < 20; i++) {
particles.push(new Particle(obj.x, obj.y));
}
}
function updateUI() {
scoreEl.textContent = `Score: ${score}`;
livesEl.textContent = `Lives: ${lives}`;
}
function handleGameOver() {
finalScoreEl.textContent = `Your Score: ${score}`;
gameOverScreen.style.display = 'flex';
}
function restartGame() {
score = 0;
lives = 3;
gameObjects = [];
particles = [];
gameOver = false;
gameOverScreen.style.display = 'none';
updateUI();
gameLoop(0);
}
// --- Main Game Loop ---
function gameLoop(timestamp) {
if (gameOver) {
handleGameOver();
return;
}
ctx.clearRect(0, 0, canvas.width, canvas.height);
// Spawn new objects
if (timestamp - lastSpawnTime > spawnInterval) {
spawnObject();
lastSpawnTime = timestamp;
spawnInterval = Math.random() * 1000 + 500;
}
// Update and draw game objects
for (let i = gameObjects.length - 1; i >= 0; i--) {
const obj = gameObjects[i];
obj.update();
obj.draw();
// Remove unsliced fruits if they fall off the bottom
if (obj.y > canvas.height + obj.radius * 2 && !obj.isSliced && !obj.isBug) {
lives--;
if(lives <= 0) {
gameOver = true;
}
gameObjects.splice(i, 1);
}
}
// Update and draw particles
for (let i = particles.length - 1; i >= 0; i--) {
const p = particles[i];
p.update();
p.draw();
if (p.alpha <= 0) {
particles.splice(i, 1);
}
}
// Draw blade trail
if (blade.length > 1) {
ctx.strokeStyle = 'rgba(255, 255, 255, 0.7)';
ctx.lineWidth = 5;
ctx.beginPath();
ctx.moveTo(blade[0].x, blade[0].y);
for (let i = 1; i < blade.length; i++) {
ctx.lineTo(blade[i].x, blade[i].y);
}
ctx.stroke();
}
// Collision detection for slicing
if (blade.length > 1) {
const lastPoint = blade[blade.length - 1];
const prevPoint = blade[blade.length - 2];
for (let i = gameObjects.length - 1; i >= 0; i--) {
const obj = gameObjects[i];
if (obj.isSliced) continue;
const dist = Math.hypot(obj.x - lastPoint.x, obj.y - lastPoint.y);
if (dist < obj.radius) {
const angle = Math.atan2(lastPoint.y - prevPoint.y, lastPoint.x - prevPoint.x);
sliceObject(obj, angle);
gameObjects.splice(i, 1);
}
}
}
updateUI();
requestAnimationFrame(gameLoop);
}
// --- Event Listeners ---
function getMousePos(evt) {
const rect = canvas.getBoundingClientRect();
return {
x: evt.clientX - rect.left,
y: evt.clientY - rect.top
};
}
canvas.addEventListener('mousemove', (e) => {
const pos = getMousePos(e);
blade.push(pos);
if (blade.length > 20) {
blade.shift();
}
});
canvas.addEventListener('mouseleave', () => {
blade = [];
});
restartButton.addEventListener('click', restartGame);
// Start the game
gameLoop(0);