Giter VIP home page Giter VIP logo

millionaire-quiz-game's Introduction

Millionaire Quiz Game

A quiz game for Code Institute Javascript Milestone 2 Project

The game is a simplified version of popular TV Quiz Show - Who Wants to be a Millionaire.

Each player has 12 questions to answer - the main prize is €1 Million. During the online game each player can use 3 chances. Each chance will hide 2 incorrect answers from the set.

Link to live project here: Quiz Game


UX

User Stories

  • As a player I'd like to play a game that is easy to use and can be played alone or in a group of friends.
  • I'd like tha game to test my general knowledge in engaging and fun way.
  • As a casual player I'd like the game to be played without a lengthy learning process and without unnecessary steps to start.
  • I'd like the game to be challenging and fun to play for longer period of time.

Structure

  • The player is presented with welcome screen, where she/he can read the rules of the game, start the game with a button or view the high scores table using the second button.
  • When starting the game the player has to enter own name, the game won’t start with an empty field.
  • The player gets some extra time before the timer (45 sec.) starts running. The delay is based on the length of the question (2, 4, 6 seconds).
  • The player is able to re-start the game after failed answer or when the timer runs out. Each event is presented with a modal screen.
  • The player can quit game the game at any stage using "Quit Game" button at the bottom of the game screen.
  • The game uses a database of 547 unique questions so it can be played for a long time before all they are all memorised.

Design

The game uses colorful, cartoon-ish graphics for the user interface. The background imitates a live TV show studio.

Game preview

Wireframes

Welcome Screen

Game Screen

High Scores List

Mobile Layout


Features

  • The game uses a set of questions loaded from the JSON file containing question, 4 answers and correct answer as each record. JSON file contains 547 sets of questions and answers.
  • Using external library chance.js each game generates 12 unique and random numbers between 1 - 547. These numbers are used as indexes to pick questions from the large set. These 12 question make the set for one game.
  • The game has a high score page. It uses localStorage feature of Javascript to save scores on individual machines. The scores are sorted - the best to the worst. The local storage only stores 10 best results and games with less than 2 questions are not saved.

Future plans

  • I would like the game to use some central database to keep the scores globally.
  • A proper game should also have some sound effects and music so that would be another feature I’d like to add at a later stage.

Technologies

The game uses the following:

  1. HTML
  2. CSS with Bootstrap framework
  3. Javascript
  4. JQuery
  5. Chance.js - number generator library
  6. Google Fonts
  7. Font Awesome

Testing

  • The project was built on a local machine using VS Code editor as the main tool. I've used couple of extensions to help me with the code, such as ESlint, Prettier and Live Server to have constant preview of the project. I've used Chrome and Firefox as my testing desktop browsers with their built-in DevTools (mainly Console) to catch any bugs in the code.
  • While writing the JS part of the application I've used console.log extensively to print out the variables, calculations or arrays used for the game. Developer tools were also helpful to preview the contents of the local storage items, normally not accessible to regular user.
  • With the access to all answers I've run the game start to finish couple of times to make sure it is playable and doesn't brake along the way. The game does indeed stop at the 12th question and displays Victory splash screen. All scores above 3 are being recorded to local storage. There's only 1 user input box - Player's name. It won't allow the game to continue without the name being entered. I've asked my family members to play as well to spot any issues I could have missed. I've left a console.log command in my final code to print all 12 questions with answers for each game as a way to test it.

During the development I come across couple of challenging issues:

  • The countdown timer was not running correctly after few questions answered. I've built a function to delay the timer "ticking" to give the player an extra time to read the question and the answers. After the delay the timer would start counting down 45 seconds. The issue was if a player clicks on an answer button during the delay the timer would not reset and start another one on top of the previous. Thus after few questions the timer would run 2x or 3x times faster. The solution for that was to disable the click event for all 4 answer buttons, and only make them "clickable" when the delay ends.
  • Another serious issue was mobile browsers not supporting Jquery .hide and .show functions. I use these 2 functions to hide 2 answer buttons when the player uses the "50:50 Chance" button. When the button is clicked the game hides 2 incorrect answers. This feature was working correctly on desktop browsers, but on mobile devices the buttons would hide but for the next question they would not reset to show all 4 again. I had to switch to special css class instead, which uses "display: none" to hide the items.
  • I've noticed that mobile browsers didn't reset the hover state from the answer buttons. The game does not refresh the page after each question so after a successful answer, the button that was clicked was still highlighted with different colour. Using media queries I was able to fix it.
  • The game was tested on all main browsers (Chrome, Firefox, Safari, Edge) and couple of mobile devices (iPhone, iPad, Samsung Galaxy). All devices display the game correctly.

Jasmine Testing

As per my mentor's request I've included Jasmine testing. This is how the testing was performed:

  • The testing is done using an external library called Jasmine.
  • For testing I've created a new html file test.html which contains links to Jasmine script files, a link to my own main script file script.js and separate file for my tests test.js.
  • I've decided to test a function which calculates a delay of the timer ticking based on the length of the question. The longer it was the bigger the delay should be. My function has couple of "break points" so I wanted to test if particular number of character will fall into the right range, ie. line shorter than 21 characters should return 2 second delay, line shorter than 51 character should return 4 seconds etc.
  • I've started my tests with intension to fail them to make sure the function will not pass incorrect values, so for my first test - the length less than 21 character - I've passed number bigger than 21. If the test pass it would mean a longer question would pick shorter delay. The test failed, so I followed with value smaller than 21 - this time the test passed.
  • I've included more tests to check all break points of my function, to be sure each of 500+ questions behave as expected.
  • This type of testing is an effective way to control the outcome of any function when extra code is being added and complexity of the function grows.

Test file can be found here: test.html | Live preview

Deployment

  • The project is hosted on GitHub repository under this url: Game Repository
  • The live version was created using GitHub pages. To create the live preview I've switched the feature on the settings panel of my repository. When the master branch was selected as the source I was given the published URL of the app.
  • The live preview is updated automatically every time I make a new commit.
  • To clone the project on another machine one can download zip file containing the whole project and run it locally on any install browser using green download button at the top of the github page.
  • The project is built with HTML and Javascript so not extra software is necessary to run it.
  • If the user is familiar with git commands and have git installed on local machine the project can be cloned using this command git clone https://github.com/redlik/millionaire-quiz-game.git
  • git clone command clones the project in its entirety, including all commits so the user can trace all changes going back to start of the project.

Credits

  • The local storage saving functionality was created using James Quick tutorial found on YouTube
  • Shout out to Steve, tutor that helped me with the timer issue

millionaire-quiz-game's People

Contributors

redlik avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.