outils/OutilDtMed.js

/*
 * Created by yvesb on 27/09/2016.
 */
/*
 * MathGraph32 Javascript : Software for animating online dynamic mathematics figures
 * https://www.mathgraph32.org/
 * @Author Yves Biton (yves.biton@sesamath.net)
 * @License: GNU AGPLv3 https://www.gnu.org/licenses/agpl-3.0.html
 */
import Color from '../types/Color'
import StyleMarqueSegment from '../types/StyleMarqueSegment'
import MotifPoint from '../types/MotifPoint'
import StyleTrait from '../types/StyleTrait'
import CDroitePerpendiculaire from '../objets/CDroitePerpendiculaire'
import CMarqueAngleDroit from '../objets/CMarqueAngleDroit'
import CMarqueSegment from '../objets/CMarqueSegment'
import CMediatrice from '../objets/CMediatrice'
import CMilieu from '../objets/CMilieu'
import CSegment from '../objets/CSegment'
import OutilObjetPar2Pts from './OutilObjetPar2Pts'
import StyleMarqueAngle from '../types/StyleMarqueAngle'

export default OutilDtMed

/**
 * Outil servant à créer une médiatrice
 * @param {MtgApp} app L'application propriétaire
 * @constructor
 */
function OutilDtMed (app) {
  OutilObjetPar2Pts.call(this, app, 'DtMed', 32790, true)
}

OutilDtMed.prototype = new OutilObjetPar2Pts()

OutilDtMed.prototype.objet = function (pt1, pt2) {
  const app = this.app
  return new CMediatrice(app.listePr, null, false, app.getCouleur(), false, 0, 0, false, '', app.getTaillePoliceNom(),
    app.getStyleTrait(), 0.9, pt1, pt2)
}

OutilDtMed.prototype.ajouteObjetsVisuels = function () {
  const app = this.app
  const list = app.listeObjetsVisuels
  const b = Color.black
  const stfp = StyleTrait.stfp(list)
  const stfc = StyleTrait.stfc2(list)
  const mil = new CMilieu(list, null, false, b, true, 0, 0, true, '', 13, MotifPoint.petitRond, false, this.point1, app.mousePoint)
  app.ajouteObjetVisuel(mil)
  const seg1 = new CSegment(list, null, false, b, false, stfp, this.point1, mil)
  app.ajouteObjetVisuel(seg1)
  const seg2 = new CSegment(list, null, false, b, false, stfp, mil, app.mousePoint)
  app.ajouteObjetVisuel(seg2)
  const mms = StyleMarqueSegment.marqueSimple
  const ms1 = new CMarqueSegment(list, null, false, b, false, stfc, mms, seg1)
  app.ajouteObjetVisuel(ms1)
  const ms2 = new CMarqueSegment(list, null, false, b, false, stfc, mms, seg2)
  app.ajouteObjetVisuel(ms2)
  // On crée une perpendiculaire plutôt qu'une médiatrice pour pouvoir lui adjoindre
  // une marque d'angle droit
  const dp = new CDroitePerpendiculaire(list, null, false, app.getCouleur(), true, 0, 0, false, '', 13, app.getStyleTrait(), 0.9, mil, seg1)
  app.ajouteObjetVisuel(dp)
  // Création de la marque d'angle droit
  // Modifié version 5?0 pour tenir compte des écrans HD
  const mad = new CMarqueAngleDroit(list, null, false, b, false, stfc, StyleMarqueAngle.marqueSimple, 13, dp)
  app.ajouteObjetVisuel(mad)
  app.afficheObjetVisuels(0) // Ajout version 6.4.4
}

/**
 * Fonction renvoyant true si l'outil accepte qu'on crée un point par défaut lors d'un clic sur un endroit vide
 */
OutilDtMed.prototype.creationPointPossible = function () {
  return true
}

OutilDtMed.prototype.preIndication = function () {
  return 'DtMed'
}