Bonjour à tous,
j'ai suivi le tuto sur la création de graphique avec la librairie GD, mais je suis face à un problème avec mon script.

J'ai la table sql suivante:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
CREATE TABLE IF NOT EXISTS `tickets` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `id_pros` text NOT NULL,
  `date` date NOT NULL,
  `societe` text NOT NULL,
  `sujet` text NOT NULL,
  `detail` text NOT NULL,
  `intervention` text NOT NULL,
  `categorie` text NOT NULL,
  `ss_cat` varchar(20) NOT NULL,
  `priorite` text NOT NULL,
  `etat` text NOT NULL,
  `nb_ticket` text NOT NULL,
  `attachement` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=91 ;

J'extrais de cette table le nombre de tickets "nb_tickets" et je groupe par date pour afficher mon histogramme.
Jusque la tous va bien, mon graphique s'affiche avec les mois et le nombre de tickets utilisés.
La ou ça ce complique c'est que je voudrais aussi afficher une 2eme bar qui elle m'afficherai les nombre d'intervention regroupé par date.
Vue ma table je pense que je dois utiliser les id pour calculer le nombre en fonction des date.

Voila la source de mon code:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
<?php
$host="localhost";
$utilisateur="root";
$motdepasse="";
$base="matable";
 
 
$conexion=mysql_connect($host,$utilisateur,$motdepasse) or die('Connexion impossible: ' . mysql_error());
$db=mysql_select_db($base, $conexion) or die('Connexion a la base impossible : ' . mysql_error());
 
$query=mysql_query('SELECT MONTH(date) as dates,(SELECT SUM(nb_ticket) FROM tickets WHERE MONTH(date)=dates) as nb_ticket FROM tickets WHERE MONTH(date) GROUP BY dates');
 
$i=0;
$element=array();
$js=array();
while($row=mysql_fetch_object($query))
{
    //Prendre la premiere quantite vendue comme le minimum et maximum
        //Mettre les noms de produit et les dates de ventes dans des tableaux
        if($i==0)
    {
        $min=$row->nb_ticket;
        $max=$row->nb_ticket;
        array_push($element, $row->libelle);
        array_push($js, $row->dates);
    }
        //Inserer le nom de produit dans le tableau s'il n'est pas encore enregistrer
    if(!in_array($row->libelle_produit,$element))
        {
            array_push($element, $row->libelle);
        }
        //Inserer le dates de vente dans le tableau s'il n'est pas encore enregistrer
    if(!in_array($row->dates,$js))
        {
            array_push($js, $row->dates);
        }
 
    if($row->nb_ticket < $min)
                {
                        $min=$row->nb_ticket;
                }
    else
                {
                        if($row->nb_ticket > $max)
                                {$max=$row->nb_ticket;}
                }
    $i++;
}
//Mettre les dates en Francais dans un tableau
$datesFr=array('Jan','Fev','Mars','Avril','Mai','Juin','Juil','Aout','Sept','Oct','Nov','Dec');
 
 
//type mime de l'image
header('Content-type: image/png');
//Chemin vers le police à utiliser
$font_file = './arial.ttf';
//Adapter la largeur de l'image par rapport au nombre de ligne et nombre de dates
$largeur=$i*20+(count($js)*10)+100;
$hauteur=400;
$absis=80;
$courbe=imagecreatetruecolor($largeur, $hauteur);
//Générer un tableau de couleurs
$couleur=array();
$red=0;
$blue=0;
$green=0;
for($n=0;$n<count($element);$n++)
{
    $x = $n%3;
    switch ($x){
        case(0):
            $red+=85;
            break;
        case(1):
            $blue+=85;
            break;
        case(2):
            $green+=85;
            break;
    }
    $couleur[$n]=imagecolorallocate($courbe, $red,$green , $blue);
}
//Les autre couleurs utils
$ligne=imagecolorallocate($courbe, 220, 220, 220);
$fond=imagecolorallocate($courbe, 250, 250, 250);
$noir=imagecolorallocate($courbe, 0, 0, 0);
$blanc=imagecolorallocate($courbe, 255, 255, 255);
$rouge=imagecolorallocate($courbe, 255, 0, 0);
//Colorer le fond
imagefilledrectangle($courbe,0 , 0, $largeur, $hauteur, $fond);
//Tracer l'abscisse et l'ordonnée
imageline($courbe, 50, $hauteur-$absis, $largeur-10,$hauteur-$absis, $noir);
imageline($courbe, 50,$hauteur-$absis,50,20, $noir);
if($min!=0)
{
    $absis+=30;
    $a=30;
}
$nbOrdonne=10;
//Calculer les échelles suivants les abscisses et ordonnées
$echelleX=($largeur-90-((count($js)*10)))/$i;
$echelleY=($hauteur-$absis-20)/$nbOrdonne;
$i=$min;
$py=($max-$min)/$nbOrdonne;
$pasY=$absis;
//Tracer les grides
while($pasY<($hauteur-19))
{
    imagestring($courbe, 2,10 , $hauteur-$pasY-6, round($i), $noir);
    imageline($courbe, 50, $hauteur-$pasY, $largeur-20,$hauteur-$pasY, $ligne);
    $pasY+=$echelleY;
    $i+=$py;
}
$pasX=60;
 mysql_data_seek($query, 0);
 $dates=0;
 while($row=mysql_fetch_object($query))
 {
   if($dates<($row->dates))
   {
        //Ecrire le dates en Français en abscisse
                imagestring($courbe, 2, $pasX,$hauteur-$absis+32 , $datesFr[$row->dates-1], $noir);
                //Décaller 10 px du dates précédent
        $pasX+=10;
   }
   //Calculer la hauteur de la rectangle
   $y=($hauteur) -(($row->nb_ticket -$min) * ($echelleY/$py))-$absis;
   //Prendre la couleur correspondante au produit
   $clr=$couleur[array_search($row->libelle, $element)];
   //Dessiner le rectangle
   imagefilledrectangle($courbe,$pasX-10 , $hauteur-$absis+$a, $pasX+10, $y, $clr);
   //Ecrire la valeur en verticale
   imagefttext($courbe, 10, 270, $pasX-3, $y+5, $blanc, $font_file, $row->nb_ticket);
   //Decaller le prochain rectangle
   $pasX+=$echelleX;
   $dates=$row->dates;
}
//La legende
$pasX=50;
//Hauteur de la premiere
$pasY=$hauteur-$absis+47;
foreach ($element as $index=>$libelle)
{
    if(($index % 4)==3)
    {
        $pasX+=120;
        $pasY=$hauteur-$absis+47;
    }
        //Le nom du poduit avec sa couleur
        imagestring($courbe, 2, $pasX,$pasY , $libelle, $couleur[$index]);
        //Un petit rectangle
        imagefilledrectangle($courbe,$pasX+80 , $pasY, $pasX+100, $pasY+12, $couleur[$index]);
    $pasY+=20;
}
imagepng($courbe);
imagedestroy($courbe);
?>
A la place de $row->libelle, je souhaiterais affiché le texte "Nombre de tickets" et "Interventions" pour la 2eme bar de l'histogramme.

Et dernier point comment est ce que je peu faire pour afficher les mois sans données?
Merci pour vos réponses.