All files / scripts Line.js

73.33% Statements 11/15
87.5% Branches 7/8
100% Functions 3/3
69.23% Lines 9/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56                      1x 1x                           12x 6x 6x 6x               1x                 1x                 1x
/**
 * @author Antonio Raúl Guijarro Contreras <alu0101100494@ull.edu.es>
 * @file Declaración de la clase linea. Hereda de Shape y representa una linea
 * con todas las caracteristicas de Shape + las coordenadas principio=Point() y
 * fin=Point()
 * @copyright Antonio Raúl Guijarro Contreras 2020
 * @since 05.03.2020
 */
 
'use strinc'
 
import Point from './Point.js';
import Shape from './Shape.js';
 
/** 
 * Hereda de Shape y representa una linea con todas las caracteristicas de Shape 
 * las coordenadas principio=Point() y fin=Point().
 * @extends Shape
*/
class Line extends Shape{
  
  /**
   * @param {Point} start punto inicial
   * @param {Point} end punto final
   * @param {boolean} discontinuous Si es discontinua true : false
   */
  constructor(start = new Point(0, 0), end = new Point(0, 0)) {
    super()
    this.start = start;
    this.end = end;
  }
 
  /**
   * Devulve la longitud de la recta
   * @return {Number} Longitud de la recta
   */
  length() {
    return Math.sqrt(Math.pow(this.end.x - this.start.x, 2) + Math.pow(this.end.y - this.start.y, 2));
  }
 
  /* istanbul ignore next   */
  /**
   * Se encarga de dibujar la figura que representa la clase
   * @param {Context} ctx Contexto del canvas, preferiblemente '2d'
   */
  draw(ctx) {
    Iif (ctx != null) {
      this.baseDraw(ctx);
      ctx.moveTo(this.start.x, this.start.y);
      ctx.lineTo(this.end.x, this.end.y);
      ctx.stroke();
    }
  }
};
 
export default Line;