diff --git a/SinglePlayer - Games/Elemental switch/index.html b/SinglePlayer - Games/Elemental switch/index.html new file mode 100644 index 00000000..65b8f394 --- /dev/null +++ b/SinglePlayer - Games/Elemental switch/index.html @@ -0,0 +1,22 @@ + + + + + + Elemental Switch + + + +
+

Elemental Switch

+ +
+ + + +
+

Use arrow keys to move. Switch between elements to overcome obstacles!

+
+ + + diff --git a/SinglePlayer - Games/Elemental switch/script.js b/SinglePlayer - Games/Elemental switch/script.js new file mode 100644 index 00000000..9a994806 --- /dev/null +++ b/SinglePlayer - Games/Elemental switch/script.js @@ -0,0 +1,88 @@ +const canvas = document.getElementById('gameCanvas'); +const ctx = canvas.getContext('2d'); + +let character = { + x: 50, + y: 350, + width: 30, + height: 30, + element: 'fire' +}; + +let obstacles = [ + { x: 200, y: 300, width: 50, height: 50, type: 'fire' }, + { x: 300, y: 200, width: 50, height: 50, type: 'water' }, + { x: 400, y: 100, width: 50, height: 50, type: 'earth' } +]; + +let goal = { x: 550, y: 350, width: 30, height: 30 }; + +function switchElement(element) { + character.element = element; +} + +document.addEventListener('keydown', (e) => { + switch (e.key) { + case 'ArrowUp': character.y -= 10; break; + case 'ArrowDown': character.y += 10; break; + case 'ArrowLeft': character.x -= 10; break; + case 'ArrowRight': character.x += 10; break; + } + checkCollisions(); + drawGame(); +}); + +function checkCollisions() { + obstacles.forEach(obstacle => { + if (character.x < obstacle.x + obstacle.width && + character.x + character.width > obstacle.x && + character.y < obstacle.y + obstacle.height && + character.y + character.height > obstacle.y) { + if (character.element !== obstacle.type) { + alert('Game Over! You hit an obstacle.'); + resetGame(); + } + } + }); + + if (character.x < goal.x + goal.width && + character.x + character.width > goal.x && + character.y < goal.y + goal.height && + character.y + character.height > goal.y) { + alert('You Win! You reached the goal.'); + resetGame(); + } +} + +function resetGame() { + character.x = 50; + character.y = 350; + character.element = 'fire'; + drawGame(); +} + +function drawGame() { + ctx.clearRect(0, 0, canvas.width, canvas.height); + + ctx.fillStyle = getColor(character.element); + ctx.fillRect(character.x, character.y, character.width, character.height); + + obstacles.forEach(obstacle => { + ctx.fillStyle = getColor(obstacle.type); + ctx.fillRect(obstacle.x, obstacle.y, obstacle.width, obstacle.height); + }); + + ctx.fillStyle = 'gold'; + ctx.fillRect(goal.x, goal.y, goal.width, goal.height); +} + +function getColor(element) { + switch (element) { + case 'fire': return 'red'; + case 'water': return 'blue'; + case 'earth': return 'green'; + default: return 'black'; + } +} + +drawGame(); diff --git a/SinglePlayer - Games/Elemental switch/styles.css b/SinglePlayer - Games/Elemental switch/styles.css new file mode 100644 index 00000000..d0dffd77 --- /dev/null +++ b/SinglePlayer - Games/Elemental switch/styles.css @@ -0,0 +1,32 @@ +body { + text-align: center; + font-family: Arial, sans-serif; + background-color: #f0f0f0; +} + +#game { + margin: 20px auto; + width: 600px; + background-color: #ffffff; + padding: 20px; + border-radius: 10px; + box-shadow: 0 0 10px rgba(0,0,0,0.1); +} + +canvas { + border: 1px solid #000; + margin-top: 10px; +} + +button { + margin: 10px; + padding: 10px 20px; + font-size: 16px; + border: none; + border-radius: 5px; + cursor: pointer; +} + +button:active { + transform: scale(0.95); +}