Subversion Repositories eFlore/Applications.coel-consultation

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
25 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Composant Cartographie gérant les images représentant le fond de carte à insérer dans un fichier html contenant une
5
 * image map.
6
 * Avantage :
7
 *  - pas de base de données liée au composant (simplicité d'utilisation dans les applications)
8
 *  - facilite l'utilisation du Javascript et CSS pour intéragir avec la carte (affichage du nom des zones au survol)
9
 *  - l'application qui utilise le composant définie elle-même l'intéraction avec le clic sur une zone
10
 * Inconvénient :
11
 *  - l'utilisation d'une balise map alourdie la page à renvoyer
12
 *
13
 * Il est possible de créer des fond de carte en vraies couleurs
14
 * (16 millions de zones maxi sur la carte) ou en couleurs indexées (255 zones maxi sur la carte).
15
 * Les couleurs réservées et a ne pas utiliser pour créer l'image png de fond sont :
16
 * - le blanc (rvb : 255-255-255)
17
 * - le noir (rvb : 0-0-0)
18
 * - le gris (rvb : 128-128-128)
19
 * - le rouge (rvb : 255-0-0)
20
 * Pour activer le cache indiquer la date de dernière mise à jour des données servant à créer la carte de cette façon :
21
 * $Carte->setCarteInfo(array('donnees_date_maj' => $date_maj_donnees));
22
 *
23
 * @category	PHP5
24
 * @package		Collection
25
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
26
 * @copyright	2010 Tela-Botanica
27
 * @license		GPL-v3 et CECILL-v2
28
 * @version		SVN:$Id$
29
 */
30
 
31
class Cartographie {
32
	/*** Constantes : ***/
33
	const FORMULE_PROPORTIONNEL = 'proportionnel';
34
	const FORMULE_LEGENDE = 'legende';
35
 
36
	//+----------------------------------------------------------------------------------------------------------------+
37
	/*** Attributs : ***/
38
	/**
39
	* L'image de la carte.
40
	* @var string l'image de la carte.
41
	*/
42
	private $carte;
43
 
44
	/**
45
	* Le nom du fichier contenant la carte sans l'extension.
46
	* @var string le nom du fichier de la carte.
47
	*/
48
	private $carte_nom;
49
 
50
	/**
51
	* @var string le chemin et le nom du fichier de l'image de la carte générée.
52
	*/
53
	private $carte_fichier;
54
 
55
	/**
56
	* Tableaux associatif contenant les informations sur la carte.
57
	* donnees_date_maj = date de dernière mise à jour des données servant à créer la carte, si plus récente que la carte
58
	* déjà créée getCarteCache renvoie false.
59
	*
60
	* @var array le tableau des infos sur la carte.
61
	*/
62
	private $carte_info = array();
63
 
64
	/**
65
	* Indique si la carte existe déjà et à besoin ou pas d'être créée.
66
	* @var bool true si la carte existe..
67
	*/
68
	private $carte_cache = false;
69
 
70
	/**
71
	* Le nom du fichier de la carte de fond.
72
	* @var string nom du fichier de la carte de fond.
73
	*/
74
	private $carte_fond_fichier;
75
 
76
	/**
77
	* Le nom du dossier contenant les cartes de fond.
78
	* @var string nom du dossier contenant les cartes de fond.
79
	*/
80
	private $carte_fond_dossier;
81
 
82
	/**
83
	* Le nom du dossier où stocker les cartes créer via la classe Cartographie.
84
	* @var string nom du dossier contenant les cartes créées.
85
	*/
86
	private $carte_stockage_dossier;
87
 
88
	/**
89
	* Format du tableau :
90
	* carte_zone_info est un tableau de tableaux associatifs.
91
	* Chaque zone de la carte doit avoir son entrée dans ce tableau. Chaque zone est représentée par :
92
	* - nom : (string)
93
	* 	le nom de la zone.
94
	* - index : (int)
95
	* 	l'index de la couleur dans la palette si on a à faire à une image indexée (moins de 255 zones sur la carte)
96
	* - rvb_fond : (string) Exemple : 255-255-255.
97
	* 	les valeurs entre 0 et 255 séparées par des tirets (-) de la couleur de la zone sur la carte de fond
98
	* 	Ne pas utiliser le blanc (255-255-255) et utiliser le noir pour les contours(0-0-0).
99
	* - rvb_carte : (string) Exemple : 255-255-255.
100
	* 	les valeurs entre 0 et 255 séparées par des tirets (-) de la couleur de remplacement
101
	* - nombre : (int) Exemple : nombre de personnes présentent dans un département.
102
	* 	nombre d'occurence dans cette zone.
103
	* @var array les informations sur les zones de la carte.
104
	*/
105
	private $carte_zone_info = array();
106
 
107
	/**
108
	* Tableau contenant la valeur RVB de la zone du fond de carte en clé et la valeur RVB venant la remplacer en valeur.
109
	* @var array valeur RVB de la zone du fond de carte en clé et valeur RVB venant la remplacer en valeur.
110
	*/
111
	private $carte_correspondance_couleurs = array();
112
 
113
	/**
114
	* La valeur RVB, sous forme de chaine de nombres séparées par des tirets (-), de la zone géographique à mettre en
115
	* surbrillance.
116
	* @var string la valeur RVB de la zone à repérer.
117
	*/
118
	private $zone_marker;
119
 
120
	/**
121
	* La formule de coloriage de la carte. Les formules disponibles sont : légende, proportionnel.
122
	* @var string la formule de coloriage.
123
	*/
124
	private $formule_coloriage;
125
 
126
	/**
127
	* Les valeurs RVB séparés par des virgules pour la couleur la plus foncée utilisée, entre autre, par la formule de
128
	* coloriage "proportionnel".
129
	* @var string les valeurs RVB séparées par des virgules.
130
	*/
131
	private $coloriage_couleur_max;
132
 
133
	/**
134
	* Les valeurs RVB séparés par des virgules pour la couleur la plus claire utilisée, entre autre, par la formule de
135
	* coloriage "proportionnel".
136
	* @var string les valeurs RVB séparées par des virgules.
137
	*/
138
	private $coloriage_couleur_min;
139
 
140
	/**
141
	* Contient le nombre de couleurs différentes utilisées par le coloriage pour créer l'image finale.
142
	* @var int le nombre de couleurs.
143
	*/
144
	private $coloriage_couleurs;
145
 
146
	/**
147
	* Contient le tableau des fréquences et des couleurs correspondantes.
148
	* @var array les frequences et leurs couleurs.
149
	*/
150
	private $coloriage_tableau_frequence = array();
151
 
152
	//+----------------------------------------------------------------------------------------------------------------+
153
	/*** Constructeur : ***/
154
	public function __construct($options = array()) {
155
		// Initialisation de l'objet Cartographie
156
		$this->setCarteNom(isset($options['carte_nom']) ? $options['carte_nom'] : '');
157
		$this->setFormuleColoriage(isset($options['formule']) ? $options['formule'] : '');
158
		$this->setCarteFondFichier(isset($options['fond_fichier']) ? $options['fond_fichier'] : '');
159
		$this->setCarteFondDossier(isset($options['fond_dossier']) ? $options['fond_dossier'] : '');
160
		$this->setCarteStockageDossier(isset($options['stock_dossier']) ? $options['stock_dossier'] : '');
161
		$this->setCarteZoneInfo(isset($options['infos']) ? $options['infos'] : array());
162
		$this->setZoneMarker(isset($options['zone_marker']) ? $options['zone_marker'] : '');
163
	}
164
 
165
	//+----------------------------------------------------------------------------------------------------------------+
166
	/*** Accesseur : ***/
167
	public function getTableauFrequence() {
168
		ksort($this->coloriage_tableau_frequence);
169
		return $this->coloriage_tableau_frequence;
170
	}
171
 
172
	public function getCarteCache() {
173
		// Gestion du cache
174
		if ($this->getCarteNom() != '') {
175
			$fichier_carte = $this->carte_stockage_dossier.$this->getCarteNom().'.png';
176
			if (file_exists($fichier_carte)) {
177
				//echo filemtime($fichier_carte).'-'.strtotime($this->carte_info['donnees_date_maj']);
178
				if (filemtime($fichier_carte) < strtotime($this->carte_info['donnees_date_maj'])) {
179
					$this->carte_cache = false;
180
				} else {
181
					$this->carte_cache = true;
182
				}
183
			}
184
		}
185
		return $this->carte_cache;
186
	}
187
 
188
	public function getCarteInfo() {
189
		return $this->carte_info;
190
	}
191
	public function setCarteInfo($ci) {
192
		$this->carte_info = $ci;
193
	}
194
 
195
	public function getColoriageCouleurClaire() {
196
		return $this->coloriage_couleur_min;
197
	}
198
	public function setColoriageCouleurClaire($ccmi) {
199
		$this->coloriage_couleur_min = $ccmi;
200
	}
201
 
202
	public function getColoriageCouleurFoncee() {
203
		return $this->coloriage_couleur_max;
204
	}
205
	public function setColoriageCouleurFoncee($ccma) {
206
		$this->coloriage_couleur_max = $ccma;
207
	}
208
 
209
	public function getFormuleColoriage() {
210
		return $this->formule_coloriage;
211
	}
212
	public function setFormuleColoriage($fc) {
213
		$this->formule_coloriage = $fc;
214
	}
215
 
216
	public function getCarteNom() {
217
		return $this->carte_nom;
218
	}
219
	public function setCarteNom($cn) {
220
		$this->carte_nom = $cn;
221
	}
222
 
223
	public function getCarteFichier() {
224
		return $this->carte_fichier;
225
	}
226
	public function setCarteFichier($cf) {
227
		$this->carte_fichier = $cf;
228
	}
229
 
230
	public function getCarteFondFichier() {
231
		return $this->carte_fond_fichier;
232
	}
233
	public function setCarteFondFichier($cff) {
234
		$this->carte_fond_fichier = $cff;
235
	}
236
 
237
	public function getCarteFondDossier() {
238
		return $this->carte_fond_dossier;
239
	}
240
	public function setCarteFondDossier($cfd) {
241
		$this->carte_fond_dossier = $cfd;
242
	}
243
 
244
	public function getCarteStockageDossier() {
245
		return $this->carte_stockage_dossier;
246
	}
247
	public function setCarteStockageDossier($csd) {
248
		$this->carte_stockage_dossier = $csd;
249
	}
250
 
251
	public function getCarteZoneInfo() {
252
		return $this->carte_zone_info;
253
	}
254
	public function setCarteZoneInfo($czi) {
255
		$this->carte_zone_info = $czi;
256
	}
257
 
258
	public function getZoneMarker() {
259
		return $this->zone_marker;
260
	}
261
	public function setZoneMarker($zm) {
262
		$this->zone_marker = $zm;
263
	}
264
 
265
	//+----------------------------------------------------------------------------------------------------------------+
266
	/*** Méthodes PUBLIQUES : ***/
267
 
268
	public function creerCarte() {
269
		// Création de la carte car aucun cache ou cache à vider
270
		$carte_fond_fichier = $this->carte_fond_dossier.$this->getCarteFondFichier().'.png';
271
		$this->carte = imagecreatefrompng($carte_fond_fichier);
272
		// Vérification que la création à fonctionnée
273
		if (!$this->carte) {
274
			// Une erreur est survenue : création d'une image blanche
275
			$this->carte = imagecreatetruecolor(520, 60);
276
			$bgc = imagecolorallocate($this->carte, 255, 255, 255);
277
			$tc  = imagecolorallocate($this->carte, 0, 0, 0);
278
			imagefilledrectangle($this->carte, 0, 0, 520, 60, $bgc);
279
			// Affichage d'un message d'erreur
280
			imagestring($this->carte, 1, 5, 5, "Erreur de chargement de l'image :", $tc);
281
			imagestring($this->carte, 1, 5, 15, $carte_fond_fichier, $tc);
282
		} else {
283
			// Nous construison le tableau de correspondance entre les couleurs présente sur l'image de fond
284
			// et les couleurs qui doivent les remplacer.
285
			$this->construireCorrespondanceCouleur();
286
 
287
			// Nous lançons la création de la carte
288
			$this->colorierCarte();
289
		}
290
 
291
		// Nous chercons à créer une image indéxées en sortie
292
		if (imageistruecolor(&$this->carte) && $this->formule_coloriage != 'legende') {
293
			if ($this->coloriage_couleurs <= 253) {
294
				//imagetruecolortopalette(&$this->carte, false, ($this->coloriage_couleurs + 2));// + 2 car noir et blanc réservés.
295
			} else {
296
				// On force la création d'une palette... si cela pose problème ajouter un attribut permettant de désactiver
297
				// ce fonctionnement.
298
				imagetruecolortopalette(&$this->carte, false, 255);
299
			}
300
		}
301
 
302
		// Nous écrivons le fichier de la carte.
303
		if ($this->getCarteNom() == '') {
304
			$this->setCarteNom(md5($this->carte));
305
		}
306
 
307
		$this->setCarteFichier($this->carte_stockage_dossier.$this->getCarteNom().'.png');
308
		imagepng(&$this->carte, $this->getCarteFichier());
309
		return true;
310
	}
311
 
312
	public function getImageMap() {
313
		// Initialisation de variables
314
		$carte_map = '';
315
 
316
		// Gestion de l'image map
317
		$chemin_carte_map_fond = $this->getCarteFondDossier().$this->getCarteNom().'.tpl.html';
318
		$chemin_carte_map = $this->getCarteStockageDossier().$this->getCarteNom().'.html';
319
		if (file_exists($chemin_carte_map)) {
320
			$carte_map = file_get_contents($chemin_carte_map);
321
		} else {
322
			$donnees['zones'] = $this->getCarteInfo();
323
			$carte_map = SquelettePhp::analyser($chemin_carte_map_fond, $donnees);
324
			if (!file_put_contents($chemin_carte_map, $carte_map)) {
325
				$e = "Écriture du fichier contenant le html de la carte impossible : $chemin_carte_map";
326
				trigger_error($e, E_USER_WARNING);
327
			}
328
		}
329
 
330
		return $carte_map;
331
	}
332
 
333
	/*** Méthodes PRIVÉES : ***/
334
	private function construireCorrespondanceCouleur() {
335
		switch ($this->formule_coloriage) {
336
			case self::FORMULE_LEGENDE :
337
				$this->construireCorrespondanceCouleurLegende();
338
				break;
339
			case self::FORMULE_PROPORTIONNEL :
340
				$this->construireCorrespondanceCouleurProportionnel();
341
				break;
342
			default :
343
				$e = 	"Aucune formule de coloriage n'a été définie parmis : ".
344
						self::FORMULE_LEGENDE.' et '.self::FORMULE_PROPORTIONNEL.'. '.
345
						"Veuillez la définir avec la méthode setFormuleColoriage().";
346
				trigger_error($e, E_USER_ERROR);
347
		}
348
	}
349
 
350
	private function construireCorrespondanceCouleurProportionnel() {
351
		// Création d'un tableau contenant seulement les nombres d'information pour chaque zone.
352
		$tab_valeurs = array();
353
		foreach ($this->carte_zone_info as $cle => $valeur) {
354
			//Nous recherchons le minimum, le maximum et le la valeur médium juste au dessous du maximum.
355
			if (isset($valeur['info_nombre'])) {
356
				$tab_valeurs[] = $valeur['info_nombre'];
357
				if ($valeur['info_nombre'] == 0){
358
					//trigger_error($valeur['nom'], E_USER_NOTICE);
359
				}
360
			}
361
		}
362
 
363
		//Nombre d'entrées dans le tableau de valeurs non nulles :
364
		$valeurs_nbre = count($tab_valeurs);
365
		$valeurs_somme = array_sum($tab_valeurs);
366
		// Tabeau des fréquences trié de la plus petite à la plus grande clé.
367
		$tab_frequences = array_count_values($tab_valeurs);
368
		krsort($tab_frequences);
369
		//trigger_error(print_r($tab_frequences, true), E_USER_NOTICE);
370
		$frequences_nbre = count($tab_frequences);
371
		if ($valeurs_nbre > 0){
372
			// Nous trions le tableau dans l'ordre croissant :
373
			sort($tab_valeurs);
374
			// Nous récupérons la valeur la plus petite :
375
			$mini = $tab_valeurs[0];
376
			$maxi = $tab_valeurs[$valeurs_nbre - 1];
377
			$medium = isset($tab_valeurs[$valeurs_nbre - 2]) ? $tab_valeurs[$valeurs_nbre - 2] : 0;
378
			$moyenne = $valeurs_somme / $valeurs_nbre;
379
			$ecart_au_carre_moyen = 0;
380
			for ($i = 0; $i < $valeurs_nbre; $i++) {
381
				$ecart_au_carre_moyen += pow(($tab_valeurs[$i] - $moyenne), 2);
382
			}
383
			$variance = $ecart_au_carre_moyen / $valeurs_nbre;
384
			$ecart_type = round(sqrt($variance), 0);
385
			$moyenne = round($moyenne, 0);
386
			$variance = round($variance, 0);
387
		}
388
 
389
		// Calcul de l'écart moyen pour chaque élément R, V et B.
390
		list($r_min, $v_min, $b_min) = explode(',', $this->coloriage_couleur_max);
391
		list($r_max, $v_max, $b_max) = explode(',', $this->coloriage_couleur_min);
392
		$r_diff = $r_min - $r_max;
393
		$r_ecart_moyen = abs($r_diff / $frequences_nbre);
394
 
395
		$v_diff = $v_min - $v_max;
396
		$v_ecart_moyen = abs($v_diff / $frequences_nbre);
397
 
398
		$b_diff = $b_min - $b_max;
399
		$b_ecart_moyen = abs($b_diff / $frequences_nbre);
400
 
401
		// Pour chaque fréquence nous attribuons une couleur.
402
		$i = 1;
403
		foreach ($tab_frequences as $cle => $valeur){
404
			if ($cle == 0) {
405
				$this->coloriage_tableau_frequence[$cle] = '255-255-255';
406
			} else {
407
				$r = $r_min + round(($i * $r_ecart_moyen), 0);
408
 
409
				$v = $v_min + round(($i * $v_ecart_moyen), 0);
410
				$b = $b_min + round(($i * $b_ecart_moyen), 0);
411
				$this->coloriage_tableau_frequence[$cle] = $r.'-'.$v.'-'.$b;
412
			}
413
			$i++;
414
		}
415
 
416
		// Attribution du nombre de couleurs utilisé pour réaliser la carte
417
		$this->coloriage_couleurs = count(array_count_values($this->coloriage_tableau_frequence));
418
		//trigger_error('<pre>'.print_r($this->coloriage_couleurs, true).'</pre>', E_USER_ERROR);
419
 
420
		// Nous attribuons les couleurs à chaque zone géographique
421
		foreach ($this->carte_zone_info as $cle => $zg) {
422
			if (isset($this->coloriage_tableau_frequence[$zg['info_nombre']])) {
423
				$this->carte_correspondance_couleurs[$zg['rvb_fond']] = $this->coloriage_tableau_frequence[$zg['info_nombre']];
424
			} else {
425
				$e = "La zone ".$zg['nom']." (".$zg['rvb_fond'].") ne possède pas de couleur RVB pour la remplir. ".
426
					 "La valeur 128-128-128 lui a été attribué.";
427
				trigger_error($e, E_USER_WARNING);
428
				$this->carte_correspondance_couleurs[$zg['rvb_fond']] = '128-128-128';
429
			}
430
		}
431
	}
432
 
433
	private function construireCorrespondanceCouleurLegende() {
434
		$tab_couleurs = array();
435
		foreach ($this->carte_zone_info as $cle => $zg) {
436
			if ($zg['rvb_carte'] != '') {
437
				$this->carte_correspondance_couleurs[$zg['rvb_fond']] = $zg['rvb_carte'];
438
			} else {
439
				$e = "La zone ".$zg['nom']." (".$zg['rvb_fond'].") ne possède pas d'information pour la légende dans le champ".
440
					 " rvb_carte. La valeur 128-128-128 lui a été attribué.";
441
				trigger_error($e, E_USER_WARNING);
442
				$this->carte_correspondance_couleurs[$zg['rvb_fond']] = '128-128-128';
443
			}
444
			if (!isset($tab_couleurs[$this->carte_correspondance_couleurs[$zg['rvb_fond']]])) {
445
				$tab_couleurs[$this->carte_correspondance_couleurs[$zg['rvb_fond']]] = 1;
446
			}
447
		}
448
		// Attribution du nombre de couleurs utilisé pour réaliser la carte
449
		$this->coloriage_couleurs = count($tab_couleurs);
450
	}
451
 
452
	private function colorierCarte() {
453
		if (imageistruecolor(&$this->carte)) {
454
			//+--------------------------------------------------------------------------------------------------------+
455
			// Remplacement des couleurs sur la carte en mode vraies couleurs (RGB)
456
 
457
			// Nous commençons le rempalcement des couleurs sur la carte de fond.
458
			$hauteur = imagesy(&$this->carte);
459
			$largeur = imagesx(&$this->carte);
460
 
461
			// Tableau contenant les couleurs traitées, pour éviter de traiter plusieurs fois la même couleur
462
			$tab_rvb_ok = array();
463
			for ($x = 0; $x < $largeur; $x++) {
464
				for ($y = 0; $y < $hauteur; $y++) {
465
					$rvb = ImageColorAt(&$this->carte, $x, $y);
466
					if (!isset($tab_rvb_ok[$rvb])) {
467
		   				// Récupération de la couleur rvb au format xxx-xxx-xxx
468
		   				$cle = (($rvb >> 16) & 0xFF).'-'.(($rvb >> 8) & 0xFF).'-'.($rvb & 0xFF);
469
		   				// Si nous n'avons pas à faire à la couleur noire (utilisé pour délimité les zones), nous continuons
470
		   				if ($cle != '255-255-255') {
471
			   				$rvb_final = null;
472
			   				if (isset($this->carte_correspondance_couleurs[$cle])) {
473
			   					if ($this->zone_marker != '' && $cle == $this->zone_marker) {
474
									$rvb_final = '255'<<16 | '0'<<8 | '0';
475
								} else {
476
			   						list($rouge, $vert, $bleu) = explode('-', $this->carte_correspondance_couleurs[$cle]);
477
			   						$rvb_final = $rouge<<16 | $vert<<8 | $bleu;
478
			   					}
479
			   					// Si le nombre de couleurs sur la carte finale est infèrieur à 255 nous créons une image indexée
480
			   					imagefill(&$this->carte, $x, $y, $rvb_final);
481
			   				} else {
482
			   					$rvb_final = '128'<<16 | '128'<<8 | '128';
483
			   					imagefill(&$this->carte, $x, $y, $rvb_final);
484
			   				}
485
		   					// Nous ajoutons la couleur ajoutée à la carte dans le tableau des couleurs traitées
486
		   					$tab_rvb_ok[$rvb_final] = true;
487
		   				}
488
		   				// Nous ajoutons la couleur trouvées sur la carte de fond dans le tableau des couleurs traitées
489
		   				$tab_rvb_ok[$rvb] = true;
490
					}
491
				}
492
			}
493
		} else {
494
			//+--------------------------------------------------------------------------------------------------------+
495
			// Remplacement des couleurs sur la carte en mode couleurs indexées (palette de couleurs)
496
 
497
			// Nous attribuons à chaque zone présente dans le tableau $this->carte_zone_info la valeur de l'index
498
			// de la couleur RVB représentant cette zone sur la carte de fond.
499
			$this->construireAssociationIndexZone();
500
 
501
			foreach ($this->carte_zone_info as $zg) {
502
				if (isset($this->carte_correspondance_couleurs[$zg['rvb_fond']])) {
503
					//Dans le cas où nous voulons repérer une zone sur la carte :
504
					if ($this->zone_marker != '' && $zg['rvb_fond'] == $this->zone_marker) {
505
						$rouge = 255;
506
						$vert = 0;
507
						$bleu = 0;
508
					} else {
509
						list($rouge, $vert, $bleu) = explode('-', $this->carte_correspondance_couleurs[$zg['rvb_fond']]);
510
					}
511
					imagecolorset(&$this->carte, $zg['index'], $rouge, $vert, $bleu);
512
				}
513
			}
514
		}
515
	}
516
 
517
	private function construireAssociationIndexZone() {
518
		// Nous récupérons le nombre de couleur différentes contenues dans l'image.
519
		$taille_palette = imagecolorstotal($this->carte);
520
		//print_r($this->carte_zone_info);
521
		// Pour chaque couleur contenue dans l'image, nous cherchons l'objet correspondant
522
		// dans le tableau $this->carte_zone_info, qui contient des informations sur chaque zone de l'image,
523
		// et nous attribuons la valeur de l'index de sa couleur sur la carte de fond.
524
		for ($i = 0; $i < $taille_palette; $i++) {
525
			$rvb = array();
526
			$rvb = imagecolorsforindex($this->carte, $i);
527
			$rvb_cle = $rvb['red'].'-'.$rvb['green'].'-'.$rvb['blue'];
528
			// La couleur ne doit pas correspondre au noir ou au blanc car ces couleurs ne sont pas traitées
529
			if ($rvb_cle != '255-255-255' && $rvb_cle != '0-0-0') {
530
				$index_ok = false;
531
				foreach($this->carte_zone_info as $cle => $zg) {
532
					if (isset($zg['rvb_fond']) && $zg['rvb_fond'] == $rvb_cle) {
533
						$this->carte_zone_info[$cle]['index'] = $i;
534
						$index_ok = true;
535
						//print_r($this->carte_zone_info[$cle]);
536
						break;
537
					}
538
				}
539
				if (!$index_ok && $rvb_cle != '0-0-0') {
540
					$e = "Aucune zone trouvée pour l'index $i : $rvb_cle";
541
					trigger_error($e, E_USER_WARNING);
542
					$this->carte_zone_info[] = array('rvb_fond' => $rvb_cle, 'rvb_carte' => '128-128-128', 'index' => $i);
543
				}
544
			}
545
		}
546
	}
547
 
548
}
549
?>