A simple, yet fun, Hangman game built using HTML, CSS, and JavaScript. The game allows users to guess words from various categories such as Football Teams, Hollywood, Cities, Animals, and more. The game includes features like a virtual keyboard, a dynamic category display, and a canvas to visually display the hangman. (NOTE- FOR BETTER EXP. OPEN IN FULL SCREEN MODE!!)
Canvas Drawing: A dynamic canvas to draw the hangman as you make incorrect guesses. The game will update the drawing to show the hangman’s progress with each wrong guess.
Virtual Keyboard: A clickable virtual keyboard for input, making it easier to play on touchscreen devices.
Score Tracking: The game tracks and displays the current score and high score.
Category Display: The current category is shown at the top for each round. Categories include various themes such as football teams, movies, cities, and animals.
Sound Effects: Background music and sound effects for actions such as hint and reset, adding to the immersive experience.
The game selects a category from a list of predefined categories. Based on the chosen category, the catagoryName
(category name) is displayed at the top.
Example code snippet for category selection:
var selectCat = function() {
if(chosenCategory === categories[0]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>FOOTBALL TEAMS</span>";
}
else if(chosenCategory === categories[1]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>HOLLYWOOD</span>";
}
else if(chosenCategory === categories[2]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>CITIES</span>";
}
// More categories can be added in the same way...
}
The game uses an HTML5 canvas to visually represent the hangman’s progress. The stickman is drawn as incorrect guesses are made.
var canvas = document.getElementById('stickman');
var ctx = canvas.getContext('2d');
The virtual keyboard allows users to click on the letters to make their guesses. The keyboard is updated as letters are selected, making it easier for users to play on touch devices.
The game is designed to work on various screen sizes. It adjusts automatically to smaller screens such as tablets and mobile devices.
The game features a beautiful gradient background for a visually appealing experience.
body {
background: linear-gradient(to right, #ff7e5f, #feb47b);
}
The game plays background music and sound effects. For example, background music starts when the game is loaded, and hints or reset actions trigger their respective sounds.
To run the game locally:
git clone <repository-url>
index.html
in your browser.
Here is the relevant code for category selection from the JS file:
var selectCat = function() {
if(chosenCategory === categories[0]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>FOOTBALL TEAMS</span>";
}
else if(chosenCategory === categories[1]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>HOLLYWOOD</span>";
}
else if(chosenCategory === categories[2]){
catagoryName.innerHTML = "<span style='font-family:monospace;'>CITIES</span>";
}
// Add more categories...
}
The canvas function helps to draw the hangman dynamically as the player makes incorrect guesses:
var canvas = document.getElementById('stickman');
var ctx = canvas.getContext('2d');
var drawHangman = function(step) {
switch (step) {
case 1: // head
ctx.beginPath();
ctx.arc(50, 50, 10, 0, Math.PI * 2, true); // Draw head
ctx.stroke();
break;
// Draw more parts of the hangman (body, arms, etc.)
}
}
The virtual keyboard is implemented to make it easier for players to input guesses by clicking the onscreen letters.
var keyboard = document.getElementById('keyboard');
keyboard.addEventListener('click', function(event) {
var letter = event.target.innerText;
// Handle letter guessing
});
This Hangman game is a fun way to test your word-guessing skills. With a variety of categories, a dynamic game experience, and visually appealing design, it provides a great user experience. Enjoy playing, and challenge your friends to beat your high score!