12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634 |
- <script>
- // import { mapActions, mapState } from 'pinia'
- import { computed } from 'vue'
- import { nextTick } from 'vue'
- import MapGradientBackground from '@components/MapGradientBackground.vue'
- // https://brm.io/matter-js/docs/classes/Engine.html
- import Matter from "matter-js";
- import MatterAttractors from "matter-attractors";
- Matter.use(MatterAttractors);
- import paper from 'paper';
- import { mapState, mapActions } from 'pinia'
- import { ConcernementsStore } from '@/stores/concernements'
- import { CommonStore } from '@/stores/common'
- import ConcernementMapPopup from '@components/ConcernementMapPopup.vue';
- import RecitPlayer from '@components/RecitPlayer.vue';
- // import iconTerraindevie from "@/assets/icons/terraindevie.svg"
- // import iconProximite from "@/assets/icons/proximite.svg"
- // import iconSuperposition from "@/assets/icons/superposition.svg"
- // import iconPuissanceagir from "@/assets/icons/puissancedagir.svg"
- // import iconAction from "@/assets/icons/action_2.svg"
- // import iconDoleancer from "@/assets/icons/doleancer.svg"
- export default {
- data() {
- return {
- canvasMap: {
- canvas: null,
- ctx: null
- },
- animateEvent: new Event('animate'),
- granim: null,
- // MATTER
- engine: null,
- world: null,
- walls: null,
- // PAPERJS
- paper: null,
- //
- mapPopupData: null,
- //
- superpositions_constraints: []
- }
- },
- provide() {
- // https://www.digitalocean.com/community/tutorials/vuejs-vue-html5-canvas
- return {
- // explicitly provide a computed property
- canvasMap: computed(() => this.canvasMap),
- matterEngine: computed(() => this.engine)
- }
- },
- computed: {
- ...mapState(ConcernementsStore,['map_mode',
- 'concernements',
- 'concernementsByID',
- 'opened_concernement',
- 'opened_entite_id',
- 'opened_recit',
- 'allSuperpositions',
- // 'allSuperpositions_bycids',
- 'allSuperpositions_clustered',
- 'allMapItems_byid'
- ]),
- ...mapState(CommonStore,['map_item_ray',
- 'hover_elmt',
- 'paper_symbol_definitions'])
- },
- created() {
- // MATTER
- // create an engine
- let engineOptions = {
- enableSleeping: true,
- timing: {
- //timestamp: 0.5,
- timeScale: 0.5
- },
- // constraintIterations: 20,
- // positionIterations: 20,
- // velocityIterations: 20
- }
- this.engine = Matter.Engine.create(engineOptions);
- this.engine.gravity.scale = 0;
- this.world = this.engine.world;
- // listen for afterUpdate event from Matter.Engine object
- Matter.Events.on(this.engine, "beforeUpdate", this.onBeforeEngineUpdate);
- Matter.Events.on(this.engine, "afterUpdate", this.onAfterEngineUpdate);
- },
- mounted() {
- console.log('map mounted');
- // update the cartouch width reference
- this.setOriginalCartoucheWidth(this.getCartouchWidth());
- this.canvasMap.canvas = this.$refs['canvas-map'];
- this.canvasMap.ctx = this.canvasMap.canvas.getContext('2d');
- let canvas_w = this.canvasMap.canvas.width = this.canvasMap.canvas.parentElement.clientWidth;
- let canvas_h = this.canvasMap.canvas.height = this.canvasMap.canvas.parentElement.clientHeight;
- console.log(`canvas_w: ${canvas_w}, canvas_h: ${canvas_h}`);
- // PAPER
- this.paper = paper.setup(this.canvasMap.canvas);
- // this.paper.view.viewSize = new paper.Size(canvas_w, canvas_h);
- // this resizing is needed for display with pixel ratio more than 1 (retina)
- this.canvasMap.canvas.setAttribute('width', canvas_w);
- this.canvasMap.canvas.setAttribute('height', canvas_h);
- // symbol defintions
- this.initPaperSymbols();
- // use the paper.view click to get back if no items is clicked
- this.paper.view.onClick = function(event) {
- // console.log("view onClick", this, event.target);
- if(event.target._id === "paper-view-0") {
- this.resetConcernementOpened();
- this.$router.push({
- name: 'home',
- hash: `#${this.map_mode}`
- });
- }
- }.bind(this);
- // use the paper.view mousemouve to removed mappopup
- this.paper.view.onMouseMove = function(event) {
- // console.log("view onMouseMove", event.target);
- if(event.target._id === "paper-view-0") {
- this.setHoverElmt(null);
- }
- }.bind(this);
- // MATTER
- this.buildMatterWalls();
- // add mouse control
- // https://github.com/liabru/matter-js/issues/491#issuecomment-331329404
- // this.mouse = Matter.Mouse.create(this.canvasMap.canvas);
- window.addEventListener("resize", this.onWindowResize.bind(this));
- this.animate()
- },
- watch: {
- hover_elmt: {
- handler (n, o) {
- // console.log(`watch hover_elmt map: o, n`, o, n);
- // over highlight effect on paper items
- if (n && n.paper_id) {
- let nitem = paper.project.getItem({id: n.paper_id});
- // console.log('watch hover_element nitem', nitem.definition);
- if (!nitem.is_symbol_instance) { // not symbol instance
- nitem.bringToFront();
- if (nitem.strokeColor) {
- nitem.data.prevStrokeColor = nitem.strokeColor.toCSS(true);
- nitem.strokeColor = "#01ffe2";
- } else {
- nitem.data.prevFillColor = nitem.fillColor.toCSS(true);
- nitem.fillColor = "#01ffe2";
- }
-
- } else { // is a symbol instanceof, then swap
- // console.log(`symbol instance n.type:${n.type}, nitem`, nitem);
- switch (n.type) {
- case 'entite':
- nitem.definition = this.paper_symbol_definitions.entite_hover;
- break;
- case 'besoin':
- nitem.definition = this.paper_symbol_definitions.besoin_hover;
- break;
- case 'reponse':
- nitem.definition = this.paper_symbol_definitions.reponse_hover;
- break;
- case 'entite_action':
- nitem.definition = this.paper_symbol_definitions.entite_action_hover;
- break;
- }
- }
- }
- if (o && o.paper_id && (!n || o.paper_id !== n.paper_id)) {
- let oitem = paper.project.getItem({id: o.paper_id})
- if (oitem) {
- // console.log('watch hover_element oitem', oitem);
- if (!oitem.is_symbol_instance) { // not symbol instance
- if (oitem.data.prevStrokeColor) {
- oitem.strokeColor = oitem.data.prevStrokeColor;
- } else {
- oitem.fillColor = oitem.data.prevFillColor;
- }
- } else { // is a symbol instanceof, then swap
- // console.log(`symbol instance o.type:${o.type}, oitem`, oitem);
- switch (o.type) {
- case 'entite':
- // console.log('this.opened_entite_id', parseInt(this.opened_entite_id), 'oitem.item_id', oitem.item_id);
- if (!this.opened_entite_id || parseInt(this.opened_entite_id) !== oitem.item_id) {
- oitem.definition = this.paper_symbol_definitions.entite;
- }
- break;
- case 'besoin':
- oitem.definition = this.paper_symbol_definitions.besoin;
- break;
- case 'reponse':
- oitem.definition = this.paper_symbol_definitions.reponse;
- break;
- case 'entite_action':
- if (!this.opened_entite_id || parseInt(this.opened_entite_id) !== oitem.item_id) {
- oitem.definition = this.paper_symbol_definitions.entite_action;
- }
- break;
- }
- }
- }
- }
- },
- deep: true
- },
- map_mode: {
- handler (n, o) {
- console.log('concernementMap watch map_mode o n', o, n);
- if (n === 'superposition') { // && !this.opened_concernement
- // create constraints
- this.setSuperpositionsMatterConstraints();
- }else{
- // destroy constraints
- this.clearSuperpositionsMatterConstraints();
- }
- },
- deep: true
- },
- opened_concernement: {
- handler (n, o) {
- console.log('concernementMap watch opened_concernement o n', o, n);
- // if (n && this.map_mode === 'superposition') {
- // this.clearSuperpositionsMatterConstraints();
- // }
- // if(o && !n){
- // this.setSuperpositionsMatterConstraints();
- // }
- },
- deep: true
- },
- allSuperpositions: {
- handler (n, o) {
- console.log('concernementMap watch allSuperpositions', o, n);
- if (this.map_mode === "superposition" && n && n.length) {
- // create constraints with a delay (watch is needed for first page load)
- window.setTimeout(this.setSuperpositionsMatterConstraints, 200);
- }
- // else{
- // // destroy constraints
- // this.clearSuperpositionsMatterConstraints();
- // }
- },
- deep: true
- },
- // opened_concernement: {
- // handler (n, o) {
- // console.log('map opened_concernement', this.opened_concernement);
- // if (this.map_mode === 'superposition' && n) {
- // this.resetSuperpositionsMatterConstraints();
- // }
- // },
- // deep: true
- // }
- },
- methods: {
- ...mapActions(ConcernementsStore,['setMapMode',
- 'resetConcernementOpened']),
- ...mapActions(CommonStore,['addPaperSymbolDefinition',
- 'setHoverElmt',
- 'updateMapItemRay',
- 'setOriginalCartoucheWidth']),
- animate () {
- // if (document.hasFocus()) {
- Matter.Engine.update(this.engine, 1);
- // }
- window.requestAnimationFrame(this.animate);
- },
- buildMatterWalls(){
- console.log('buildMatterWalls');
- // remove old walls if exists
- let oldWallsBody = Matter.Composite.get(this.world, 'walls', 'body');
- if (oldWallsBody) {
- console.log('buildMatterWalls oldWallsBody', oldWallsBody);
- Matter.Composite.remove(this.world, oldWallsBody);
- }
- console.log('buildMatterWalls oldWallsBody after remove', Matter.Composite.get(this.world, 'walls', 'body'));
- // create walls
- let canvas_w = this.canvasMap.canvas.width;
- let canvas_h = this.canvasMap.canvas.height;
- console.log(`buildMatterWalls canvas_w: ${canvas_w}, canvas_h: ${canvas_h}`);
- let length = 10000; // set a length long enought that we don't have to redimmension it when window resize
- let thickness = 1000;
- let pad = 1;
- let wallsParts = [
- // walls
- // Matter.Bodies.rectangle(x, y, width, height, [options])
- Matter.Bodies.rectangle(canvas_w/2, -thickness/2 +pad, length, thickness, { label: 'top_wall'}), // top
- Matter.Bodies.rectangle(canvas_w/2, canvas_h+thickness/2 -pad, length, thickness, { label: 'bottom_wall'}), // bottom
- Matter.Bodies.rectangle(-thickness/2 +pad, canvas_h/2, thickness, length, { label: 'left_wall'}), // left
- Matter.Bodies.rectangle(canvas_w+thickness/2 -pad, canvas_h/2, thickness, length, { label: 'right_wall'}), // right
- // make the items never goes under menus
- // Matter.Bodies.rectangle(500, 25, 1000, 50, { label: 'menutop_wall'}), // menu top
- // Matter.Bodies.rectangle(500, canvas_h-15, 1000, 30, { label: 'menubottom_wall'}) // menu bottom
- ];
- this.walls = Matter.Body.create({
- parts: wallsParts,
- id: 'walls',
- isStatic: true
- });
- Matter.Composite.add(this.world, this.walls);
- console.log('buildMatterWalls this.walls', this.walls);
- },
- updateMatterWalls(){
- let canvas_w = this.canvasMap.canvas.width;
- let canvas_h = this.canvasMap.canvas.height;
- console.log(`buildMatterWalls canvas_w: ${canvas_w}, canvas_h: ${canvas_h}`);
- let thickness = 1000;
- let pad = 10;
- this.walls.parts.forEach((p, i) =>{
- // console.log('p.label', p.label);
- let pos = false;
- switch (p.label) {
- case 'top_wall':
- pos = Matter.Vector.create(canvas_w/2, -thickness/2 +pad)
- break;
- case 'bottom_wall':
- pos = Matter.Vector.create(canvas_w/2, canvas_h+thickness/2 -pad)
- break;
- case 'left_wall':
- pos = Matter.Vector.create(-thickness/2 +pad, canvas_h/2)
- break;
- case 'right_wall':
- pos = Matter.Vector.create(canvas_w+thickness/2 -pad, canvas_h/2)
- break;
- case 'menutop_wall':
- pos = Matter.Vector.create(500, 25)
- break;
- case 'menubottom_wall':
- pos = Matter.Vector.create(500, canvas_h-15)
- break;
- }
- if(pos){
- Matter.Body.setPosition(p, pos);
- }
- })
- },
- onWindowResize(e){
- // console.log('onWindowResize', e);
- // get the new size
- let canvas_w = this.canvasMap.canvas.width = this.canvasMap.canvas.parentElement.clientWidth;
- let canvas_h = this.canvasMap.canvas.height = this.canvasMap.canvas.parentElement.clientHeight;
- console.log(`canvas_w: ${canvas_w}, canvas_h: ${canvas_h}`);
- // apply to paper env
- // paper.view.viewSize.width = canvas_w;
- // paper.view.viewSize.height = canvas_h;
- this.paper.view.viewSize = new paper.Size(canvas_w, canvas_h);
- // this.canvasMap.canvas.setAttribute('width', canvas_w);
- // this.canvasMap.canvas.setAttribute('height', canvas_h);
- // apply to matter env
- // this.buildMatterWalls();
- this.updateMatterWalls();
- // resize the base item ray, this will trigger all the map_items to resize in nextTick()
- this.updateMapItemRay();
- // rebuild all the paper symbols with new ray
- this.initPaperSymbols(true)
- // update the cartouch width reference
- this.setOriginalCartoucheWidth(this.getCartouchWidth());
- },
- getCartouchWidth(){
- let ww = window.clientWidth;
- if (ww > 1500) {
- return 450;
- } else if (ww > 880) {
- return 400;
- } else {
- return 350;
- }
- },
- initPaperSymbols(update){
- this.addPaperSymbolDefinition('boussole_bg', this.setPaperBoussoleBGSymbol());
- this.addPaperSymbolDefinition('puissanceagir_bg', this.setPaperPuissanceagirBGSymbol());
- // this.addPaperSymbolDefinition('puissanceagir_icon', this.setPaperPuissanceagirICONSymbol());
- this.addPaperSymbolDefinition('doleance_bg', this.setPaperDoleanceBGSymbol());
- // this.addPaperSymbolDefinition('doleance_icon', this.setPaperDoleanceICONSymbol());
- if (!update) {
- this.addPaperSymbolDefinition('entite', this.setPaperEntiteSymbol());
- this.addPaperSymbolDefinition('entite_hover', this.setPaperEntiteHoverSymbol());
- this.addPaperSymbolDefinition('entite_inactive', this.setPaperInactiveEntiteSymbol());
- this.addPaperSymbolDefinition('entite_inactive_hover', this.setPaperInactiveEntiteHoverSymbol());
- this.addPaperSymbolDefinition('entite_hidden', this.setPaperHiddenEntiteSymbol());
- this.addPaperSymbolDefinition('entite_action_icon', this.setPaperEntiteActionIconSymbol());
- this.addPaperSymbolDefinition('entite_action', this.setPaperEntiteActionSymbol());
- this.addPaperSymbolDefinition('entite_action_hover', this.setPaperEntiteActionHoverSymbol());
- this.addPaperSymbolDefinition('besoin', this.setPaperBesoinSymbol());
- this.addPaperSymbolDefinition('besoin_hover', this.setPaperBesoinHoverSymbol());
- this.addPaperSymbolDefinition('reponse', this.setPaperReponseSymbol());
- this.addPaperSymbolDefinition('reponse_hover', this.setPaperReponseHoverSymbol());
- }
- },
- setPaperBoussoleBGSymbol(){
- // BOUSSOLE
- let children = [];
- let ray = this.map_item_ray;
- let pos = {x:0, y:0};
- // big invisible global exterior circle to keep center aligned
- children.push(new paper.Path.Circle({
- center: [0, 0],
- radius: ray*3,
- style: {
- strokeColor: 'rgba(255,255,255,0)',
- strokeWidth: 0.5
- }
- }));
- // cercles
- // for (let i = 1; i < 9; i++) {
- // let sw = i === 4 || i === 8 ? 0.25 : 0.1; // width
- // let da = i === 4 || i === 8 ? null : [5,5]; // dash array
- // if (!da) { // draw only 2 main non-dashed circles
- // children.push(new paper.Path.Circle({
- // center: [pos.x, pos.y],
- // radius: ray/8*i,
- // strokeColor: '#fff',
- // strokeWidth: sw,
- // dashArray: da
- // }));
- // }
- // }
- // cercle exterieur
- let ext_circle_factor = 0.915; // be eware that concernement map item also use this factor
- children.push(new paper.Path.Circle({
- center: [pos.x, pos.y],
- radius: ray*ext_circle_factor,
- strokeColor: '#fff',
- strokeWidth: 0.25
- }));
- // cercle interieur
- children.push(new paper.Path.Circle({
- center: [pos.x, pos.y],
- radius: ray*0.51,
- strokeColor: '#fff',
- strokeWidth: 0.25
- }));
- // axes
- // vertical
- children.push(new paper.Path.Line({
- from: [pos.x, pos.y - ray*ext_circle_factor],
- to: [pos.x, pos.y + ray*ext_circle_factor],
- strokeColor: '#fff',
- strokeWidth: 0.25
- }));
- // horizontal
- children.push(new paper.Path.Line({
- from: [pos.x - ray*ext_circle_factor, pos.y],
- to: [pos.x + ray*ext_circle_factor, pos.y],
- strokeColor: '#fff',
- strokeWidth: 0.25
- }))
-
- // fleches
- // haute
- children.push(new paper.Path({
- segments: [
- [pos.x - 8, pos.y - ray*ext_circle_factor + 8],
- [pos.x, pos.y - ray*ext_circle_factor],
- [pos.x + 8, pos.y - ray*ext_circle_factor + 8],
- ],
- strokeWidth: 0.25,
- strokeColor: '#fff',
- }));
- // milieu
- children.push(new paper.Path({
- segments: [
- [pos.x - 8, pos.y + 8],
- [pos.x, pos.y],
- [pos.x + 8, pos.y + 8],
- ],
- strokeWidth: 0.25,
- strokeColor: '#fff',
- }));
- // MOINS - PLUS
- // PLUS
- // horizontal
- children.push(new paper.Path.Line({
- from: [pos.x + ray - 5, pos.y - ray],
- to: [pos.x + ray + 5, pos.y - ray],
- strokeWidth: 2,
- strokeColor: '#fff',
- }))
- // vertical
- children.push(new paper.Path.Line({
- from: [pos.x + ray, pos.y - ray - 5],
- to: [pos.x + ray, pos.y - ray + 5],
- strokeWidth: 2,
- strokeColor: '#fff',
- }))
-
- // MOINS
- // horizontal
- children.push(new paper.Path.Line({
- from: [pos.x - ray - 5, pos.y - ray],
- to: [pos.x - ray + 5, pos.y - ray],
- strokeWidth: 2,
- strokeColor: '#fff',
- }))
- let fontsize = 3;
- let fontFamily = "public_sans";
-
- children.push(new paper.PointText({
- point: [pos.x + 4.5, pos.y - ray],
- content: `entités qui menacent \u2194 entités qui maintiennent`,
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'center',
- fillColor: '#000',
- }))
- children.push(new paper.PointText({
- point: [pos.x - ray, pos.y + 1],
- content: "axe d'intensité",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'right',
- fillColor: '#000',
- }))
- children.push(new paper.PointText({
- point: [pos.x + ray, pos.y - 3],
- content: "situation future\n\u2195\nsituation actuelle",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'left',
- fillColor: '#000',
- }))
- let t1 = new paper.PointText({
- point: [pos.x - ray/8*2.54, pos.y - ray/8*2.54],
- content: "avec prise",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'center',
- fillColor: '#000',
- })
- t1.rotate(-45)
- children.push(t1)
- let t2 = new paper.PointText({
- point: [pos.x - ray/8*3.1, pos.y - ray/8*3.1],
- content: "sans prise",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'center',
- fillColor: '#000',
- })
- t2.rotate(-45)
- children.push(t2)
- return new paper.Group({
- children: children,
- pivot: new paper.Point(pos),
- name: 'boussole_bg',
- // locked: true,
- });
- },
- setPaperPuissanceagirBGSymbol(){
- let children = [];
- let ray = this.map_item_ray;
- let pos = {x:0,y:0};
- // cercles interieur
- for (let i = 1; i < 6; i++) {
- children.push(new paper.Path.Circle({
- center: [pos.x, pos.y],
- radius: (ray/5)*i,
- strokeWidth: 0.25
- }));
- }
- // rayons
- for (let j = 0; j < 16; j++) {
- let a = (360 / 16) * j;
-
- let ext_x = Math.cos(a*(Math.PI/180)) * ray;
- let ext_y = Math.sin(a*(Math.PI/180)) * ray;
- let int_x = Math.cos(a*(Math.PI/180)) * 2;
- let int_y = Math.sin(a*(Math.PI/180)) * 2;
- children.push(new paper.Path.Line({
- from: [pos.x + ext_x, pos.y + ext_y],
- to: [pos.x + int_x, pos.y + int_y],
- strokeWidth: 0.25,
- dashArray: [0.5,1]
- }))
- }
-
- // cercle exterieur
- children.push(new paper.Path.Circle({
- center: [pos.x, pos.y],
- radius: ray,
- strokeWidth: 0.5,
- fillColor: `rgba(255,255,255,0.6)`
- }));
- return new paper.Group({
- children: children,
- pivot: new paper.Point(pos),
- name: 'puissanceagir_bg',
- // locked: true,
- style: {
- strokeColor: '#fff'
- }
- });
- },
- // setPaperPuissanceagirICONSymbol(){
- // let children = [];
- // let svgIcon = paper.project.importSVG(iconPuissanceagir);
- // children.push(svgIcon);
- // svgIcon.position = this.pos;
-
- // return new paper.Group({
- // children: children,
- // pivot: new paper.Point(this.pos),
- // name: 'puissanceagir_icon',
- // locked: true,
- // style: {
- // strokeColor: '#000',
- // strokeWidth: 0.75,
- // fillColor: null
- // }
- // });
- // },
- setPaperDoleanceBGSymbol(){
- let ray = this.map_item_ray;
- let pos = {x:0,y:0};
- var r = ray * 0.8; // ray
- var dr = r/2; // demi ray
- var pcr = 3; // petits cercle rayon
- // https://fr.wikipedia.org/wiki/Trigonom%C3%A9trie#/media/Fichier:Unit_circle_angles_color.svg
- // https://fr.wikipedia.org/wiki/Identit%C3%A9_trigonom%C3%A9trique_pythagoricienne#Preuve_utilisant_le_cercle_unit%C3%A9
- // radians = degrees * (pi/180)
- // degrees = radians * (180/pi)
- // Points for 45° axes
- let m = Math.sin(45*(Math.PI/180)) * r; // x = y for rayon
- let n = Math.sin(45*(Math.PI/180)) * r/2; // x = y for demi rayon
- // console.log('m', m);
- // points for legende arcs
- var lar = r*1.1; // legendes arcs rayon
- let o = Math.cos(22.5*(Math.PI/180)) * lar; // x @ 22.5° for legende arc rayon
- let p = Math.sin(22.5*(Math.PI/180)) * lar; // y @ 22.5° for legende arc rayon
- let q = Math.sin(45*(Math.PI/180)) * lar; // x = y @ 45° for legende arc rayon
- var ltr = lar + 4; // legendes texts rayon
- let o_t = Math.cos(22.5*(Math.PI/180)) * ltr; // x @ 22.5° for legende text rayon
- let p_t = Math.sin(22.5*(Math.PI/180)) * ltr; // y @ 22.5° for legende text rayon
- let q_t = Math.sin(45*(Math.PI/180)) * ltr; // x = y @ 45° for legende text rayon
- let style = {strokeColor: '#fff', strokeWidth: 0.25}
- let felchesstyle = {strokeColor: '#fff', strokeWidth: 0.5}
- let legende_style = {strokeColor: '#000', strokeWidth: 0.25}
- let fontsize = 3;
- let fontFamily = "public_sans";
- let children = [
- // big global exterior circle to keep center aligned
- new paper.Path.Circle({
- center: [0, 0],
- radius: r*3,
- style: {
- strokeColor: 'rgba(255,255,255,0)',
- strokeWidth: 0.5
- }
- }),
- //
- // ARCS EXTERIEURS
- // haut gauche
- new paper.Path.Arc({
- from: [- r, -pcr],
- through: [- m, -m],
- to: [ -pcr, -r],
- style: style
- }),
- // haut droite
- new paper.Path.Arc({
- from: [pcr, -r],
- through: [m, -m],
- to: [r, -pcr],
- style: style
- }),
- // bas droite
- new paper.Path.Arc({
- from: [r, pcr],
- through: [m, m],
- to: [pcr, r],
- style: style
- }),
- // bas gauche
- new paper.Path.Arc({
- from: [-pcr, r],
- through: [-m, m],
- to: [-r, pcr],
- style: style
- }),
- //
- // cercle interieur
- new paper.Path.Circle({
- center: [0, 0],
- radius: dr,
- style: style
- }),
- //
- // petit cercles
- new paper.Path.Circle({
- center: [0, -r],
- radius: pcr,
- style: style
- }),
- new paper.Path.Circle({
- center: [0, r],
- radius: pcr,
- style: {...style, ...{fillColor: 'rgba(255,255,255,0.9)'}},
- }),
- new paper.Path.Circle({
- center: [r, 0],
- radius: pcr,
- style: style
- }),
- new paper.Path.Circle({
- center: [-r, 0],
- radius: pcr,
- style: style
- }),
- //
- // AXES
- // vertical haut
- new paper.Path.Line({
- from: [0, -r + pcr],
- to: [0, -dr],
- style: style
- }),
- // vertical bas
- new paper.Path.Line({
- from: [0, r - pcr],
- to: [0, dr],
- style: style
- }),
- // horizontal gauche
- new paper.Path.Line({
- from: [-r + pcr, 0],
- to: [-dr, 0],
- style: style
- }),
- // horizontal droite
- new paper.Path.Line({
- from: [r - pcr, 0],
- to: [dr, 0],
- style: style
- }),
- //
- // DIAGONALES
- // bas droite
- new paper.Path.Line({
- from: [m, m],
- to: [n, n],
- style: style
- }),
- // bas gauche
- new paper.Path.Line({
- from: [-m, m],
- to: [-n, n],
- style: style
- }),
- // fleches
- // haut
- new paper.Path({
- segments: [
- [-4, -dr*1.5 - 4],
- [0, -dr*1.5],
- [-4, -dr*1.5 + 4]
- ],
- style: felchesstyle
- }),
- // bas
- new paper.Path({
- segments: [
- [4, dr*1.5 - 4],
- [0, dr*1.5],
- [4, dr*1.5 + 4]
- ],
- style: felchesstyle
- }),
- // gauche
- new paper.Path({
- segments: [
- [-dr*1.5 - 4, 4],
- [-dr*1.5, 0],
- [-dr*1.5 + 4, 4]
- ],
- style: felchesstyle
- }),
- // droite
- new paper.Path({
- segments: [
- [dr*1.5 - 4, -4],
- [dr*1.5, 0],
- [dr*1.5 + 4, -4]
- ],
- style: felchesstyle
- }),
- //
- // LEGENDES
- //
- // arc bas gauche 1
- new paper.Path.Arc({
- from: [-pcr, lar],
- through: [-p, o],
- to: [-q + pcr/2, q + pcr/2],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [-p, o],
- to: [-p_t, o_t],
- style: legende_style
- }),
- //text
- new paper.PointText({
- point: [-p_t - 1, o_t],
- content: "2. Enquête menée\nsur le terrain de vie",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'right'
- }),
- // arc bas gauche 2
- new paper.Path.Arc({
- from: [-q - pcr/2, q - pcr/2],
- through: [-o, p],
- to: [-lar, pcr],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [-o, p],
- to: [-o_t, p_t],
- style: legende_style
- }),
- // texte
- new paper.PointText({
- point: [-o_t - 1, p_t],
- content: "3. Construction de groupes d'intérets\navec qui composer la doléance",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'right'
- }),
- // arc haut gauche
- new paper.Path.Arc({
- from: [-lar, -pcr],
- through: [-q, -q],
- to: [-pcr, -lar],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [-q, -q],
- to: [-q_t, -q_t],
- style: legende_style
- }),
- // texte
- new paper.PointText({
- point: [-q_t - 1, -q_t],
- content: "5. Réception et traitement\nde la doléance",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'right'
- }),
- // arc haut droite
- new paper.Path.Arc({
- from: [pcr, -lar],
- through: [q, -q],
- to: [lar, -pcr],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [q, -q],
- to: [q_t, -q_t],
- style: legende_style
- }),
- // texte
- new paper.PointText({
- point: [q_t + 1, -q_t],
- content: "7. Mise-en-œuvre\nde la décision",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'left'
- }),
- // arc bas droite 1
- new paper.Path.Arc({
- from: [lar, pcr],
- through: [o, p],
- to: [q + pcr/2, q - pcr/2],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [o, p],
- to: [o_t, p_t],
- style: legende_style
- }),
- // texte
- new paper.PointText({
- point: [o_t + 1, p_t],
- content: "9. Réception et application\nde la décision",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'left'
- }),
- // arc bas droite 2
- new paper.Path.Arc({
- from: [q - pcr/2, q + pcr/2],
- through: [p, o],
- to: [pcr, lar],
- style: legende_style
- }),
- // tiret
- new paper.Path.Line({
- from: [p, o],
- to: [p_t, o_t],
- style: legende_style
- }),
- // texte
- new paper.PointText({
- point: [p_t + 1, o_t],
- content: "10. Réussite / échec / reprise\ndu cercle politique",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'left'
- }),
- //
- // Points Cardinaux
- //
- // haut
- new paper.Path.Circle({
- center: [0, -r],
- radius: 0.5,
- style: {
- fillColor: '#000'
- }
- }),
- new paper.Path.Line({
- from: [0, -r],
- to: [0, -r - 9],
- style: legende_style
- }),
- new paper.PointText({
- point: [0, -r - 11],
- content: "6. Décision",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'center'
- }),
- // bas
- new paper.Path.Circle({
- center: [0, r],
- radius: 0.5,
- style: {
- fillColor: '#000'
- }
- }),
- new paper.Path.Line({
- from: [0, r],
- to: [0, r + 9],
- style: legende_style
- }),
- new paper.PointText({
- point: [0, r + 14],
- content: "1. Début du cercle\nLe problème\n(injustice, indignation, plainte...)",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'center'
- }),
- // droite
- new paper.Path.Circle({
- center: [r, 0],
- radius: 0.5,
- style: {
- fillColor: '#000'
- }
- }),
- new paper.Path.Line({
- from: [r, 0],
- to: [r + 8, 0],
- style: legende_style
- }),
- new paper.PointText({
- point: [r + 10, -0.5],
- content: "8. Adresse de la décision\nà appliquer",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'left'
- }),
- // gauche
- new paper.Path.Circle({
- center: [-r, 0],
- radius: 0.5,
- style: {
- fillColor: '#000'
- }
- }),
- new paper.Path.Line({
- from: [-r, 0],
- to: [-r - 8, 0],
- style: legende_style
- }),
- new paper.PointText({
- point: [-r - 10, 0.4],
- content: "4. Adresse de la doléance",
- fontSize: fontsize,
- fontFamily: fontFamily,
- justification: 'right'
- }),
- ];
- return new paper.Group({
- children: children,
- pivot: new paper.Point(pos),
- name: 'doleance_bg',
- // locked: true
- });
- },
- // setPaperDoleanceICONSymbol(){
- // let children = [];
- // let svgIcon = paper.project.importSVG(iconDoleancer);
- // children.push(svgIcon);
- // svgIcon.position = this.pos;
- // return new paper.Group({
- // children: children,
- // pivot: new paper.Point(this.pos),
- // name: 'doleance_icon',
- // locked: true,
- // style: {
- // strokeColor: '#000',
- // strokeWidth: 0.75,
- // fillColor: null
- // }
- // });
- // },
- setPaperEntiteSymbol(){
- return new paper.Path.Circle({
- pivot: new paper.Point({x:0,y:0}),
- center: [0,0],
- radius: 0.5, //0.3
- fillColor: '#000',
- strokeColor: 'rgba(255,255,255,0.05)',
- strokeWidth:2
- })
- },
- setPaperEntiteHoverSymbol(){
- return new paper.Path.Circle({
- pivot: new paper.Point({x:0,y:0}),
- center: [0,0],
- radius: 0.5,
- fillColor: '#01ffe2',
- strokeColor: 'rgba(255,255,255,0.05)',
- strokeWidth:2
- })
- },
- setPaperHiddenEntiteSymbol(){
- return new paper.Path.Circle({
- pivot: new paper.Point({x:0,y:0}),
- center: [0,0],
- radius: 0.7, //0.3
- fillColor: '#fff',
- strokeColor: 'rgba(255,255,255,0.05)',
- strokeWidth:2
- })
- },
- setPaperInactiveEntiteSymbol(){
- return new paper.Path.Circle({
- pivot: new paper.Point({x:0,y:0}),
- center: [0,0],
- radius: 0.5, //0.3
- fillColor: '#F00',
- strokeColor: 'rgba(255,0,0,0.05)',
- strokeWidth:2
- })
- },
- setPaperInactiveEntiteHoverSymbol(){
- // let svgIcon = paper.project.importSVG(iconAction);
- // svgIcon.strokeColor = '#01ffe2';
- // svgIcon.strokeWidth = 0.25;
- // svgIcon.scale(0.15);
- // svgIcon.fillColor = null;
- // svgIcon.position = {x:0, y:0};
- // let circle = new paper.Path.Circle({
- // radius: 3,
- // fillColor: 'rgba(255,255,255,0.05)'
- // })
- // return new paper.Group({
- // children: [circle, svgIcon],
- // name: 'action_icon'
- // });
- let children = [];
- let ray = 0.7; //this.map_item_ray;
- // let pos = {x:0, y:0};
- // let strokewidth = 0.4;
- // children.push(new paper.Path.Line({
- // from: [- ray, ray],
- // to: [ray, - ray],
- // strokeColor: '#01ffe2',
- // strokeWidth: strokewidth
- // }));
- // children.push(new paper.Path.Line({
- // from: [ray, ray],
- // to: [- ray, - ray],
- // strokeColor: '#01ffe2',
- // strokeWidth: strokewidth
- // }));
- children.push(new paper.Path.Circle({
- radius: ray/2,
- fillColor: '#F00'
- }))
- children.push(new paper.Path.Circle({
- radius: ray * 1.2,
- strokeColor: '#01ffe2',
- strokeWidth: 0.2,
- fillColor: 'rgba(0,0,0,0)'
- }))
- children.push(new paper.Path.Circle({
- radius: ray,
- fillColor: 'rgba(255,255,255,0.01)'
- }))
- return new paper.Group({
- children: children,
- name: 'action_icon'
- });
- },
- setPaperEntiteActionIconSymbol(){
- // let svgIcon = paper.project.importSVG(iconAction);
- // svgIcon.strokeWidth = 0.8;
- // svgIcon.scale(0.6);
- // svgIcon.strokeColor = '#000';
- // svgIcon.fillColor = null;
- // svgIcon.position = {x:0, y:0};
- let children = [];
- let ray = 2; //this.map_item_ray;
- let pos = {x:0, y:0};
- children.push(new paper.Path.Line({
- from: [- ray, ray],
- to: [ray, - ray],
- strokeColor: '#000',
- strokeWidth: 1.1
- }));
- children.push(new paper.Path.Line({
- from: [ray, ray],
- to: [- ray, - ray],
- strokeColor: '#000',
- strokeWidth: 1.1
- }));
- return new paper.Group({
- children: children,
- name: 'action_icon'
- });
- },
- setPaperEntiteActionSymbol(){
- // let svgIcon = paper.project.importSVG(iconAction);
- // svgIcon.strokeWidth = 0.25;
- // svgIcon.scale(0.15);
- // svgIcon.strokeColor = '#000';
- // svgIcon.fillColor = null;
- // svgIcon.position = {x:0, y:0};
- let children = [];
- let ray = 1; //this.map_item_ray;
- // let pos = {x:0, y:0};
- // children.push(new paper.Path.Line({
- // from: [- ray, ray],
- // to: [ray, - ray],
- // strokeColor: '#000',
- // strokeWidth: strokewidth
- // }));
- // children.push(new paper.Path.Line({
- // from: [ray, ray],
- // to: [- ray, - ray],
- // strokeColor: '#000',
- // strokeWidth: strokewidth
- // }));
- children.push(new paper.Path.Circle({
- radius: ray/2,
- fillColor: 'rgba(0,0,0,1)'
- }))
- children.push(new paper.Path.Circle({
- radius: ray,
- strokeColor: 'rgba(0,0,0,1)',
- strokeWidth: 0.2,
- fillColor: 'rgba(0,0,0,0)'
- }))
- children.push(new paper.Path.Circle({
- radius: ray,
- fillColor: 'rgba(255,255,255,0.01)'
- }))
- return new paper.Group({
- children: children,
- name: 'action_icon'
- });
- },
- setPaperEntiteActionHoverSymbol(){
- // let svgIcon = paper.project.importSVG(iconAction);
- // svgIcon.strokeColor = '#01ffe2';
- // svgIcon.strokeWidth = 0.25;
- // svgIcon.scale(0.15);
- // svgIcon.fillColor = null;
- // svgIcon.position = {x:0, y:0};
- // let circle = new paper.Path.Circle({
- // radius: 3,
- // fillColor: 'rgba(255,255,255,0.05)'
- // })
- // return new paper.Group({
- // children: [circle, svgIcon],
- // name: 'action_icon'
- // });
- let children = [];
- let ray = 0.7; //this.map_item_ray;
- // let pos = {x:0, y:0};
- // let strokewidth = 0.4;
- // children.push(new paper.Path.Line({
- // from: [- ray, ray],
- // to: [ray, - ray],
- // strokeColor: '#01ffe2',
- // strokeWidth: strokewidth
- // }));
- // children.push(new paper.Path.Line({
- // from: [ray, ray],
- // to: [- ray, - ray],
- // strokeColor: '#01ffe2',
- // strokeWidth: strokewidth
- // }));
- children.push(new paper.Path.Circle({
- radius: ray/2,
- fillColor: '#01ffe2'
- }))
- children.push(new paper.Path.Circle({
- radius: ray,
- strokeColor: '#01ffe2',
- strokeWidth: 0.2,
- fillColor: 'rgba(0,0,0,0)'
- }))
- children.push(new paper.Path.Circle({
- radius: ray,
- fillColor: 'rgba(255,255,255,0.01)'
- }))
- return new paper.Group({
- children: children,
- name: 'action_icon'
- });
- },
- setPaperBesoinSymbol(){
- return new paper.Path({
- pivot: new paper.Point(this.pos),
- segments: [[0, -1],[1, 0],[0, 1],[-1, 0],[0, -1]],
- fillColor: '#000'
- })
- },
- setPaperBesoinHoverSymbol(){
- return new paper.Path({
- pivot: new paper.Point(this.pos),
- segments: [[0, -1],[1, 0],[0, 1],[-1, 0],[0, -1]],
- fillColor: '#01ffe2'
- })
- },
- setPaperReponseSymbol(){
- return new paper.Path({
- pivot: new paper.Point(this.pos),
- segments: [[0, -1],[1, 0],[0, 1],[-1, 0],[0, -1]],
- fillColor: '#eee',
- strokeColor: "#000",
- strokeWidth: 0.25,
- })
- },
- setPaperReponseHoverSymbol(){
- return new paper.Path({
- pivot: new paper.Point(this.pos),
- segments: [[0, -1],[1, 0],[0, 1],[-1, 0],[0, -1]],
- fillColor: '#eee',
- strokeColor: "#01ffe2",
- strokeWidth: 0.25,
- })
- },
- async setSuperpositionsMatterConstraints(){
- await nextTick(); // wait for dom to be upadted before applying constraint
- console.log('setSuperpositionsMatterConstraints this.allSuperpositions_clustered', this.allSuperpositions_clustered);
-
- // loop through all supperposition couple
- for(let [cluster_index, cluster] of Object.entries(this.allSuperpositions_clustered)){
-
- for(let [i, cid_eid_A] of cluster.entries()){
- // console.log(`i:${i}, cid_eid_A cid:${cid_eid_A.cid}, eid:${cid_eid_A.eid}`);
- let cid_eid_B = i === cluster.length -1 ? cluster[0] : cluster[i+1];
- // console.log(`i:${i}, cid_eid_B cid:${cid_eid_B.cid}, eid:${cid_eid_B.eid}`);
-
- let concernementA = this.concernementsByID[cid_eid_A.cid];
- // console.log('concernementA', concernementA);
- let concernementB = this.concernementsByID[cid_eid_B.cid];
- // console.log('concernementB', concernementB);
- // console.log('superposition', superposition_id, superposition);
- let mapitemA_id = `${cid_eid_A.cid}___${cluster_index}`
- let mapitemB_id = `${cid_eid_B.cid}___${cluster_index}`
- // console.log(`mapitemA_id: ${mapitemA_id}, mapitemB_id: ${mapitemB_id}`);
-
- let mapitemA = this.allMapItems_byid[mapitemA_id];
- let mapitemB = this.allMapItems_byid[mapitemB_id];
- console.log('mapitemA', mapitemA);
- console.log('mapitemB', mapitemB);
- // get the concernement matter bodies with id
- let bodyA = Matter.Composite.get(this.world, mapitemA_id, 'body'); // matter body id is the same as mapitem_id
- let bodyB = Matter.Composite.get(this.world, mapitemB_id, 'body'); // matter body id is the same as mapitem_id
- // console.log('bodyA, bodyB', bodyA, bodyB);
-
- // get the entite coordinates inside the concernement body
- let pointA = null;
- for(let entiteA of concernementA.revisions_byid[concernementA.active_revision].entites){
- if (entiteA.entite && entiteA.entite.id === cid_eid_A.eid && entiteA.display) {
- // console.log('entiteA', entiteA);
- let scale = mapitemA.scale;
- console.log(`mapitemA.scale ${concernementA.id}`, scale);
- pointA = Matter.Vector.create(entiteA.display.pos.x * scale, entiteA.display.pos.y * scale);
- break;
- }
- }
- let pointB = null;
- for(let entiteB of concernementB.revisions_byid[concernementB.active_revision].entites){
- if (entiteB.entite && entiteB.entite.id === cid_eid_B.eid && entiteB.display) {
- // console.log('entiteB', entiteB);
- let scale = mapitemB.scale;
- console.log(`mapitemB.scale ${concernementB.id}`, scale);
- pointB = Matter.Vector.create(entiteB.display.pos.x * scale, entiteB.display.pos.y * scale);
- break;
- }
- }
-
- // console.log(`pointA:`, pointA,` pointB:`, pointB);
- if (bodyA && bodyB && pointA && pointB) {
- let c = Matter.Constraint.create({
- bodyA: bodyA,
- pointA: pointA,
- bodyB: bodyB,
- pointB: pointB,
- stiffness: 1,
- length: 0,
- damping: 1,
- concernementA: concernementA,
- concernementB: concernementB
- });
- this.superpositions_constraints.push(c);
- Matter.Composite.add(this.world, c);
- // keep a link the constraint into the concernement object (useful for tweening the constraint pointA & pointB in concernementMapItem)
- if(!concernementA.superposition_constraints_id[mapitemA_id]){
- concernementA.superposition_constraints_id[mapitemA_id] = [];
- }
- concernementA.superposition_constraints_id[mapitemA_id].push(c.id);
- if(!concernementB.superposition_constraints_id[mapitemB_id]){
- concernementB.superposition_constraints_id[mapitemB_id] = [];
- }
- concernementB.superposition_constraints_id[mapitemB_id].push(c.id);
- // record all superposed concernements for each concernement
- if (concernementA.all_superposed_concernements_id.indexOf(concernementB.id) < 0) {
- concernementA.all_superposed_concernements_id.push(concernementB.id);
- }
- if (concernementB.all_superposed_concernements_id.indexOf(concernementA.id) < 0) {
- concernementB.all_superposed_concernements_id.push(concernementA.id);
- }
- // record all superposed concernements for each concernement by mapitem_id
- // A
- if (!concernementA.superposed_mapitem_id_by_mapitem_id[mapitemA_id]) {
- concernementA.superposed_mapitem_id_by_mapitem_id[mapitemA_id] = []
- }
- if (concernementA.superposed_mapitem_id_by_mapitem_id[mapitemA_id].indexOf(mapitemB_id) < 0) {
- concernementA.superposed_mapitem_id_by_mapitem_id[mapitemA_id].push(mapitemB_id);
- }
- // B
- if (!concernementB.superposed_mapitem_id_by_mapitem_id[mapitemB_id]) {
- concernementB.superposed_mapitem_id_by_mapitem_id[mapitemB_id] = []
- }
- if (concernementB.superposed_mapitem_id_by_mapitem_id[mapitemB_id].indexOf(mapitemA_id) < 0) {
- concernementB.superposed_mapitem_id_by_mapitem_id[mapitemB_id].push(mapitemA_id);
- }
- }
- }
- }
- },
- clearSuperpositionsMatterConstraints(){
- console.log('clearSuperpositionsMatterConstraints', this.superpositions_constraints);
- for(let constraint of this.superpositions_constraints){
-
- // Delete superposition constraints ids recorded in concernement object
- ['A', 'B'].forEach(ab => {
- for( let [mapitem_id, constraint_ids] of Object.entries(constraint[`concernement${ab}`].superposition_constraints_id)){
- let indexes = Object.keys(constraint_ids);
- indexes.forEach(i => {
- if(constraint_ids[i] === constraint.id) {
- delete constraint[`concernement${ab}`].superposition_constraints_id[mapitem_id][i];
- }
- })
- }
- });
-
- Matter.Composite.remove(this.world, constraint, true);
- }
- this.superpositions_constraints = [];
- },
- // resetSuperpositionsMatterConstraints(){
- // this.clearSuperpositionsMatterConstraints();
- // this.setSuperpositionsMatterConstraints();
- // },
- onBeforeEngineUpdate(){
- },
- onAfterEngineUpdate(){
- // // START OF DEBUGGING
- // this.debugDrawConstraints()
- // this.debugDrawWalls()
- // // END OF DEBUGGING
- },
- debugDrawConstraints(){
- // draw lines of constraints for debuging
- let constraints_lines = this.paper.project.getItem({name: 'constraints_lines', class: paper.Group});
- if (constraints_lines) {
- constraints_lines.removeChildren();
- }else{
- constraints_lines = new paper.Group({
- pivot: new paper.Point({x:0,y:0}),
- name: 'constraints_lines',
- });
- }
- let all_constrains = Matter.Composite.allConstraints(this.world);
- let children = [];
- for(let constraint of all_constrains){
- // console.log('constrain', constraint);
- let pointAWorld = Matter.Constraint.pointAWorld(constraint);
- let pointBWorld = Matter.Constraint.pointBWorld(constraint);
- // console.log('pointAWorld, pointBWorld', pointAWorld, pointBWorld);
- children.push(new paper.Path.Line({
- from: [pointAWorld.x, pointAWorld.y],
- to: [pointBWorld.x, pointBWorld.y],
- strokeColor: '#f00',
- strokeWidth: 1
- }));
- }
- constraints_lines.addChildren(children);
- },
- debugDrawWalls(){
- let wall_rects = this.paper.project.getItem({name: 'wall_rects', class: paper.Group});
- if (wall_rects) {
- wall_rects.removeChildren();
- }else{
- wall_rects = new paper.Group({
- pivot: new paper.Point({x:0,y:0}),
- name: 'wall_rects',
- });
- }
- let wallsbody = Matter.Composite.get(this.world, 'walls', 'body');
- if (wallsbody) {
- // console.log('wallsbody', wallsbody.parts);
- let children = [];
- wallsbody.parts.forEach((part, i) => {
- if(i > 0){
- // console.log('part', part.label, part.bounds.min);
- children.push(new paper.Path.Rectangle({
- from: part.bounds.min,
- to: part.bounds.max,
- strokeColor: '#00f',
- strokeWidth: 2
- }));
- }
- });
- wall_rects.addChildren(children);
- }
- }
- },
- beforeUpdate () {
- },
- components: {
- MapGradientBackground,
- ConcernementMapPopup,
- RecitPlayer
- }
- }
- </script>
- <template>
- <div id="map-backgrounds">
- <MapGradientBackground />
- </div>
- <!-- <div id="map-matter">
- <canvas ref="canvas-engine"></canvas>
- </div> -->
- <div id="map-concernements">
- <canvas ref="canvas-map"></canvas>
- <slot></slot>
- </div>
- <nav id="map-nav">
- <ul>
- <li>
- <a
- title="terrain de vie" href="#terraindevie" @click="setMapMode('terraindevie')"
- :class="{active: map_mode === 'terraindevie'}"
- >
- <span class="icon terraindevie"/> <span class="label"> terrain de vie</span>
- </a>
- </li>
- <li>
- <a
- title="proximite" href="#proximite" @click="setMapMode('proximite')"
- :class="{ disabled: opened_concernement && !opened_concernement.has_proximites, active: map_mode === 'proximite'}"
- >
- <span class="icon proximite"/> <span class="label"> proximité</span>
- </a>
- </li>
- <li>
- <a
- title="superposition" href="#superposition" @click="setMapMode('superposition')"
- :class="{ disabled: opened_concernement && !opened_concernement.has_superpositions, active: map_mode === 'superposition'}"
- >
- <span class="icon superposition"/> <span class="label"> superposition</span>
- </a>
- </li>
- <li>
- <a
- title="puissance d'agir" href="#puissancedagir" @click="setMapMode('puissancedagir')"
- :class="{
- disabled: opened_concernement && !opened_concernement.has_puissancedagir && !opened_concernement.can_update,
- active: map_mode === 'puissancedagir'}"
- >
- <span class="icon puissancedagir"/> <span class="label"> puissance d'agir</span>
- </a>
- </li>
- <li>
- <a
- title="action" href="#action" @click="setMapMode('action')"
- :class="{ disabled: opened_concernement && !opened_concernement.has_agissantes, active: map_mode === 'action'}"
- >
- <span class="icon action"/> <span class="label"> action</span>
- </a>
- </li>
- <li>
- <a
- title="cercle politique" href="#doleancer" @click="setMapMode('doleancer')"
- :class="{ disabled: opened_concernement && !opened_concernement.has_doleance, active: map_mode === 'doleancer'}"
- >
- <span class="icon doleancer"/> <span class="label"> cercle politique</span>
- </a>
- </li>
- </ul>
- </nav>
- <RecitPlayer />
- <ConcernementMapPopup
- v-if="hover_elmt && hover_elmt.type !== 'doleance_step' && !hover_elmt.no_popup"
- :infos="hover_elmt"
- />
- </template>
- <style lang="css" scoped>
- </style>
|