outils/OutilMesLongLigne.js

/*
 * Created by yvesb on 24/01/2017.
 */
/*
 * 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 NatObj from '../types/NatObjAdd'
import Nat from '../types/Nat'
import CMesureLongueurLigne from '../objets/CMesureLongueurLigne'
import OutilObjetPar1Objet from './OutilObjetPar1Objet'
import AvertDlg from '../dialogs/AvertDlg'
import NomMesureDlg from '../dialogs/NomMesureDlg'
import CMilieu from '../objets/CMilieu'
import Color from '../types/Color'
import MotifPoint from '../types/MotifPoint'
import CValeurAffichee from '../objets/CValeurAffichee'
import StyleEncadrement from '../types/StyleEncadrement'
import CAffLiePt from '../objets/CAffLiePt'
import { getStr } from '../kernel/kernel'
import CValeurAngle from '../objets/CValeurAngle'
export default OutilMesLongLigne
/**
 * Outil servant à créer une droite horizontale
 * @param {MtgApp} app L'application propriétaire
 * @constructor
 */
function OutilMesLongLigne (app) {
  OutilObjetPar1Objet.call(this, app, 'MesLongLigne', 33129, true, Nat.or(NatObj.NPolygone, NatObj.NLigneBrisee))
}

OutilMesLongLigne.prototype = new OutilObjetPar1Objet()

OutilMesLongLigne.prototype.indication = function () {
  return 'indPolOuLig'
}

OutilMesLongLigne.prototype.preIndication = function () {
  return 'MesLongLigne'
}

OutilMesLongLigne.prototype.creeObjet = function (elg) {
  const app = this.app
  const self = this
  this.ligne = elg
  new NomMesureDlg(app, this.tip, function (st) { self.callBackOK(st) }, function () { self.reselect() }, false)
}

OutilMesLongLigne.prototype.callBackOK = function (st) {
  const self = this
  const app = this.app
  const list = app.listePr
  const ligne = this.ligne
  const mes = new CMesureLongueurLigne(list, null, false, st, ligne)
  app.ajouteElement(mes)
  if (app.verifieDernierElement(1)) {
    // On vérifie que les points de la ligne sont bien nommés. Sinon on leur attribue un nom.
    for (let i = 0; i < ligne.colPoints.length; i++) {
      const ptp = ligne.colPoints[i].pointeurSurPoint
      if (ptp.nom === '') {
        ptp.donneNom(list.genereNomPourPoint())
        ptp.updateName(app.svgFigure, true)
      }
    }
    if (app.displayMeasures) {
      const nomSommets = ligne.estDeNature(NatObj.NPolygone) ? ligne.nomSommetsPolygone() : ligne.nomSommets()
      const svg = app.svgFigure
      const dimf = app.dimf
      const coulfond = app.doc.couleurFond
      const pt1 = ligne.colPoints[1].pointeurSurPoint
      const pt2 = ligne.colPoints[2].pointeurSurPoint
      let mil = new CMilieu(list, null, false, Color.black,
        false, 0, 3, true, '', app.pref_TaillePoliceNom,
        MotifPoint.petitRond, false, pt1, pt2)
      const milieuDejaCree = app.objetDejaCree(mil)
      if (milieuDejaCree) {
        mil = milieuDejaCree
      } else {
        list.add(mil)
        mil.positionneEtCreeAffichage(false, dimf, svg, coulfond)
      }
      const affVal = new CValeurAffichee(list, null, false, app.getCouleur(), 0, 0, 0, 0,
        false, mil, app.dys ? 18 : 16, StyleEncadrement.Sans, true, app.doc.couleurFond,
        CAffLiePt.alignHorCent, CAffLiePt.alignVerCent, mes,
        getStr('chinfo73') + ' ' + getStr('de') + ' ' + nomSommets + ' : ', '', 2,
        new CValeurAngle(list, 0), false)
      list.add(affVal)
      mil.positionneEtCreeAffichage(false, dimf, svg, coulfond)
      affVal.positionneEtCreeAffichage(false, dimf, svg, coulfond)
    }
    this.saveFig()
  } else {
    new AvertDlg(app, 'DejaCree', function () {
      self.app.activeOutilCapt()
    })
  }
}

// Pas d'objets visuels ici
OutilMesLongLigne.prototype.ajouteObjetsVisuels = function () {
}

OutilMesLongLigne.prototype.activationValide = function () {
  const list = this.app.listePr
  return list.pointeurLongueurUnite !== null && list.nombreObjetsParNatureVisibles(NatObj.NLigneOuPoly) > 0
}