/*
* 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'
import CPointLieDroite from '../objets/CPointLieDroite'
import CMarqueAngleGeometrique from '../objets/CMarqueAngleGeometrique'
import { defaultSurfOpacity } from '../objets/CMathGraphDoc'
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.1, pt1, pt2)
}
OutilDtMed.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
const dimf = app.dimf
const svg = app.svgFigure
const coulfond = app.doc.couleurFond
const coul = app.getCouleur()
const coulRemp = new Color(coul.red, coul.green, coul.blue, defaultSurfOpacity)
// Si app.autoComplete est à true et si la médiatrice n'a pas été déjà créé,et si le milieu du sgement
// n'a pas déjà été créé, on rajoute le milieu, deux segments joignant les extrémités au segment
// deux marques de segment et une marque d'angle droit
const list = app.listePr
const len = list.longueur()
const med = list.get(len - 1) // a été rajouté à liste par OutilObjetPar2Pts.prototype.creeObjet
let mil = new CMilieu(app.listePr, null, false, coul, false, 0, 3, false, '', app.getTaillePoliceNom(),
app.getStylePoint(), false, this.point1, this.point2)
const milieuDejaCree = app.objetDejaCree(mil)
if (milieuDejaCree) mil = milieuDejaCree
else {
list.add(mil)
mil.positionneEtCreeAffichage(false, dimf, svg, coulfond)
}
// On crée un point lié la médiatrice pour pouvoir créer une marque d'angle
const ptlie = new CPointLieDroite(list, null, false, Color.black, false, 3, 0, true, '', app.getTaillePoliceNom(), MotifPoint.petitRond, false, false, 0.25, med)
list.add(ptlie)
ptlie.positionneEtCreeAffichage(false, dimf, svg, coulfond)
const marqAng = new CMarqueAngleGeometrique(list, null, false, coulRemp, false, StyleTrait.stfc(list), app.getStyleMarqueAngle(), 14, ptlie, mil, this.point1, false)
list.add(marqAng)
marqAng.positionneEtCreeAffichage(false, dimf, svg, coulfond)
if (!milieuDejaCree) {
const seg1 = new CSegment(list, null, false, coul, true, app.getStyleTrait(), this.point1, mil)
list.add(seg1)
const seg2 = new CSegment(list, null, false, coul, true, app.getStyleTrait(), this.point2, mil)
list.add(seg2)
const styleTrait = new StyleTrait(list, StyleTrait.styleTraitContinu, 2)
const marque1 = new CMarqueSegment(list, null, false, coul, false, styleTrait, app.getStyleMarqueSegment(), seg1)
list.add(marque1)
const marque2 = new CMarqueSegment(list, null, false, coul, false, styleTrait, app.getStyleMarqueSegment(), seg2)
list.add(marque2)
mil.positionneEtCreeAffichage(false, dimf, svg, coulfond)
seg1.positionneEtCreeAffichage(false, dimf, svg, coulfond)
seg2.positionneEtCreeAffichage(false, dimf, svg, coulfond)
marque1.positionneEtCreeAffichage(false, dimf, svg, coulfond)
marque2.positionneEtCreeAffichage(false, dimf, svg, coulfond)
// On reclasse la mdéiatrice pour qu'un éditeur de nom n'apparaisse pas pour le milieu créé
list.reclasseVersFinAvecDependants(med, svg)
}
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
}
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'
}