outils/OutilMilieu.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 StyleTrait from '../types/StyleTrait'
import CMarqueSegment from '../objets/CMarqueSegment'
import CMilieu from '../objets/CMilieu'
import CSegment from '../objets/CSegment'
import OutilObjetPar2Pts from './OutilObjetPar2Pts'
export default OutilMilieu
/**
 * Outil servant à créer une droite définie par deux points
 * @param {MtgApp} app L'application propriétaire
 * @constructor
 */
function OutilMilieu (app) {
  OutilObjetPar2Pts.call(this, app, 'Milieu', 32781, true)
}

OutilMilieu.prototype = new OutilObjetPar2Pts()

OutilMilieu.prototype.preIndication = function () {
  return 'Milieu'
}

OutilMilieu.prototype.objet = function (pt1, pt2) {
  const app = this.app
  return new CMilieu(app.listePr, null, false, app.getCouleur(), false, 0, 3, false, '', app.getTaillePoliceNom(),
    app.getStylePoint(), false, pt1, pt2)
}

OutilMilieu.prototype.creeObjet = function () {
  const app = this.app
  const pasDejaCree = OutilObjetPar2Pts.prototype.creeObjet.call(this, !app.autoComplete)
  if (!pasDejaCree) return false
  if (!app.autoComplete) return true
  // Si app.autoComplete est à true et si la perpendiculaire n'a pas été déjà créé, on rajoute une marque
  // d'angle perpendiculaire
  const list = app.listePr
  const len = list.longueur()
  const mil = list.get(len - 1) // a été rajouté à liste par OutilParDtPt.prototype.creeObjet
  // En mode autoComplete on rajoute deux segments joignant les extrémités au milieu et on leur affecte une marque de segment
  const seg1 = new CSegment(list, null, false, app.getCouleur(), true, app.getStyleTrait(), this.point1, mil)
  list.add(seg1)
  const seg2 = new CSegment(list, null, false, app.getCouleur(), true, app.getStyleTrait(), this.point2, mil)
  list.add(seg2)
  const styleTrait = new StyleTrait(list, StyleTrait.styleTraitContinu, 2)
  const marque1 = new CMarqueSegment(list, null, false, app.getCouleur(), false, styleTrait, app.getStyleMarqueSegment(), seg1)
  list.add(marque1)
  const marque2 = new CMarqueSegment(list, null, false, app.getCouleur(), false, styleTrait, app.getStyleMarqueSegment(), seg2)
  list.add(marque2)
  const dimf = app.dimf
  const svg = app.svgFigure
  const coulfond = app.doc.couleurFond
  seg1.positionneEtCreeAffichage(false, dimf, svg, coulfond)
  seg2.positionneEtCreeAffichage(false, dimf, svg, coulfond)
  marque1.positionneEtCreeAffichage(false, dimf, svg, coulfond)
  marque2.positionneEtCreeAffichage(false, dimf, svg, coulfond)
  const seg = new CSegment(list, null, false, app.getCouleur(), false, app.getStyleTrait(), this.point1, this.point2)
  if (!app.objetDejaCree(seg)) {
    list.add(seg)
    seg.positionneEtCreeAffichage(false, dimf, svg, coulfond)
  }
  this.saveFig()
  this.reselect()
  return true
}

OutilMilieu.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 mms = StyleMarqueSegment.marqueSimple
  const mil = this.objet(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 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)
  app.afficheObjetVisuels(0) // Ajout version 6.4.4
}