objetsAdd/CGrapheSuiteRecAdd.js

/*
 * Created by yvesb on 10/10/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 CGrapheSuiteRec from '../objets/CGrapheSuiteRec'
import CElementLigne from '../objets/CElementLigne'
import GrapheSuiteRecDlg from '../dialogs/GrapheSuiteRecDlg'
import CSegment from '../objets/CSegment'
import { getStr } from '../kernel/kernel'
export default CGrapheSuiteRec

CGrapheSuiteRec.prototype.infoHist = function () {
  return this.getName() + ' : ' + getStr('chinfo88') + ' ' + this.suiteAssociee.nomCalcul + ' ' +
    getStr('chinfo32') + ' ' + this.repereAssocie.getNom()
}

CGrapheSuiteRec.prototype.distancePoint = function (xp, yp, masquage, distmin) {
  let dist, i
  if (!this.existe || (masquage && this.masque)) return -1
  for (i = 1; i <= this.suiteAssociee.indiceDernierTermeExistant; i++) {
    if (i === 1) {
      this.point1.abs.donneValeur(this.suiteAssociee.valeurs[0])
      this.point1.ord.donneValeur(this.suiteAssociee.valeurs[1])
      this.point2.abs.donneValeur(this.suiteAssociee.valeurs[1])
      this.point2.ord.donneValeur(this.suiteAssociee.valeurs[1])
      this.point1.positionne(false, this.dimf)
      this.point2.positionne(false, this.dimf)
      this.seg.positionne(false, this.dimf)
      dist = this.seg.distancePoint(xp, yp, masquage)
      if ((dist !== -1) && (dist < distmin)) return dist
      if (this.traitsDeRappelSurAbscisses) {
        this.point1.abs.donneValeur(this.suiteAssociee.valeurs[0])
        this.point1.ord.donneValeur(0)
        this.point2.abs.donneValeur(this.suiteAssociee.valeurs[0])
        this.point2.ord.donneValeur(this.suiteAssociee.valeurs[1])
        this.point1.positionne(false, this.dimf)
        this.point2.positionne(false, this.dimf)
        this.seg.positionne(false, this.dimf)
        dist = this.seg.distancePoint(xp, yp, masquage)
        if ((dist !== -1) && (dist < distmin)) return dist
      }
    } else {
      this.point1.abs.donneValeur(this.suiteAssociee.valeurs[i - 1])
      this.point1.ord.donneValeur(this.suiteAssociee.valeurs[i - 1])
      this.point2.abs.donneValeur(this.suiteAssociee.valeurs[i - 1])
      this.point2.ord.donneValeur(this.suiteAssociee.valeurs[i])
      this.point1.positionne(false, this.dimf)
      this.point2.positionne(false, this.dimf)
      this.seg.positionne(false, this.dimf)
      dist = this.seg.distancePoint(xp, yp, masquage)
      if ((dist !== -1) && (dist < distmin)) return dist
      this.point1.abs.donneValeur(this.suiteAssociee.valeurs[i - 1])
      this.point1.ord.donneValeur(this.suiteAssociee.valeurs[i])
      this.point2.abs.donneValeur(this.suiteAssociee.valeurs[i])
      this.point2.ord.donneValeur(this.suiteAssociee.valeurs[i])
      this.point1.positionne(false, this.dimf)
      this.point2.positionne(false, this.dimf)
      this.seg.positionne(false, this.dimf)
      dist = this.seg.distancePoint(xp, yp, masquage)
      if ((dist !== -1) && (dist < distmin)) return dist
    }
    if (this.traitsDeRappelSurAbscisses) {
      this.point1.abs.donneValeur(this.suiteAssociee.valeurs[i])
      this.point1.ord.donneValeur(0)
      this.point2.abs.donneValeur(this.suiteAssociee.valeurs[i])
      this.point2.ord.donneValeur(this.suiteAssociee.valeurs[i])
      this.point1.positionne(false, this.dimf)
      this.point2.positionne(false, this.dimf)
      this.seg.positionne(false, this.dimf)
      dist = this.seg.distancePoint(xp, yp, masquage)
      if ((dist !== -1) && (dist < distmin)) return dist
    }
  }
  return -1
}

CGrapheSuiteRec.prototype.depDe4Rec = function (p) {
  if (this.elementTestePourDependDePourRec === p) return this.dependDeElementTestePourRec
  return this.memDep4Rec(CElementLigne.prototype.depDe4Rec.call(this, p) ||
    this.suiteAssociee.depDe4Rec(p) || this.repereAssocie.depDe4Rec(p))
}

CGrapheSuiteRec.prototype.modifiableParMenu = function () {
  return !this.estElementFinal
}

CGrapheSuiteRec.prototype.modifDlg = function (app, callBack1, callBack2) {
  new GrapheSuiteRecDlg(app, this, true, true, callBack1, callBack2)
}

/**
 * Fonction appelée par l'outil de création de graphe de suite récurrente
 * et associant aux points utilisés de façon interne le repère
 */
