Skip to content

Commit

Permalink
Merge pull request #209 from praveen-p09/main
Browse files Browse the repository at this point in the history
Added minesweeper game+Bug fixes
  • Loading branch information
shrey141102 authored Jan 7, 2024
2 parents 2bccb41 + f934fe9 commit 9ba583c
Show file tree
Hide file tree
Showing 9 changed files with 171 additions and 4 deletions.
4 changes: 2 additions & 2 deletions Age-calculator/age_cal.html
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Age calculator</title>
<link rel="stylesheet" href="style.css">
<link rel="stylesheet" href="age_cal.css">
</head>
<body>
<div class="container">
Expand All @@ -17,6 +17,6 @@ <h1>Simple Javascript <br><span> age calculator</span></h1>
<p id="result"></p>
</div>
</div>
<script src="script.js"></script>
<script src="age_cal.js"></script>
</body>
</html>
2 changes: 1 addition & 1 deletion Dice-game/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ document.querySelectorAll("img")[1].setAttribute("src", randomImageSource2);

//If player 1 wins
if (randomNumber1 > randomNumber2) {
document.querySelector("h1").innerHTML = "🚩 Play 1 Wins!";
document.querySelector("h1").innerHTML = "🚩 Player 1 Wins!";
}
else if (randomNumber2 > randomNumber1) {
document.querySelector("h1").innerHTML = "Player 2 Wins! 🚩";
Expand Down
23 changes: 23 additions & 0 deletions Minesweeper/Readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Minesweeper

Minesweeper... yep, that old classic game you remember playing on good ol' Windows '95 back in the day (in fact it was implemented in Microsoft's software updates until Windows 8). Minesweeper has its origins in the earliest mainframe games of the 1960s and 1970s. The earliest ancestor of Minesweeper was Jerimac Ratliff's Cube. The basic gameplay style became a popular segment of the puzzle game genre during the 1980s.

Brush up on your Minesweeper history [here](https://en.wikipedia.org/wiki/Minesweeper_(video_game)).

Do you know what an actual Minesweeper is? I didn't either until I read [this](https://en.wikipedia.org/wiki/Minesweeper).

### Basic Gameplay
1. Select your difficulty level.
* Easy = 9x9, 10 mines
* Medium = 16x16, 40 mines
* Hard = 30x30, 160 mines
2. Click anywhere on the board to begin and start the timer.
*The numbers depict how many mines are adjacent to any given cell.
3. Use **"Shift + Click"** to add flags to a cell if you think it's a mine.


### Winning/Losing
* If you hit a mine... game over, homie.
* Win by uncovering all the cells without mines!

(get it... MINE... SWEEPER...?)
19 changes: 19 additions & 0 deletions Minesweeper/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Minesweeper</title>
<link rel="stylesheet" href="style.css">
</head>
<body>

<div style="display:flex; justify-content: center; align-items: center; flex-direction: column;">
<h1>Minesweeper Game</h2>
<div id="board"></div>
</div>

<script src="script.js"></script>
</body>
</html>
83 changes: 83 additions & 0 deletions Minesweeper/script.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
const boardSize = 10;
const totalMines = 20;
let mines = [];
let revealedCells = 0;

function initializeBoard() {
const board = document.getElementById('board');
for (let i = 0; i < boardSize * boardSize; i++) {
const cell = document.createElement('div');
cell.classList.add('cell');
cell.setAttribute('data-index', i);
cell.addEventListener('click', handleCellClick);
board.appendChild(cell);
}

generateMines();
}

function generateMines() {
mines = Array.from({ length: totalMines }, () => Math.floor(Math.random() * (boardSize * boardSize)));
console.log(mines);
}

function handleCellClick(event) {
const clickedIndex = parseInt(event.target.getAttribute('data-index'));
if (mines.includes(clickedIndex)) {
revealMines();
alert('Game Over! You hit a mine.');
} else {
revealCell(clickedIndex);
if (revealedCells === boardSize * boardSize - totalMines) {
alert('Congratulations! You won!');
}
}
}

function revealMines() {
mines.forEach(index => {
const cell = document.querySelector(`.cell[data-index="${index}"]`);
cell.classList.add('mine');
});
}

function revealCell(index) {
const cell = document.querySelector(`.cell[data-index="${index}"]`);
if (!cell.classList.contains('revealed')) {
cell.classList.add('revealed');
revealedCells++;

const mineCount = countAdjacentMines(index);
if (mineCount > 0) {
cell.textContent = mineCount;
} else {
const neighbors = getNeighbors(index);
neighbors.forEach(neighborIndex => revealCell(neighborIndex));
}
}
}

function countAdjacentMines(index) {
const neighbors = getNeighbors(index);
return neighbors.filter(neighborIndex => mines.includes(neighborIndex)).length;
}

function getNeighbors(index) {
const neighbors = [];
const row = Math.floor(index / boardSize);
const col = index % boardSize;

for (let i = -1; i <= 1; i++) {
for (let j = -1; j <= 1; j++) {
const neighborRow = row + i;
const neighborCol = col + j;
if (neighborRow >= 0 && neighborRow < boardSize && neighborCol >= 0 && neighborCol < boardSize) {
neighbors.push(neighborRow * boardSize + neighborCol);
}
}
}

return neighbors;
}

initializeBoard();
36 changes: 36 additions & 0 deletions Minesweeper/style.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
}

#board {
display: grid;
gap: 2px;
grid-template-columns: repeat(10, 30px);
border: 1px solid #ccc;
}

.cell {
width: 30px;
height: 30px;
background-color: #ddd;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
font-weight: bold;
font-size: 14px;
user-select: none;
}

.cell:hover {
background-color: #eee;
}

.mine {
background-color: #f00;
color: #fff;
}
2 changes: 1 addition & 1 deletion MovieApp/Readme.md
Original file line number Diff line number Diff line change
@@ -1 +1 @@
# Movie-App
1 change: 1 addition & 0 deletions PokeDex/style.css
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ body{
background-color: white;
margin: 5px;
padding: 5px;
cursor: pointer;
}

#pokemon-info img{
Expand Down
5 changes: 5 additions & 0 deletions script.js
Original file line number Diff line number Diff line change
Expand Up @@ -382,6 +382,11 @@ const projects = [
discription: "This project can calculate factorial of the very large numbers.",
link: "Factorial-Calculator/index.html",
image: "https://github.com/shrey141102/Javascript-projects/assets/114330097/1c3e626e-40b3-4ee3-9f0c-ab92263d39c3"
},
{ title: "Minesweeper",
discription: "Simple minesweeper game made using HTML, CSS and JS.",
link: "Minesweeper/index.html",
image: ""
}
];

Expand Down

0 comments on commit 9ba583c

Please sign in to comment.