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.
Do you know what an actual Minesweeper is? I didn't either until I read this.
I remember my first experience with computers in the 90's involved playing this game a lot, so I thought what better game than this to come full circle?
My Version
Getting Started
Play the Game here!
Basic Gameplay
- Select your difficulty level.
- Easy = 9x9, 10 mines
- Medium = 16x16, 40 mines
- Hard = 30x30, 160 mines
- Click anywhere on the board to begin and start the timer.
*The numbers depict how many mines are adjacent to any given cell.
- 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...?)
Technologies Used
The good old Three Amigos:
HTML
As you can see from the source code, the HTML is very concise, as most of the action happens in the JavaScript. Not to mention, the gameboard itself is just a simple table.
CSS
I had a lot of fun styling this to the old look of the Windows '95 desktop view. I still want to mess around with it a bit to get it perrrrfect (couldn't find the exact font used by MS).
My biggest challenge with the CSS was figuring out the table styles (borders, td sizes, etc.)
JavaScript
As this was my first time ever writing a functioning web app using JavaScript, it's not a big surprise that this section was by far the greatest challenge of the project for me.
Here are a couple highlights:
- Dynamically sizing the table when clicking a difficulty level
- I created a function (with the help of Jim, of course) which parses the number from the ID on the table which converts it into a ${size} variable which basically appends rows/cols based on the number it grabs. This concept blew my mind.
- In turn, dynamically creating an array of arrays to match the visual table.
- Creating a "Cell" class which I used to create individual "cell objects" which I assigned a ton of properties to: row#, col#, bomb t/f, # of adjacent bombs (another challenge in and of itself, btw), revealed t/f, and flagged t/f.
- This approach made it a lot easier to write more concise code and not repeat myself over and over, as well as create methods on the class that would run for every cell object.
- Creating a functional timer that displayed the seconds elapsed.
- Randomizing bomb placement on the array.
- Rendering everything in the DOM.
- Assigning click handlers to different events.
- Creating win/lose logic
- Figuring out the control flow of how the functions are all chained together synchronously.
- Learning about recursion and how to properly write a function that creates such an effect.
My Design Choices
I decided to roll with the OG Windows '95 look. I am a firm believer in the "Imitate. Assimilate. Innovate." model of learning, so figured for my first project I needed to walk before I could run and start with the imitation phase of the learning process.
I'm very glad I chose this path, because I learned A LOT by simply trying to match the styles from the original game.
With that said, I am definitely going to create a modernized version of this someday soon.
Next Steps!
This project really was a lot of fun for me. I plan to continue to refine it and refer back to the many lessons learned for years to come.
- Like I mentioned earlier, I would love to make a "display toggle" which flips the CSS to a modernized, clean, flat, minimalist UI.
- There are some stupid little aesthetic bugs that are making me pull my hair out, like how the cell width/height gets tweaked by a few pixels when the board is totally revealed. I need to fix that.
- I would also love to flesh out the Windows '95 thing more, making the Start button do something, add a clock to the bottom right corner, and some functional desktop icons.
- A really difficult feature I would love to tackle would be to make a feature where the user could choose the difficulty by inputing numbers (row/col/mine numbers).
That'll be for a rainy day.
Thank you for reading! I hope you enjoy the game :)