CGrapheSuiteRec.prototype.updateObjetsInternes = function () {
  const rep = this.repereAssocie
  this.point1.rep = rep
  this.point2.rep = rep
}

// Modifié par rapport à la version Java
/**
 * Fonction utilisée pour générer un nom pour le protocole de la figure
 * @returns {string}Le nom généré
 */
CGrapheSuiteRec.prototype.genereNom = function () {
  CGrapheSuiteRec.ind++
  return getStr('rgsr') + CGrapheSuiteRec.ind
}

CGrapheSuiteRec.prototype.tikz = function (dimf, nomaff, coefmult, bu) {
  let ch = ''
  const point1 = this.point1
  const point2 = this.point2
  const seg = new CSegment(this.listeProprietaire, null, false, this.couleur, false, this.style, point1, point2)
  const suiteAssociee = this.suiteAssociee
  seg.donneCouleur(this.couleur)
  seg.donneStyle(this.style)
  for (let i = 1; i <= this.suiteAssociee.indiceDernierTermeExistant; i++) {
    if (i === 1) {
      point1.abs.donneValeur(suiteAssociee.valeurs[0])
      point1.ord.donneValeur(suiteAssociee.valeurs[1])
      point2.abs.donneValeur(suiteAssociee.valeurs[1])
      point2.ord.donneValeur(suiteAssociee.valeurs[1])
      point1.positionne(false, dimf)
      point2.positionne(false, dimf)
      seg.positionne(false, dimf)
      if (seg.existe && !seg.horsFenetre) ch += seg.tikz(dimf, nomaff, coefmult, bu) + '\n'
      if (this.traitsDeRappelSurAbscisses) {
        point1.abs.donneValeur(suiteAssociee.valeurs[0])
        point1.ord.donneValeur(0)
        point2.abs.donneValeur(suiteAssociee.valeurs[0])
        point2.ord.donneValeur(suiteAssociee.valeurs[1])
        point1.positionne(false, dimf)
        point2.positionne(false, dimf)
        seg.positionne(false, dimf)
        if (seg.existe && !seg.horsFenetre) ch += seg.tikz(dimf, false, coefmult, bu) + '\n'
      }
    } else {
      point1.abs.donneValeur(suiteAssociee.valeurs[i - 1])
      point1.ord.donneValeur(suiteAssociee.valeurs[i - 1])
      point2.abs.donneValeur(suiteAssociee.valeurs[i - 1])
      point2.ord.donneValeur(suiteAssociee.valeurs[i])
      point1.positionne(false, dimf)
      point2.positionne(false, dimf)
      seg.positionne(false, dimf)
      if (seg.existe && !seg.horsFenetre) ch += seg.tikz(dimf, nomaff, coefmult, bu) + '\n'
      point1.abs.donneValeur(suiteAssociee.valeurs[i - 1])
      point1.ord.donneValeur(suiteAssociee.valeurs[i])
      point2.abs.donneValeur(suiteAssociee.valeurs[i])
      point2.ord.donneValeur(suiteAssociee.valeurs[i])
      point1.positionne(false, dimf)
      point2.positionne(false, dimf)
      seg.positionne(false, dimf)
      if (seg.existe && !seg.horsFenetre) ch += seg.tikz(dimf, false, coefmult, bu) + '\n'
    }
    if (this.traitsDeRappelSurAbscisses) {
      point1.abs.donneValeur(suiteAssociee.valeurs[i])
      point1.ord.donneValeur(0)
      point2.abs.donneValeur(suiteAssociee.valeurs[i])
      point2.ord.donneValeur(suiteAssociee.valeurs[i])
      point1.positionne(false, dimf)
      point2.positionne(false, dimf)
      seg.positionne(false, dimf)
      if (seg.existe && !seg.horsFenetre) ch += seg.tikz(dimf, false, coefmult, bu) + '\n'
    }
  }
  return ch
}

CGrapheSuiteRec.prototype.estDefiniParObjDs = function (listeOb) {
  return this.suiteAssociee.estDefPar(listeOb) &&
  this.repereAssocie.estDefPar(listeOb)
}