Skip to content

Latest commit

 

History

History
72 lines (60 loc) · 2.73 KB

README.md

File metadata and controls

72 lines (60 loc) · 2.73 KB

Sushi-Go-Round

Link to live webpage:

Demo

demo

Motivations, Thoughts, and Consideration Behind This Project

Inspired by the Nintendo 64 Pokemon Stadium minigames, Sushi-Go-Round lickitung is a modern recreation of the Pokemon minigame with a minesweeper spin.

Features Overview and Technologies Involved

  • HTML5
    • Canvas, game design, animation.
  • Javascript
    • Game logic - point complexity and level difficulty (time intervals).

Altogether, these technologies were incorporated to: (1) Created game animations and player movement using HTML5 canvas. (2) Increased level of difficulty and using setintervals and document event listeners. (3) Developed game logic, point system, and level system using custom made algorithms and Object-Oriented Programming in Javascript.

Configuration and Deployment Instructions:

  1. Download the zip from github
  2. Open terminal
  3. Run "npm start" to run webpack
  4. Open index.html file

Code Snippet of Conveyor Belt Items:

  • To avoid deleting the conveyor belt tiles when popping items off (sushi monster eating): I deep duplicated the original array of the possible positions, which was then called the new array 'orderedPositions'. I used this array to scrambled the possible positions by grabbing a random index, splicing the position from it, and pushing it into the 'scrambledPositions'. This allowed me to remove the glitch that was deleting the tiles with the items that were being eaten.
    const orderedPositions = [];
    const scrambledPositions = [];
    const { allConveyorBeltItems } = this;
    this.possiblePos.forEach((arr) => {
      const mini = [];
      mini.push(arr[0]);
      mini.push(arr[1]);
      orderedPositions.push(mini);
    });
    while (orderedPositions.length !== 0) {
      const random = Math.floor(Math.random() * Math.floor(orderedPositions.length));
      scrambledPositions.push(orderedPositions[random]);
      orderedPositions.splice(random, 1);
    }

    for (let i = 0; i < 6; i += 1) {
      allConveyorBeltItems.push(new Sushi(scrambledPositions[i]));
    }
    for (let i = 6; i < 12; i += 1) {
      allConveyorBeltItems.push(new SushiOne(scrambledPositions[i]));
    }
    for (let i = 12; i < 18; i += 1) {
      allConveyorBeltItems.push(new SushiTwo(scrambledPositions[i]));
    }
    for (let i = 18; i < 23; i += 1) {
      allConveyorBeltItems.push(new Chili(scrambledPositions[i]));
    }
    for (let i = 23; i < 28; i += 1) {
      allConveyorBeltItems.push(new Fish(scrambledPositions[i]));
    }
  }

  drawConveyorBeltItems(context) {
    const { allConveyorBeltItems } = this;
    allConveyorBeltItems.forEach((item) => (
      item.draw(context)
    ));
  }