KEMBAR78
HTML | PDF
0% found this document useful (0 votes)
12 views4 pages

HTML

The document is an HTML file for a dynamic collection game featuring a player that collects items on a canvas. It includes styles for a retro aesthetic, a countdown before the game starts, and functionality for player movement and item collection. The game adjusts difficulty by increasing the number of items and decreasing the interval for item disappearance as the player's score increases.

Uploaded by

vedant.coolk
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as TXT, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
12 views4 pages

HTML

The document is an HTML file for a dynamic collection game featuring a player that collects items on a canvas. It includes styles for a retro aesthetic, a countdown before the game starts, and functionality for player movement and item collection. The game adjusts difficulty by increasing the number of items and decreasing the interval for item disappearance as the player's score increases.

Uploaded by

vedant.coolk
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as TXT, PDF, TXT or read online on Scribd
You are on page 1/ 4

<!

DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Dynamic Collection Game</title>
<style>
body {
margin: 0;
overflow: hidden;
background-color: #000;
font-family: 'Press Start 2P', cursive; /* Retro font */
}
canvas {
display: block;
margin: 0 auto;
}
#startScreen {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: white;
font-size: 40px;
opacity: 1;
transition: opacity 1s;
}
#countdown {
display: none;
font-size: 60px;
}
</style>
<link href="https://fonts.googleapis.com/css2?
family=Press+Start+2P&display=swap" rel="stylesheet"> <!-- Retro font -->
</head>
<body>
<canvas id="gameCanvas"></canvas>
<div id="startScreen">
<div id="introText">Game Starts!</div>
<div id="countdown"></div>
</div>
<script>
const canvas = document.getElementById('gameCanvas');
const ctx = canvas.getContext('2d');
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;

const playerSize = 50;


const playerColor = 'blue';
let playerX = canvas.width / 2 - playerSize / 2;
let playerY = canvas.height / 2 - playerSize / 2;

let numItems = 1;
const itemSize = 30;
let items = [];
let itemColors = ['red', 'green', 'yellow', 'purple', 'orange'];
let score = 0;
let isDragging = false;
let touchStartX = 0;
let touchStartY = 0;

// Difficulty settings
let itemDisappearInterval = 3000; // Starting interval in milliseconds
const minItemDisappearInterval = 1000; // Minimum interval
const intervalDecreasePerScore = 500; // Interval decrease per score point

function initializeItems() {
items = [];
for (let i = 0; i < numItems; i++) {
items.push({
x: Math.random() * (canvas.width - itemSize),
y: Math.random() * (canvas.height - itemSize),
color: itemColors[Math.floor(Math.random() *
itemColors.length)]
});
}
}

function drawBackground() {
const gradient = ctx.createLinearGradient(0, 0, canvas.width,
canvas.height);

// Define colors
gradient.addColorStop(0, '#000000'); // Black
gradient.addColorStop(0.2, '#FFFF00'); // Neon Yellow
gradient.addColorStop(0.4, '#FFA07A'); // Light Orange
gradient.addColorStop(0.6, '#FF4500'); // Dark Orange
gradient.addColorStop(0.8, '#87CEEB'); // Light Blue
gradient.addColorStop(1, '#00FF00'); // Neon Green

ctx.fillStyle = gradient;
ctx.fillRect(0, 0, canvas.width, canvas.height);
}

function drawPlayer() {
ctx.fillStyle = playerColor;
ctx.fillRect(playerX, playerY, playerSize, playerSize);
}

function drawItems() {
items.forEach(item => {
ctx.fillStyle = item.color;
ctx.fillRect(item.x, item.y, itemSize, itemSize);
});
}

function drawScoreboard() {
ctx.fillStyle = 'white'; // Change the text color to white
ctx.font = '24px Arial';
ctx.fillText(`Score: ${score}`, 10, 30);
}

function update() {
const now = Date.now();

// Draw background, player, items, and scoreboard


drawBackground();
drawPlayer();
drawItems();
drawScoreboard();

// Check for collisions


items.forEach((item, index) => {
if (playerX < item.x + itemSize &&
playerX + playerSize > item.x &&
playerY < item.y + itemSize &&
playerY + playerSize > item.y) {
// Collision detected
score++;
items.splice(index, 1); // Remove the collected item
if (items.length === 0) {
// If all items are collected, add new items and increase
difficulty
numItems = Math.min(numItems + 1, 3); // Max 3 items
initializeItems();
itemDisappearInterval = Math.max(minItemDisappearInterval,
itemDisappearInterval - intervalDecreasePerScore);
}
}
});

// Handle item disappearance


if (now - lastItemUpdateTime > itemDisappearInterval) {
initializeItems();
lastItemUpdateTime = now;
}

requestAnimationFrame(update);
}

function startDrag(event) {
isDragging = true;
const touch = event.touches ? event.touches[0] : event;
touchStartX = touch.clientX - playerX;
touchStartY = touch.clientY - playerY;
event.preventDefault();
}

function drag(event) {
if (isDragging) {
const touch = event.touches ? event.touches[0] : event;
playerX = touch.clientX - touchStartX;
playerY = touch.clientY - touchStartY;

// Ensure the player stays within canvas boundaries


playerX = Math.max(0, Math.min(canvas.width - playerSize,
playerX));
playerY = Math.max(0, Math.min(canvas.height - playerSize,
playerY));

event.preventDefault();
}
}

function endDrag() {
isDragging = false;
}

function showStartScreen() {
const startScreen = document.getElementById('startScreen');
const introText = document.getElementById('introText');
const countdown = document.getElementById('countdown');

// Animate the intro text


let scale = 1;
let interval = setInterval(() => {
if (scale >= 10) {
clearInterval(interval);
startCountdown();
return;
}
scale += 0.1;
introText.style.transform = `scale(${scale})`;
}, 50);

function startCountdown() {
introText.style.display = 'none';
countdown.style.display = 'block';
let count = 3;
countdown.textContent = count;
const countdownInterval = setInterval(() => {
count--;
if (count <= 0) {
clearInterval(countdownInterval);
window.location.href = './game.html'; // Redirect after
countdown
} else {
countdown.textContent = count;
}
}, 1000);
}
}

canvas.addEventListener('touchstart', startDrag);
canvas.addEventListener('touchmove', drag);
canvas.addEventListener('touchend', endDrag);

// For desktop support


canvas.addEventListener('mousedown', startDrag);
canvas.addEventListener('mousemove', drag);
canvas.addEventListener('mouseup', endDrag);

// Initialize items and start the game loop


initializeItems();
let lastItemUpdateTime = Date.now();

// Show the start screen animation before starting the game


showStartScreen();
</script>
</body>
</html>

You might also like