Dinossaur game

The dinossaur game also known as the Chrome Dino is a built-in browser game in the Google Chrome web browser. The player guides a pixelated Tyrannosaurus rex across a side-scrolling landscape, avoiding obstacles. In this tutorial we will explan how to create a basic version of the game using LimonadeJS.

A working example

Source code

var Dinosaur = function() {
// Initializing self.
var self = {
    // Propertie to store the dino element.
    dino: document.getElementById("dino"),
    // Propertie to store the cactus element.
    cactus: document.getElementById("cactus"),
}
/**
 * Self.init is used to initialize some methods and functions.
 */ 
self.init = function() {
  /*
   * Call the function self.Jump() when a key is pressed.
   */ 
  document.addEventListener("keydown", function () {
  self.jump();
  });
  /**
   * This interval will call self.isAlive() at every 10 miliseconds to check 
   * if the dinosaur is already alive.
   * @param {function} self.isAlive - The function that will be called.
   * @param {number} 10 - The number represents the milliseconds of the interval.
   */
  setInterval(self.isAlive, 10);
}
/**
 * Make the dinosaur recieve the class jump, and after the jump, remove it. 
 */ 
self.jump = function() {
    if (dino.classList != "jump") {
    dino.classList.add("jump");
    /**
     * Time out execute a function after 300 milliseconds.
     * @param {function} dino.classList.remove - The function to remove jump class from the dinossaur.
     * @param {number} 300 - The number represents the milliseconds of the timeout.
     */
    setTimeout(function () {
        dino.classList.remove("jump");
    }, 300);
    }
}
/**
 * Cactus recieve a class to make his animation;
 * @param {object} o - The cactus object.
 */
self.play = function (o) {
    o.setAttribute("class", "cactus");
    o.style.display = "";
}
/**
 * Self.isAlive uses an if condition to check the position of
 * the dinosaur and the cactus to detect collision.
 */
self.isAlive = function() {
    // Variable to store the position: of the top of the dino.
    var dinoTop = parseInt(window.getComputedStyle(dino).getPropertyValue("top"));
    // Variable to store the position of the left of the cactus.
    var cactusLeft = parseInt(window.getComputedStyle(cactus).getPropertyValue("left"));
    if (cactusLeft < 50 && cactusLeft > 0 && dinoTop >= 140) {
        alert("Game Over!");
        cactus.classList.remove("cactus");
    }
}
// Game template.
let template = `
    <div class="game" @ready="self.init()">
        <div id="dino"><img src=""></div>
        <div id="cactus" style="display: none"><img src=""></div>
    </div>
    <div class="btn"><button onclick="self.play(cactus)">Play</button></div>`;
    
return lemonade.element(template, self);
}

Acess dinosaur game github here