forked from public/foundryvtt-reve-de-dragon
		
	#27 Gestion des rencontres
This commit is contained in:
		| @@ -208,9 +208,9 @@ export class RdDActor extends Actor { | |||||||
|             defenseMsg = RdDUtility.buildDefenseChatCard(this, target, rollData); |             defenseMsg = RdDUtility.buildDefenseChatCard(this, target, rollData); | ||||||
|             explications += "<br><strong>Cible</strong> : " + target.actor.data.name; |             explications += "<br><strong>Cible</strong> : " + target.actor.data.name; | ||||||
|           } |           } | ||||||
|           explications += "<br>Dommages : " + rollData.degats + "<br>Localisation : " + rollData.loc.label; |           explications += "<br>Dégâts : " + rollData.degats + "<br>Localisation : " + rollData.loc.label; | ||||||
|         } else { |         } else { | ||||||
|           explications = "<br>Echec ! Pas de dommages"; |           explications = "<br>Echec ! Pas de dégâts"; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ import { TMRUtility } from "./tmr-utility.js"; | |||||||
| import { RdDRollTables } from "./rdd-rolltables.js"; | import { RdDRollTables } from "./rdd-rolltables.js"; | ||||||
| import { RdDResolutionTable } from "./rdd-resolution-table.js"; | import { RdDResolutionTable } from "./rdd-resolution-table.js"; | ||||||
|  |  | ||||||
|  | /* -------------------------------------------- */ | ||||||
| const tmrConstants = { | const tmrConstants = { | ||||||
|   col1_y: 30, |   col1_y: 30, | ||||||
|   col2_y: 55, |   col2_y: 55, | ||||||
| @@ -16,6 +17,7 @@ const tmrConstants = { | |||||||
|   gridy: 28 |   gridy: 28 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* -------------------------------------------- */ | ||||||
| export class RdDTMRDialog extends Dialog { | export class RdDTMRDialog extends Dialog { | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
| @@ -131,6 +133,11 @@ export class RdDTMRDialog extends Dialog { | |||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   _tellToUser(message) { |   _tellToUser(message) { | ||||||
|  |     ChatMessage.create({ title: "TMR", content: message, user: game.user._id }); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   _tellToGM(message) { | ||||||
|     ChatMessage.create({ title: "TMR", content: message, user: game.user._id, whisper: ChatMessage.getWhisperRecipients("GM") }); |     ChatMessage.create({ title: "TMR", content: message, user: game.user._id, whisper: ChatMessage.getWhisperRecipients("GM") }); | ||||||
|   } |   } | ||||||
|    |    | ||||||
| @@ -360,6 +367,7 @@ export class RdDTMRDialog extends Dialog { | |||||||
|         this._addDemiReve(); |         this._addDemiReve(); | ||||||
|         this.displayPreviousRencontres(); |         this.displayPreviousRencontres(); | ||||||
|         this.displaySortReserve(); |         this.displaySortReserve(); | ||||||
|  |  | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|     if (this.viewOnly) { |     if (this.viewOnly) { | ||||||
| @@ -464,5 +472,6 @@ export class RdDTMRDialog extends Dialog { | |||||||
|     this._setTokenPosition(token); |     this._setTokenPosition(token); | ||||||
|     this.pixiApp.stage.addChild(token.sprite); |     this.pixiApp.stage.addChild(token.sprite); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -439,8 +439,8 @@ export class RdDUtility  { | |||||||
|     else if ( result <= 12 ) txt = "Poitrine, dos"; |     else if ( result <= 12 ) txt = "Poitrine, dos"; | ||||||
|     else if ( result <= 14 ) txt = "Avant-bras, main, coude"; |     else if ( result <= 14 ) txt = "Avant-bras, main, coude"; | ||||||
|     else if ( result <= 18 ) txt = "Epaule, bras, omoplate"; |     else if ( result <= 18 ) txt = "Epaule, bras, omoplate"; | ||||||
|     else if ( result == 19)  txt = "Tête autre"; |     else if ( result == 19)  txt = "Tête"; | ||||||
|     else if ( result == 20)  txt = "Tête visage"; |     else if ( result == 20)  txt = "Tête (visage)"; | ||||||
|      |      | ||||||
|     return { result: result, label: txt }; |     return { result: result, label: txt }; | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -208,16 +208,16 @@ const TMRMapping = { | |||||||
|     } |     } | ||||||
|  |  | ||||||
| const rencontresTable = [ | const rencontresTable = [ | ||||||
|       {name:"Messagers des Rêves", data: { force: "2d4", ignorer: true, derober: true, refoulement: 1, quitterTMR: true,  |       {name:"Messagers des Rêves", data: { force: "2d4", ignorer: true, derober: true, refoulement: 1, quitterTMR: false,  | ||||||
|                                         cite: "01-25", sanctuaire: "01-25", plaines: "01-20", pont: "01-20", collines: "01-15", foret: "01-15", monts: "01-10", desert: "01-10", fleuve: "01-05",  |                                         cite: "01-25", sanctuaire: "01-25", plaines: "01-20", pont: "01-20", collines: "01-15", foret: "01-15", monts: "01-10", desert: "01-10", fleuve: "01-05",  | ||||||
|                                         lac: "01-05", marais: "01-02", gouffre: "01-02", necropole: "00-00", desolation: "00-00" } }, |                                         lac: "01-05", marais: "01-02", gouffre: "01-02", necropole: "00-00", desolation: "00-00" } }, | ||||||
|       {name:"Passeur des Rêves",  data:  { force: "2d4", ignorer: true, derober: true, refoulement: 1, quitterTMR: true,  |       {name:"Passeur des Rêves",  data:  { force: "2d4", ignorer: true, derober: true, refoulement: 1, quitterTMR: false,  | ||||||
|                                           cite: "26-50", sanctuaire: "26-50", plaines: "21-40", pont: "21-40", collines: "16-30", foret: "16-30", monts: "11-20", desert: "11-20", fleuve: "06-10",  |                                           cite: "26-50", sanctuaire: "26-50", plaines: "21-40", pont: "21-40", collines: "16-30", foret: "16-30", monts: "11-20", desert: "11-20", fleuve: "06-10",  | ||||||
|                                           lac: "06-10", marais: "03-04", gouffre: "03-04", necropole: "00-00", desolation: "00-00" } }, |                                           lac: "06-10", marais: "03-04", gouffre: "03-04", necropole: "00-00", desolation: "00-00" } }, | ||||||
|       {name:"Fleur des Rêves", data:     { force: "1d6", ignorer: true, derober: true, refoulement: 1, quitterTMR: true,  |       {name:"Fleur des Rêves", data:     { force: "1d6", ignorer: true, derober: true, refoulement: 1, quitterTMR: false,  | ||||||
|                                         cite: "51-65", sanctuaire: "51-65", plaines: "41-55", pont: "41-55", collines: "31-42", foret: "31-42", monts: "21-26", desert: "21-26", fleuve: "11-13",  |                                         cite: "51-65", sanctuaire: "51-65", plaines: "41-55", pont: "41-55", collines: "31-42", foret: "31-42", monts: "21-26", desert: "21-26", fleuve: "11-13",  | ||||||
|                                        lac: "11-13", marais: "05-05", gouffre: "05-05", necropole: "00-00", desolation: "00-00" } }, |                                        lac: "11-13", marais: "05-05", gouffre: "05-05", necropole: "00-00", desolation: "00-00" } }, | ||||||
|       {name:"Mangeur de Rêve", data:    { force: "1d6", ignorer: false, derober: true, refoulement: 1, quitterTMR: true,  |       {name:"Mangeur de Rêve", data:    { force: "1d6", ignorer: false, derober: true, refoulement: 1, quitterTMR: false,  | ||||||
|                                        cite: "66-70", sanctuaire: "66-70", plaines: "56-60", pont: "56-60", collines: "43-54", foret: "43-54", monts: "27-44", desert: "27-44", fleuve: "14-37",  |                                        cite: "66-70", sanctuaire: "66-70", plaines: "56-60", pont: "56-60", collines: "43-54", foret: "43-54", monts: "27-44", desert: "27-44", fleuve: "14-37",  | ||||||
|                                        lac: "14-37", marais: "06-29", gouffre: "06-29", necropole: "01-20", desolation: "01-20" } }, |                                        lac: "14-37", marais: "06-29", gouffre: "06-29", necropole: "01-20", desolation: "01-20" } }, | ||||||
|       {name:"Changeur de Rêve", data:   { force: "2d6", ignorer: false, derober: true, refoulement: 1, quitterTMR: false,  |       {name:"Changeur de Rêve", data:   { force: "2d6", ignorer: false, derober: true, refoulement: 1, quitterTMR: false,  | ||||||
| @@ -240,9 +240,23 @@ const rencontresTable = [ | |||||||
|                                        lac: "98-00", marais: "98-00", gouffre: "98-00", necropole: "98-00", desolation: "98-00" } }  |                                        lac: "98-00", marais: "98-00", gouffre: "98-00", necropole: "98-00", desolation: "98-00" } }  | ||||||
|       ] |       ] | ||||||
|  |  | ||||||
|  | /* -------------------------------------------- */ | ||||||
|  | const tmrConstants = { | ||||||
|  |   col1_y: 30, | ||||||
|  |   col2_y: 55, | ||||||
|  |   cellw: 55, | ||||||
|  |   cellh: 55, | ||||||
|  |   gridx: 28, | ||||||
|  |   gridy: 28 | ||||||
|  | } | ||||||
|  |  | ||||||
| /* -------------------------------------------- */ | /* -------------------------------------------- */ | ||||||
| export class TMRUtility  { | export class TMRUtility  { | ||||||
|    |    | ||||||
|  |   static getTMRConstants() { | ||||||
|  |     return tmrConstants; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   static convertToTMRCoord( x, y ) |   static convertToTMRCoord( x, y ) | ||||||
|   { |   { | ||||||
| @@ -480,5 +494,43 @@ export class TMRUtility  { | |||||||
|     let caseIndex = letter+num; |     let caseIndex = letter+num; | ||||||
|     console.log("Case ", letterValue, letter, num, TMRMapping[caseIndex].label ); |     console.log("Case ", letterValue, letter, num, TMRMapping[caseIndex].label ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static _checkTMRCoord( x, y ) { | ||||||
|  |     if (x >= 0 && x < 13 && y >= 0 && y < 15  ) return true; | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static computeRealPictureCoordinates( coordXY ) { | ||||||
|  |     let decallagePairImpair = (coordXY.x % 2 == 0) ? tmrConstants.col1_y : tmrConstants.col2_y; | ||||||
|  |     return {  | ||||||
|  |       x: tmrConstants.gridx + (coordXY.x * tmrConstants.cellw), | ||||||
|  |       y: tmrConstants.gridy + (coordXY.y * tmrConstants.cellh) + decallagePairImpair | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   /** Returns a list of case inside a given distance | ||||||
|  |    *  | ||||||
|  |    */ | ||||||
|  |   static getTMRArea( coord, distance ) { | ||||||
|  |     let pos = this.convertToCellCoord( coord );     | ||||||
|  |     let posPic = this.computeRealPictureCoordinates( pos ); | ||||||
|  |     let caseList = []; | ||||||
|  |     for (let x=pos.x-distance; x<=pos.x+distance; x++ ) { // Loop thru lines | ||||||
|  |       for (let y=pos.y-distance; y<=pos.y+distance; y++ ) { // Loop thru lines | ||||||
|  |         //console.log("Parsing position", x, y); | ||||||
|  |         if ( this._checkTMRCoord(x, y) ) { // Coordinate is valie | ||||||
|  |           let posPicNow = this.computeRealPictureCoordinates( {x: x, y: y} ); | ||||||
|  |           let dist = Math.sqrt(Math.pow(posPicNow.x - posPic.x,2) + Math.pow(posPicNow.y - posPic.y, 2)) / tmrConstants.cellw; | ||||||
|  |           if ( dist < distance+0.5) { | ||||||
|  |             caseList.push( this.convertToTMRCoord(x, y) ); // Inside the area | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return caseList; | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
|   "name": "foundryvtt-reve-de-dragon", |   "name": "foundryvtt-reve-de-dragon", | ||||||
|   "title": "Rêve de Dragon", |   "title": "Rêve de Dragon", | ||||||
|   "description": "Rêve de Dragon RPG for FoundryVTT", |   "description": "Rêve de Dragon RPG for FoundryVTT", | ||||||
|   "version": "0.9.62", |   "version": "0.9.63", | ||||||
|   "minimumCoreVersion": "0.7.5", |   "minimumCoreVersion": "0.7.5", | ||||||
|   "compatibleCoreVersion": "0.7.6", |   "compatibleCoreVersion": "0.7.6", | ||||||
|   "templateVersion": 47, |   "templateVersion": 47, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user