Skip to content

Latest commit

 

History

History
78 lines (64 loc) · 1.94 KB

README.md

File metadata and controls

78 lines (64 loc) · 1.94 KB

Hackathon "Labyrinth"

Project architecture

Quick start

  • npm i
  • npm start

Description

This project is an implementation of simple game which is designed to perform a hackathon in JS department teamplayers. The game consists in competition of "TeamPlayers" implemented by participants of hackathon.

The goal of every "TeamPlayer" is to move and find the destination point "JEVEL" item before the others. The board will be rounded with wall and there will be many borders inside.

How to test?

Register your "TeamPlayer" class inside src/players/unit_Player.spec.js and simply run npm test.

"TeamPlayer" class implementation

To implement your "TeamPlayer" create a new file with name TeamPlayer[your-team-number].js in src/players/ and write your magic code following next interface:

import PlayerBot from '../core/PlayerBot';
import {FORWARD, BACKWARD, RIGHT, LEFT} from '../constants/directions';
import {EMPTY, BORDER, PLAYER, JEVEL, WALL} from '../constants/boardFields';

export default class TeamPlayer extends PlayerBot {
  constructor(id) {
    super(id);
  }

  /**
   * Returns direction in which player makes his move
   * @return {string} (FORWARD, BACKWARD, RIGHT, LEFT)
   */
  move() {
    ...
  }

  /**
   * @param {Object} moveResult result of the move in selected direction
   *  {
   *    pass: {Boolean},
   *    finish: {Boolean},
   *    type: {String} one of map field type (EMPTY, BORDER, PLAYER, JEVEL, WALL)
   *   }
   * @return {void}
   */
  setMoveResult(moveResult) {
    ...
  }

  /**
   * Background color of player-bot e.g.: #a7a7a7
   * @return {string}
   */
  getColor() {
    ...
  }

  /**
   * Path (URL) to an logo image - jpg/png 32x32
   * @return {string}
   */
  getAvatar() {
    ...
  }

  /**
   * Nick name to be displayed in Player info panel
   * @return {string}
   */
  getNickname() {
    ...
  }
}