IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques et frameworks PHP Discussion :

[Artichow] Construction d'un camembert


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut [Artichow] Construction d'un camembert
    Bonjour à tous, j'ai installé artichow sur mon serveur linux et j'ai testé un de vos exemple et cela fonctionne.

    J'ai essayer de le mettre en pratique en recuperant des donnée de ma base mysql et ca bug.


    voila ce qui apparait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Warning: Cannot modify header information - headers already sent by (output started at /var/www/qualite/v0.1a/stats2.php:21) in /var/www/qualite/v0.1a/Artichow/php5/Image.class.php on line 582
    ‰PNG  ��� IHDR�����Z���Ù—ý�
    �™IDAT8íy$Õ}ç/¯ªÊ:»ú>¦çh†Ã0Â#.I`d@+lc…*p�Ëj±v½²,Ë2ƁX²7t86¬Å²vƒ`k„±d$
    Ns-Œf˜FÌÐ3Ýsu÷ô]]WfåýöW••™••]Ý Ýí÷‰ŽŠ¬WïýÞ/³+¿õ{¿|ùa ,˜N ea>h( %,T°(Êš …BY3PÁ¢P(k*X eÍ@‹B¡¬¨`Q(5ÃÊÆÍg$…©C¡P(8Ÿ2§Ž ÔšÔ®C¡PÖ&ÊüüÌ‘ƒ3‡Î>Xæa¶,lز,Ã`!sчÛw\Ö¶ýÒöK/KoÙÆ°ìŠº„ÜAŽSƒšêÑRk]Š)kœ¹w¾¸ŸˆTñÌð
    §„x¼©*XË ,ʪAžùÅí7“;¸(ÓÛo†AñÉdº·7d`ufüì 
     
    ............................

    voici ma page qui execute le 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
     
    <?php
    $mois = isset($_POST['mois'])?$_POST['mois']:null;
    $annee = isset($_POST['annee'])?$_POST['annee']:null;
     
    $server="****";
    $user="****";
    $pass="*****";
    $db="*****";
    mysql_connect($server,$user,$pass) or die('erreur de connexion');
    mysql_select_db($db) or die ('impossible de se connecter a la base');
    $sql1="SELECT count( id_reclamation ) as reclamation
    FROM reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee';";
     
    $query1 = mysql_query($sql1) or die('Erreur SQL !'.$sql1.'<br>'.mysql_error());
    //mysql_num_rows($query1);
    echo 'Pour le mois de '.$mois.'/'.$annee.', nous avons ';
    while ( $list3 = mysql_fetch_array( $query1 ) ) { echo $list3["reclamation"];}
    echo ' XXXX Réclamations.';
     
    echo '<SELECT name="id_critere" onchange="critere()">';
    $sql2="SELECT id_critere, nom_critere FROM critere;";
    $query2 = mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    echo '<option value="-1"> Faite votre Choix</option>';
    while ($list4 = mysql_fetch_array($query2))
    {
    echo '<option value='.$list4["id_critere"].'">'.$list4["nom_critere"].'</option>';
    }
    echo '</SELECT>';
    require_once('Artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $sql3="SELECT id_critere, nom_critere FROM critere;";
    $query3 = mysql_query($sql3) or die('Erreur SQL !'.$sql3.'<br>'.mysql_error());
     
    $ServArray = array ();
    while($servicetab= mysql_fetch_array($query3)) {
    $ServArray[$servicetab['id_critere']][0] = $servicetab['id_critere'];
    $ServArray[$servicetab['id_critere']][1] = $servicetab['nom_critere'];
    }
     
    $genres = array();
    while($servicetab2= mysql_fetch_array($query3)) {
    $genres[$servicetab2['nom_critere']][0] = $servicetab2['id_critere'];
    $genres[$servicetab2['nom_critere']][1] = $servicetab2['nom_critere'];
    }
    ;
    foreach ($ServArray as $key => $val)
    {
    $sql4="SELECT count( id_eva_reclamation ) as total, nom_critere
    FROM eva_reclamation
    INNER JOIN critere ON critere.id_critere=eva_reclamation.id_critere
    INNER JOIN reclamation ON eva_reclamation.id_reclamation=reclamation.id_reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee'
    AND critere.id_critere IN($key) GROUP by nom_critere;";
    $query4 = mysql_query($sql4) or die('Erreur SQL !'.$sql4.'<br>'.mysql_error());
    while($ligne = mysql_fetch_assoc($query4)){
     
    echo '<br>'.$ligne["nom_critere"].'==>'.$ligne["eva_reclamation"].'<br>';
    }
    }
    ////////////////
     
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
    Je pense m'être tombé dans la création du tableau array ? non ?
    Ou est mon erreur ?
    Merci d'avance

    guigui69

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Ca ne marche pas comme ca, il faut lire la doc monsieur
    http://www.artichow.org/base/Page
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    D'accord mais se qui est bizarre c'est que dans leur exemple

    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
     
    ?php
     
    require_once('artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $genres = array(
    	'Action'		=> 28,
    	'Policier'		=> 14,
    	'Aventure'		=> 20,
    	'Romance'		=> 8,
    	'Drame'			=> 3,
    	'Science-Fiction'	=> 17,
    );
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
     
    ?>
    On arrive a voir le graphique, pourquoi je ne peut arriver avec mon code étant donner que je créer le tableau array (genres).

    Merci

    guigui69

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Parce que tu ne peux pas avoir en meme temps le flux de ta page html et le flux de ton graphique.

    Il faut appeller le graphique dans une balise <img> s'il doit etre intégré à du code html.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    D'accord,

    Comment je doit faire pour afficher le graphique sur ma page désirer.


    Ma requête récupérer le nombre de réclamation pour chaque critère. et je voudrait les afficher sur cette page sur forme d'un camembert.

    Merci

    guigui69

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Quelle est ta difficulté ?
    Par rapport a ce que tu as fais, il faut juste séparer la création du graphique dans une autre page.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Voici la page que j'ai fait:


    Ma page stats:

    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
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
     
    <?php session_start(); ?>
    <?php
    if(!isset($_SESSION['login'])) {
    	include('login.php');
    	echo $_SESSION['login'];
    	echo 'Vous n\'êtes pas autoris´ à acceder à cette zone';
    	echo '<br>';
     
      exit;
    }
    else
    {
    }
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<title>Service réclamation</title>
    		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15" />
    		<meta http-equiv="Content-Style-Type" content="text/css" />
    		<meta http-equiv="Content-Language" content="fr" />
    <link rel="stylesheet" type="text/css" href="css/site.css" media="screen" />
    <link rel="stylesheet" type="text/css" href="css/print.css" media="print" />
    	<script type="text/javascript">
    <!--
    window.onload=montre;
    function montre(id) {
    var d = document.getElementById(id);
    	for (var i = 1; i<=10; i++) {
    		if (document.getElementById('smenu'+i)) {document.getElementById('smenu'+i).style.display='none';}
    	}
    if (d) {d.style.display='block';}
    }
    function getXhr(){
                                    var xhr = null; 
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
                                    return xhr;
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function critere(){
    				var xhr = getXhr();
     
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
    						leselect = xhr.responseText;
    						// On se sert de innerHTML pour rajouter les options a la liste
    						document.getElementById('information').innerHTML = leselect;
     
    						}
    				}
     
    				// Ici on va voir comment faire du post
    				xhr.open("POST","ajax_stats.php",true);
    				// ne pas oublier ça pour le post
    				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    				// ne pas oublier de poster les arguments
    				// ici, l'id de l'auteur
    				idauteur = document.getElementById('code_client').value;
    				//idauteur2 = document.getElementById('debut_date').value;
    				//idauteur3 = document.getElementById('fin_date').value;
    				//alert(idauteur);
    				var indexsite = document.getElementById('id_critere') 
    				idauteur = document.getElementById("id_critere").value
    				//xhr.send("idauteur2="+idauteur2);
    				//xhr.send("idauteur3="+idauteur3);
    			}
    //-->
    </script>
    	</head>
    	<body>
    	<div id="conteneur">		
    		<h1 id="header"><a href="3" title="Accueil"></a></h1>
     
    <dl id="menu">
     
    		<dt onclick="javascript:montre('smenu1');">Rèclamation</dt>
    			<dd id="smenu1">
    				<ul>
    					<li><a href="reclamation.php">Nouvelle Rèclamation</a></li>
     
    				</ul>
    			</dd>			
    		<dt onclick="javascript:montre('smenu2');">Action immédiate</dt>
     
    			<dd id="smenu2">
    				<ul>
    					<li><a href="action_immediate.php">Faire une Action Immédiate</a></li>
    					<li><a href="maj_action_immediate.php">Mise à jour Action immédiate</a></li>
    				</ul>
    			</dd>	
     
    		<dt onclick="javascript:montre('smenu3');">Evaluation réclamation</dt>
     
    			<dd id="smenu3">
    				<ul>
    					<li><a href="evaluation_reclamation.php"> Evaluation Réclamation</a></li><li><a href="maj_evaluation_reclamation.php"> Maj Evaluation Réclamation</a></li>
    					<li><a href="maj_fac.php"> Maj Action Corrective</a></li>
    				</ul>
    			</dd>
     
    		<dt onclick="javascript:montre('smenu4');">Recap</dt>
     
    			<dd id="smenu4">
    				<ul>
    					<li><a href="recap.php">Recap  par Client</a></li>
    					<li><a href="recla_par_fac.php">Reclamation / Fac</a></li>
     
    				</ul>
    			</dd>
     
    </dl>
     
    		<div id="contenu">
    			<h2>Stats</h2>
    <?php
    $mois = isset($_POST['mois'])?$_POST['mois']:null;
    $annee = isset($_POST['annee'])?$_POST['annee']:null;
     
    $server="localhost";
    $user="root";
    $db="qualite";
    mysql_connect($server,$user,$pass) or die('erreur de connexion');
    mysql_select_db($db) or die ('impossible de se connecter a la base');
    $sql1="SELECT count( id_reclamation ) as reclamation
    FROM reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee';";
     
    $query1 = mysql_query($sql1) or die('Erreur SQL !'.$sql1.'<br>'.mysql_error());
    //mysql_num_rows($query1);
    echo 'Pour le mois de '.$mois.'/'.$annee.', nous avons ';
    while ( $list3 = mysql_fetch_array( $query1 ) ) { echo $list3["reclamation"];}
    echo 'Réclamations.';
     
    echo '<SELECT name="id_critere" onchange="critere()">';
    $sql2="SELECT id_critere, nom_critere FROM critere;";
    $query2 = mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    echo '<option value="-1"> Faite votre Choix</option>';
    while ($list4 = mysql_fetch_array($query2))
    {
    echo '<option value='.$list4["id_critere"].'">'.$list4["nom_critere"].'</option>';
    }
    echo '</SELECT>';
     
    $sql3="SELECT id_critere, nom_critere FROM critere;";
    $query3 = mysql_query($sql3) or die('Erreur SQL !'.$sql3.'<br>'.mysql_error());
     
    $ServArray = array ();
    while($servicetab= mysql_fetch_array($query3)) {
    $ServArray[$servicetab['id_critere']][0] = $servicetab['id_critere'];
    $ServArray[$servicetab['id_critere']][1] = $servicetab['nom_critere'];
    }
    $sql31="SELECT id_critere, nom_critere FROM critere;";
    $query31 = mysql_query($sql31) or die('Erreur SQL !'.$sql31.'<br>'.mysql_error());
    $genres = array();
    foreach ($ServArray as $key => $val)
    {
    $sql4="SELECT count( id_eva_reclamation ) as total, nom_critere
    FROM eva_reclamation
    INNER JOIN critere ON critere.id_critere=eva_reclamation.id_critere
    INNER JOIN reclamation ON eva_reclamation.id_reclamation=reclamation.id_reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee'
    AND critere.id_critere IN($key) GROUP by nom_critere;";
    $query4 = mysql_query($sql4) or die('Erreur SQL !'.$sql4.'<br>'.mysql_error());
    while($ligne = mysql_fetch_assoc($query4)){
    echo '<br>'.$ligne["nom_critere"].'==>'.$ligne["total"].'<br>';
     
    $genres[$ligne['nom_critere']] = $ligne['total'];
    }
     
    }
     
    echo "<img src='graph.php?values=".urlencode(serialize($genres))."' alt='Mon graphique'/>";
    ////////////////
     
    echo '<pre>' . print_r($genres, true) . '</pre>';
    ?>	
    		</div>
     
    		<p id="footer">Essai pour le service Qualité section reclamation cliente</p>
    	</div>
    	</body>
    </html>
    Cela va chercher dans ma base diverse information et créer un tableau array
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Array
    (
        [Commercial] => 1
        [Télévente] => 2
    )
    Et la page graph.php:

    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
     
    <?php
     
       // On vérifie que les données à afficher sur le graphique existent
       if(isset($_GET['genres']) === FALSE) {
       echo '<pre>pasok' . print_r($values, true) . '</pre>';
          exit;
       }
    echo '<pre>test1' . print_r($genres, true) . '</pre>';
       // On récupère les valeurs à afficher sur le graphique dans $_GET['values'] et on les désérialize
       $data = @unserialize($_GET['values']);
     
       // On vérifie que les données passées en GET sont correctes
       if(is_array($data) === FALSE) {
          exit;
       }
    echo '<pre>test2' . print_r($values, true) . '</pre>';
     
      require_once('Artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
     
     
    ?>
    (le graphe doit être un camembert)
    Quel partie du code vous apparait-elle incorrect ?

    Merci d'avance pour votre aide.

    guigui69

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Qu'est ce qui ne marche pas ?
    Sous-entendu, une fois enlevés les print_r de controle.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    En faites la place du graphe j'ai marqué "Mon graphique "le paramètre ALT.

    Quel est le problème? Par ou je doit commencer?

    Est que le format du array est-il bon

    Array
    (
    [Commercial] => 1
    [Télévente] => 2
    )

    Merci

    guigui69

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(isset($_GET['genres'])
    est faux puisque tu passes "values"
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    D'accord j'avais deja corrigé ce probleme mais cela ne s'affiche toujours pas.

    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
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
     
    <?php session_start(); ?>
    <?php
    if(!isset($_SESSION['login'])) {
    	include('login.php');
    	echo $_SESSION['login'];
    	echo 'Vous n\'êtes pas autoris´ à acceder à cette zone';
    	echo '<br>';
     
      exit;
    }
    else
    {
    }
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<title>Service réclamation</title>
    		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15" />
    		<meta http-equiv="Content-Style-Type" content="text/css" />
    		<meta http-equiv="Content-Language" content="fr" />
    <link rel="stylesheet" type="text/css" href="css/site.css" media="screen" />
    <link rel="stylesheet" type="text/css" href="css/print.css" media="print" />
    	<script type="text/javascript">
    <!--
    window.onload=montre;
    function montre(id) {
    var d = document.getElementById(id);
    	for (var i = 1; i<=10; i++) {
    		if (document.getElementById('smenu'+i)) {document.getElementById('smenu'+i).style.display='none';}
    	}
    if (d) {d.style.display='block';}
    }
    function getXhr(){
                                    var xhr = null; 
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
                                    return xhr;
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function critere(){
    				var xhr = getXhr();
     
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
    						leselect = xhr.responseText;
    						// On se sert de innerHTML pour rajouter les options a la liste
    						document.getElementById('information').innerHTML = leselect;
     
    						}
    				}
     
    				// Ici on va voir comment faire du post
    				xhr.open("POST","ajax_stats.php",true);
    				// ne pas oublier ça pour le post
    				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    				// ne pas oublier de poster les arguments
    				// ici, l'id de l'auteur
    				idauteur = document.getElementById('code_client').value;
    				//idauteur2 = document.getElementById('debut_date').value;
    				//idauteur3 = document.getElementById('fin_date').value;
    				//alert(idauteur);
    				var indexsite = document.getElementById('id_critere') 
    				idauteur = document.getElementById("id_critere").value
    				//xhr.send("idauteur2="+idauteur2);
    				//xhr.send("idauteur3="+idauteur3);
    			}
    //-->
    </script>
    	</head>
    	<body>
    	<div id="conteneur">		
    		<h1 id="header"><a href="3" title="Accueil"></a></h1>
     
    <dl id="menu">
     
    		<dt onclick="javascript:montre('smenu1');">Rèclamation</dt>
    			<dd id="smenu1">
    				<ul>
    					<li><a href="reclamation.php">Nouvelle Rèclamation</a></li>
     
    				</ul>
    			</dd>			
    		<dt onclick="javascript:montre('smenu2');">Action immédiate</dt>
     
    			<dd id="smenu2">
    				<ul>
    					<li><a href="action_immediate.php">Faire une Action Immédiate</a></li>
    					<li><a href="maj_action_immediate.php">Mise à jour Action immédiate</a></li>
    				</ul>
    			</dd>	
     
    		<dt onclick="javascript:montre('smenu3');">Evaluation réclamation</dt>
     
    			<dd id="smenu3">
    				<ul>
    					<li><a href="evaluation_reclamation.php"> Evaluation Réclamation</a></li><li><a href="maj_evaluation_reclamation.php"> Maj Evaluation Réclamation</a></li>
    					<li><a href="maj_fac.php"> Maj Action Corrective</a></li>
    				</ul>
    			</dd>
     
    		<dt onclick="javascript:montre('smenu4');">Recap</dt>
     
    			<dd id="smenu4">
    				<ul>
    					<li><a href="recap.php">Recap  par Client</a></li>
    					<li><a href="recla_par_fac.php">Reclamation / Fac</a></li>
     
    				</ul>
    			</dd>
     
    </dl>
     
    		<div id="contenu">
    			<h2>Stats</h2>
    <?php
    $mois = isset($_POST['mois'])?$_POST['mois']:null;
    $annee = isset($_POST['annee'])?$_POST['annee']:null;
     
    $server="l******";
    $user="********";
    $pass="*********";
    $db="qualite";
    mysql_connect($server,$user,$pass) or die('erreur de connexion');
    mysql_select_db($db) or die ('impossible de se connecter a la base');
    $sql1="SELECT count( id_reclamation ) as reclamation
    FROM reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee';";
     
    $query1 = mysql_query($sql1) or die('Erreur SQL !'.$sql1.'<br>'.mysql_error());
    //mysql_num_rows($query1);
    echo 'Pour le mois de '.$mois.'/'.$annee.', nous avons ';
    while ( $list3 = mysql_fetch_array( $query1 ) ) { echo $list3["reclamation"];}
    echo 'Réclamations.';
     
    echo '<SELECT name="id_critere" onchange="critere()">';
    $sql2="SELECT id_critere, nom_critere FROM critere;";
    $query2 = mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    echo '<option value="-1"> Faite votre Choix</option>';
    while ($list4 = mysql_fetch_array($query2))
    {
    echo '<option value='.$list4["id_critere"].'">'.$list4["nom_critere"].'</option>';
    }
    echo '</SELECT>';
     
    $sql3="SELECT id_critere, nom_critere FROM critere;";
    $query3 = mysql_query($sql3) or die('Erreur SQL !'.$sql3.'<br>'.mysql_error());
     
    $ServArray = array ();
    while($servicetab= mysql_fetch_array($query3)) {
    $ServArray[$servicetab['id_critere']][0] = $servicetab['id_critere'];
    $ServArray[$servicetab['id_critere']][1] = $servicetab['nom_critere'];
    }
    $sql31="SELECT id_critere, nom_critere FROM critere;";
    $query31 = mysql_query($sql31) or die('Erreur SQL !'.$sql31.'<br>'.mysql_error());
    $genres = array();
    foreach ($ServArray as $key => $val)
    {
    $sql4="SELECT count( id_eva_reclamation ) as total, nom_critere
    FROM eva_reclamation
    INNER JOIN critere ON critere.id_critere=eva_reclamation.id_critere
    INNER JOIN reclamation ON eva_reclamation.id_reclamation=reclamation.id_reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee'
    AND critere.id_critere IN($key) GROUP by nom_critere;";
    $query4 = mysql_query($sql4) or die('Erreur SQL !'.$sql4.'<br>'.mysql_error());
    while($ligne = mysql_fetch_assoc($query4)){
    echo '<br>'.$ligne["nom_critere"].'==>'.$ligne["total"].'<br>';
     
    $genres[$ligne['nom_critere']] = $ligne['total'];
    }
     
    }
     
    echo "<img src='graph.php?genres=".urlencode(serialize($genres))."' alt='Mon graphique'/>";
    ////////////////
     
    //echo '<pre>' . print_r($genres, true) . '</pre>';
    ?>	
    		</div>
     
    		<p id="footer">Essai pour le service Qualité section reclamation cliente</p>
    	</div>
    	</body>
    </html>
    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
     
    <?php
     
       // On vérifie que les données à afficher sur le graphique existent
       if(isset($_GET['genres']) === FALSE) {
       echo '<pre>pasok' . print_r($genres, true) . '</pre>';
          exit;
       }
    echo '<pre>test1' . print_r($genres, true) . '</pre>';
       // On récupère les valeurs à afficher sur le graphique dans $_GET['values'] et on les désérialize
       $data = @unserialize($_GET['genres']);
     
       // On vérifie que les données passées en GET sont correctes
       if(is_array($data) === FALSE) {
          exit;
       }
    echo '<pre>test2' . print_r($genres, true) . '</pre>';
     
      require_once('Artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
     
     
    ?>
    Donc j'ai la page corrigé

    Mon tableau a comme nom genres

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    echo "<img src='graph.php?genres=".urlencode(serialize($genres))."' alt='Mon graphique'/>";
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <?php
     
       // On vérifie que les données à afficher sur le graphique existent
       if(isset($_GET['genres']) === FALSE) {
       echo '<pre>pasok' . print_r($genres, true) . '</pre>';
          exit;
    Si dessus je recuperer les valeur recuperer en 'genres'.

    pourtant je n'ai toujours aucun affichage

    Merci pour ton aide.

  12. #12
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Tu ne dois rien ecrire dans ton graph.php puisque c'est une image.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  13. #13
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Comment ca? Je ne comprend pas.

    Désolé je n'arrive pas a comprendre. Il me faut combien de fichier php,

    Moi j'ai ma première page php qui exécute la requête mysql et l'enregistre d'une le tableau array puis la page graph ou j'ai les instruction pour créer mon graphique.


    Merci d'avance pour ton aide.

    guigui69

  14. #14
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Quand je dis rien ecrire, je veux dire pas d'echo, print, print_r ou autre.

    Quand tu fais $graph->draw() , cela retourne le contenu d'un fichier image.
    Donc si tu fais un print_r avant, le resultat du print_r est melangé dans le code de l'image.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  15. #15
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Bonjour j'ai corrigé mon erreur,


    Ma page principale:
    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
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
     
    <?php session_start(); ?>
    <?php
    if(!isset($_SESSION['login'])) {
    	include('login.php');
    	echo $_SESSION['login'];
    	echo 'Vous n\'êtes pas autoris´ à acceder à cette zone';
    	echo '<br>';
     
      exit;
    }
    else
    {
    }
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<title>Service réclamation</title>
    		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15" />
    		<meta http-equiv="Content-Style-Type" content="text/css" />
    		<meta http-equiv="Content-Language" content="fr" />
    <link rel="stylesheet" type="text/css" href="css/site.css" media="screen" />
    <link rel="stylesheet" type="text/css" href="css/print.css" media="print" />
    	<script type="text/javascript">
    <!--
    window.onload=montre;
    function montre(id) {
    var d = document.getElementById(id);
    	for (var i = 1; i<=10; i++) {
    		if (document.getElementById('smenu'+i)) {document.getElementById('smenu'+i).style.display='none';}
    	}
    if (d) {d.style.display='block';}
    }
    function getXhr(){
                                    var xhr = null; 
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
                                    return xhr;
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function critere(){
    				var xhr = getXhr();
     
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
    						leselect = xhr.responseText;
    						// On se sert de innerHTML pour rajouter les options a la liste
    						document.getElementById('information').innerHTML = leselect;
     
    						}
    				}
     
    				// Ici on va voir comment faire du post
    				xhr.open("POST","ajax_stats.php",true);
    				// ne pas oublier ça pour le post
    				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    				// ne pas oublier de poster les arguments
    				// ici, l'id de l'auteur
    				idauteur = document.getElementById('code_client').value;
    				//idauteur2 = document.getElementById('debut_date').value;
    				//idauteur3 = document.getElementById('fin_date').value;
    				//alert(idauteur);
    				var indexsite = document.getElementById('id_critere') 
    				idauteur = document.getElementById("id_critere").value
    				//xhr.send("idauteur2="+idauteur2);
    				//xhr.send("idauteur3="+idauteur3);
    			}
    //-->
    </script>
    	</head>
    	<body>
    	<div id="conteneur">		
    		<h1 id="header"><a href="3" title="Accueil"></a></h1>
     
    <dl id="menu">
     
    		<dt onclick="javascript:montre('smenu1');">Rèclamation</dt>
    			<dd id="smenu1">
    				<ul>
    					<li><a href="reclamation.php">Nouvelle Rèclamation</a></li>
     
    				</ul>
    			</dd>			
    		<dt onclick="javascript:montre('smenu2');">Action immédiate</dt>
     
    			<dd id="smenu2">
    				<ul>
    					<li><a href="action_immediate.php">Faire une Action Immédiate</a></li>
    					<li><a href="maj_action_immediate.php">Mise à jour Action immédiate</a></li>
    				</ul>
    			</dd>	
     
    		<dt onclick="javascript:montre('smenu3');">Evaluation réclamation</dt>
     
    			<dd id="smenu3">
    				<ul>
    					<li><a href="evaluation_reclamation.php"> Evaluation Réclamation</a></li><li><a href="maj_evaluation_reclamation.php"> Maj Evaluation Réclamation</a></li>
    					<li><a href="maj_fac.php"> Maj Action Corrective</a></li>
    				</ul>
    			</dd>
     
    		<dt onclick="javascript:montre('smenu4');">Recap</dt>
     
    			<dd id="smenu4">
    				<ul>
    					<li><a href="recap.php">Recap  par Client</a></li>
    					<li><a href="recla_par_fac.php">Reclamation / Fac</a></li>
     
    				</ul>
    			</dd>
     
    </dl>
     
    		<div id="contenu">
    			<h2>Stats</h2>
    <?php
    $mois = isset($_POST['mois'])?$_POST['mois']:null;
    $annee = isset($_POST['annee'])?$_POST['annee']:null;
     
    $server="*********";
    $user="*********";
    $pass="**********";
    $db="qualite";
    mysql_connect($server,$user,$pass) or die('erreur de connexion');
    mysql_select_db($db) or die ('impossible de se connecter a la base');
    $sql1="SELECT count( id_reclamation ) as reclamation
    FROM reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee';";
     
    $query1 = mysql_query($sql1) or die('Erreur SQL !'.$sql1.'<br>'.mysql_error());
    //mysql_num_rows($query1);
    echo 'Pour le mois de '.$mois.'/'.$annee.', nous avons ';
    while ( $list3 = mysql_fetch_array( $query1 ) ) { echo $list3["reclamation"];}
    echo 'Réclamations.';
     
    echo '<SELECT name="id_critere" onchange="critere()">';
    $sql2="SELECT id_critere, nom_critere FROM critere;";
    $query2 = mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    echo '<option value="-1"> Faite votre Choix</option>';
    while ($list4 = mysql_fetch_array($query2))
    {
    echo '<option value='.$list4["id_critere"].'">'.$list4["nom_critere"].'</option>';
    }
    echo '</SELECT>';
     
    $sql3="SELECT id_critere, nom_critere FROM critere;";
    $query3 = mysql_query($sql3) or die('Erreur SQL !'.$sql3.'<br>'.mysql_error());
     
    $ServArray = array ();
    while($servicetab= mysql_fetch_array($query3)) {
    $ServArray[$servicetab['id_critere']][0] = $servicetab['id_critere'];
    $ServArray[$servicetab['id_critere']][1] = $servicetab['nom_critere'];
    }
    $sql31="SELECT id_critere, nom_critere FROM critere;";
    $query31 = mysql_query($sql31) or die('Erreur SQL !'.$sql31.'<br>'.mysql_error());
    $genres = array();
    foreach ($ServArray as $key => $val)
    {
    $sql4="SELECT count( id_eva_reclamation ) as total, nom_critere
    FROM eva_reclamation
    INNER JOIN critere ON critere.id_critere=eva_reclamation.id_critere
    INNER JOIN reclamation ON eva_reclamation.id_reclamation=reclamation.id_reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee'
    AND critere.id_critere IN($key) GROUP by nom_critere;";
    $query4 = mysql_query($sql4) or die('Erreur SQL !'.$sql4.'<br>'.mysql_error());
    while($ligne = mysql_fetch_assoc($query4)){
    echo '<br>'.$ligne["nom_critere"].'==>'.$ligne["total"].'<br>';
     
    $genres[$ligne['nom_critere']] = $ligne['total'];
    }
     
    }
     
    echo "<img src='graph.php?values=".urlencode(serialize($genres))."' alt='Mon graphique'/>";
    ////////////////
     
    echo '<pre>' . print_r($genres, true) . '</pre>';
    ?>	
    		</div>
     
    		<p id="footer">Essai pour le service Qualité section reclamation cliente</p>
    	</div>
    	</body>
    </html>
    ma page graph.php:

    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
     
    <?php
     
       // On vérifie que les données à afficher sur le graphique existent
       if(isset($_GET['values']) === FALSE) {
          exit;
       }
       // On récupère les valeurs à afficher sur le graphique dans $_GET['values'] et on les désérialize
       $data = @unserialize($_GET['values']);
     
       // On vérifie que les données passées en GET sont correctes
       if(is_array($data) === FALSE) {
          exit;
       }
      require_once('Artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
     
     
    ?>
    Ou est-ce que j'ai commis encore une erreur ?

    Merci d'avance pour ton aide.

    guigui69

  16. #16
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Pour debugger tu peux ajouter dans ta premiere page.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    include("graph.php?values=".urlencode(serialize($genres))
    Et remplacer tes exit() par des exit("point x") dans ta page de graph pour controler le deroulement du script.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  17. #17
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Merci j'ai rajouter ton code:
    premiere page php
    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
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
     
    <?php session_start(); ?>
    <?php
    if(!isset($_SESSION['login'])) {
    	include('login.php');
    	echo $_SESSION['login'];
    	echo 'Vous n\'êtes pas autoris´ à acceder à cette zone';
    	echo '<br>';
     
      exit;
    }
    else
    {
    }
    ?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
    	<head>
    		<title>Service réclamation</title>
    		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15" />
    		<meta http-equiv="Content-Style-Type" content="text/css" />
    		<meta http-equiv="Content-Language" content="fr" />
    <link rel="stylesheet" type="text/css" href="css/site.css" media="screen" />
    <link rel="stylesheet" type="text/css" href="css/print.css" media="print" />
    	<script type="text/javascript">
    <!--
    window.onload=montre;
    function montre(id) {
    var d = document.getElementById(id);
    	for (var i = 1; i<=10; i++) {
    		if (document.getElementById('smenu'+i)) {document.getElementById('smenu'+i).style.display='none';}
    	}
    if (d) {d.style.display='block';}
    }
    function getXhr(){
                                    var xhr = null; 
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
                                    return xhr;
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function critere(){
    				var xhr = getXhr();
     
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
    						leselect = xhr.responseText;
    						// On se sert de innerHTML pour rajouter les options a la liste
    						document.getElementById('information').innerHTML = leselect;
     
    						}
    				}
     
    				// Ici on va voir comment faire du post
    				xhr.open("POST","ajax_stats.php",true);
    				// ne pas oublier ça pour le post
    				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    				// ne pas oublier de poster les arguments
    				// ici, l'id de l'auteur
    				idauteur = document.getElementById('code_client').value;
    				//idauteur2 = document.getElementById('debut_date').value;
    				//idauteur3 = document.getElementById('fin_date').value;
    				//alert(idauteur);
    				var indexsite = document.getElementById('id_critere') 
    				idauteur = document.getElementById("id_critere").value
    				//xhr.send("idauteur2="+idauteur2);
    				//xhr.send("idauteur3="+idauteur3);
    			}
    //-->
    </script>
    	</head>
    	<body>
    	<div id="conteneur">		
    		<h1 id="header"><a href="3" title="Accueil"></a></h1>
     
    <dl id="menu">
     
    		<dt onclick="javascript:montre('smenu1');">Rèclamation</dt>
    			<dd id="smenu1">
    				<ul>
    					<li><a href="reclamation.php">Nouvelle Rèclamation</a></li>
     
    				</ul>
    			</dd>			
    		<dt onclick="javascript:montre('smenu2');">Action immédiate</dt>
     
    			<dd id="smenu2">
    				<ul>
    					<li><a href="action_immediate.php">Faire une Action Immédiate</a></li>
    					<li><a href="maj_action_immediate.php">Mise à jour Action immédiate</a></li>
    				</ul>
    			</dd>	
     
    		<dt onclick="javascript:montre('smenu3');">Evaluation réclamation</dt>
     
    			<dd id="smenu3">
    				<ul>
    					<li><a href="evaluation_reclamation.php"> Evaluation Réclamation</a></li><li><a href="maj_evaluation_reclamation.php"> Maj Evaluation Réclamation</a></li>
    					<li><a href="maj_fac.php"> Maj Action Corrective</a></li>
    				</ul>
    			</dd>
     
    		<dt onclick="javascript:montre('smenu4');">Recap</dt>
     
    			<dd id="smenu4">
    				<ul>
    					<li><a href="recap.php">Recap  par Client</a></li>
    					<li><a href="recla_par_fac.php">Reclamation / Fac</a></li>
     
    				</ul>
    			</dd>
     
    </dl>
     
    		<div id="contenu">
    			<h2>Stats</h2>
    <?php
    $mois = isset($_POST['mois'])?$_POST['mois']:null;
    $annee = isset($_POST['annee'])?$_POST['annee']:null;
     
    $server="*****";
    $user="******";
    $pass="*******";
    $db="qualite";
    mysql_connect($server,$user,$pass) or die('erreur de connexion');
    mysql_select_db($db) or die ('impossible de se connecter a la base');
    $sql1="SELECT count( id_reclamation ) as reclamation
    FROM reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee';";
     
    $query1 = mysql_query($sql1) or die('Erreur SQL !'.$sql1.'<br>'.mysql_error());
    //mysql_num_rows($query1);
    echo 'Pour le mois de '.$mois.'/'.$annee.', nous avons ';
    while ( $list3 = mysql_fetch_array( $query1 ) ) { echo $list3["reclamation"];}
    echo 'Réclamations.';
     
    echo '<SELECT name="id_critere" onchange="critere()">';
    $sql2="SELECT id_critere, nom_critere FROM critere;";
    $query2 = mysql_query($sql2) or die('Erreur SQL !'.$sql2.'<br>'.mysql_error());
    echo '<option value="-1"> Faite votre Choix</option>';
    while ($list4 = mysql_fetch_array($query2))
    {
    echo '<option value='.$list4["id_critere"].'">'.$list4["nom_critere"].'</option>';
    }
    echo '</SELECT>';
     
    $sql3="SELECT id_critere, nom_critere FROM critere;";
    $query3 = mysql_query($sql3) or die('Erreur SQL !'.$sql3.'<br>'.mysql_error());
     
    $ServArray = array ();
    while($servicetab= mysql_fetch_array($query3)) {
    $ServArray[$servicetab['id_critere']][0] = $servicetab['id_critere'];
    $ServArray[$servicetab['id_critere']][1] = $servicetab['nom_critere'];
    }
    $sql31="SELECT id_critere, nom_critere FROM critere;";
    $query31 = mysql_query($sql31) or die('Erreur SQL !'.$sql31.'<br>'.mysql_error());
    $genres = array();
    foreach ($ServArray as $key => $val)
    {
    $sql4="SELECT count( id_eva_reclamation ) as total, nom_critere
    FROM eva_reclamation
    INNER JOIN critere ON critere.id_critere=eva_reclamation.id_critere
    INNER JOIN reclamation ON eva_reclamation.id_reclamation=reclamation.id_reclamation
    WHERE MONTH( date_reclamation ) = '$mois'
    AND YEAR( date_reclamation ) = '$annee'
    AND critere.id_critere IN($key) GROUP by nom_critere;";
    $query4 = mysql_query($sql4) or die('Erreur SQL !'.$sql4.'<br>'.mysql_error());
    while($ligne = mysql_fetch_assoc($query4)){
    echo '<br>'.$ligne["nom_critere"].'==>'.$ligne["total"].'<br>';
     
    $genres[$ligne['nom_critere']] = $ligne['total'];
    }
     
    }
    include("graph.php?values=".urlencode(serialize($genres)));
    //echo "<img src=\"graph.php?values=".urlencode(serialize($genres))."\" alt='Mon graphique'/>";
    ////////////////
     
    //echo '<pre>' . print_r($genres, true) . '</pre>';
    ?>	
    		</div>
     
    		<p id="footer">Essai pour le service Qualité section reclamation cliente</p>
    	</div>
    	</body>
    </html>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    include("graph.php?values=".urlencode(serialize($genres)));
    Graph.php
    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
     
    <?php
     
       // On vérifie que les données à afficher sur le graphique existent
       if(isset($_GET['values']) === FALSE) {
     
          exit("point x");
       }
       // On récupère les valeurs à afficher sur le graphique dans $_GET['values'] et on les désérialize
       $data = @unserialize($_GET['values']);
     
       // On vérifie que les données passées en GET sont correctes
       if(is_array($data) === FALSE) {
          exit;
       }
      require_once('Artichow/Pie.class.php');
     
    $graph = new Graph(450, 280);
     
    $graph->shadow->setPosition(Shadow::RIGHT_BOTTOM);
    $graph->shadow->setSize(4);
     
    $graph->setBackgroundGradient(
    	new LinearGradient(
    		new Color(240, 240, 240, 0),
    		new White,
    		0
    	)
    );
     
    $pie = new Pie(array_values($genres));
     
    $pie->setLabelPrecision(1);
     
    $pie->setLegend(array_keys($genres));
    $pie->legend->setPosition(1.45, .25);
     
    $pie->setCenter(.36, .58);
     
    $pie->setSize(.65, .65);
     
    $pie->set3D(5);
     
    $pie->title->set('Popularité pour le mois juin');
    $pie->title->move(0, -40);
    $pie->title->setFont(new TuffyBold(14));
    $pie->title->setBackgroundColor(new White(50));
    $pie->title->setPadding(5, 5, 2, 2);
    $pie->title->border->setColor(new Black());
     
    $graph->add($pie);
     
    $graph->draw();
     
     
    ?>
    Voila se qu'il me retourne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Warning: include(graph.php?values=a%3A2%3A%7Bs%3A10%3A%22Commercial%22%3Bs%3A1%3A%221%22%3Bs%3A9%3A%22T%E9l%E9vente%22%3Bs%3A1%3A%222%22%3B%7D) [function.include]: failed to open stream: No such file or directory in /var/www/qualite/v0.1a/stats2.php on line 191
     
    Warning: include() [function.include]: Failed opening 'graph.php?values=a%3A2%3A%7Bs%3A10%3A%22Commercial%22%3Bs%3A1%3A%221%22%3Bs%3A9%3A%22T%E9l%E9vente%22%3Bs%3A1%3A%222%22%3B%7D' for inclusion (include_path='.:/usr/share/php:/usr/share/pear') in /var/www/qualite/v0.1a/stats2.php on line 191
    Le problème viendrait-il de mes données?

    Merci pour ton aide

    guigui69

  18. #18
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Le fichier graph.php est dans le meme dossier que le fichier stats2.php ?
    Si non il faut adapter le chemin.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  19. #19
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Oui, les deux fichiers sont dans le même répertoire.

  20. #20
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    825
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 825
    Par défaut
    Est-ce correcte ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    include("graph.php?values=".urlencode(serialize($genres)));
    Si oui d'où peut venir mon erreur, les données ?

    merci

    guigui69

Discussions similaires

  1. [XL-2010] Construction d'un graphique au format camembert
    Par shakapouet dans le forum Excel
    Réponses: 5
    Dernier message: 31/07/2012, 10h50
  2. [Artichow] Afficher un camembert
    Par Sh4dow49 dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 10/09/2008, 11h45
  3. [ARTICHOW] Légendes et couleurs d'un graphe camembert
    Par L'aigle de Carthage dans le forum Langage
    Réponses: 10
    Dernier message: 09/05/2008, 17h29
  4. [Artichow] Problème au niveau des camemberts
    Par Sekigawa dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 18/04/2008, 10h22
  5. [JBuilder 7] Construction d'executable natif
    Par renaudfaucon dans le forum JBuilder
    Réponses: 3
    Dernier message: 24/11/2006, 22h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo