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 :

[JpGraph] Générer un graphique JPGraph avec une connexion PostGres


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Membre à l'essai
    Homme Profil pro
    Administrateur SIG
    Inscrit en
    Novembre 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Administrateur SIG
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2010
    Messages : 13
    Points : 10
    Points
    10
    Par défaut [JpGraph] Générer un graphique JPGraph avec une connexion PostGres
    Bonjour,

    Mon niveau PHP est débutant, mais j'arrive à générer des tableaux automatiques (b de naissances) avec des données issues d'une base PostGres avec une variable en entrée (nom de la commune).
    J'aimerais maintenant pouvoir associer un graphique.
    J'ai réussi à installer la bibliothèque JpGraph, et j'arrive à afficher le grahique.

    Dès que je veux lui entrée les valeurs de ma base, il affiche une page blanche.

    Question 1 : comment faire pour intégrer une connexion Postgres avant la génération du tableau et récupérer les données dans le Graphique courbe (code ci-dessous)
    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
     
     
    <?php 
    include ("c:\jpgraph\src\jpgraph.php");
    include ("c:\jpgraph\src\jpgraph_line.php");
     
    // connexion à la base 
    $user='utilisateur';
    $pass='util';
    $dsn='pgsql:host=localhost;dbname=sigoval1';
     
    try{
    	$dbh= new PDO($dsn,$user,$pass);
    }
    catch(PDOException $e) {
    	die ("Erreur!:".$e->getMessage());
    }
     
    $sql="SELECT naisd01,naisd02 FROM pop_etatcivil.naissance WHERE codgeo='60175'"
    $resultat=$dbh->query($sql);
    // insertion des données ici
    while ($row=$resultat->fetch()){
    $ydata = array(row[naids01],row[naids01]);
    }
    // Creation du graphique
    $graph = new Graph(300,200); 
    $graph->SetScale("textlin");
     // On élargit les marges pour pouvoir placer les légendes (gauche, droite, haut, bas)
         $graph->img->SetMargin(40,20,20,40);
         $graph->title->Set('Evolution de la population depuis 1968');
         $graph->xaxis->title->Set('Source : Insee recensement de la population 2009');
         $graph->yaxis->title->Set('');
    // Création du système de points
    $lineplot=new LinePlot($ydata);
     
    // On rajoute les points au graphique
    $graph->Add($lineplot);
     
    // Affichage
    $graph->Stroke();
     
    ?>
    Question 2 : Si j'arrive à solutionner ce pb, j'aimerais savoir comment envoyer en dynamique la variable [codgeo] à ce tableau.

    Merci pour votre aide.

  2. #2
    Membre éclairé Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    595
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 595
    Points : 879
    Points
    879
    Par défaut
    Bonjour
    Le plus simple consiste à créer 2 fichier
    • le fichier qui crée le graphique
    • le fichier qui affiche le graphique créé

    ce deuxième fichier doit contenir l'affichage du graphe créé par le premier fichier monGraphique.php sous forme d'appel à une image
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <img src="monGraphique.php" width="240" height="240" />;
    Cela te permet d'intégrer ton graphique dans une page html avec texte et autre graphes.
    pour la valeur a transmettre en dynamique, tu fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <img src="monGraphique.php?valeuratransmettre=$lavaleur" width="240" height="240" />;
    que tu récupères dans fichier monGraphique.php avec un $_request['valeuratransmettre']
    Participez vous aussi !
    Message utile
    Discussion résolue

  3. #3
    Membre à l'essai
    Homme Profil pro
    Administrateur SIG
    Inscrit en
    Novembre 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Administrateur SIG
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2010
    Messages : 13
    Points : 10
    Points
    10
    Par défaut
    Bonjour,

    Merci pour cette réponse, mais j'avais testé cette solution, et cela ne marche pas. Dès qu'on insère un ligne de commande dans mongraph.php (qui génère le graph), le graph ne s'affiche plus.
    La synthaxe d'envoi de la valeur ne pose pas depb.
    Ligne de commande d'insertion dans mon fichier hml/php
    <img src="graph1.php?codgeo=$codgeo" alt="Affichage du graphique impossible"/>
    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
    <?php // content="text/plain; charset=utf-8"
    include ("c:\jpgraph\src\jpgraph.php");
    include ("c:\jpgraph\src\jpgraph_line.php");
    $_request['codgeo'] ==> dès que cette ligne est insérée, le graph ne s'afiche plus
    $datay1 = array(20,15,23,15);
    
    
    // Setup the graph
    $graph = new Graph(300,250);
    $graph->SetScale("textlin");
    
    $theme_class=new UniversalTheme;
    
    $graph->SetTheme($theme_class);
    $graph->img->SetAntiAliasing(false);
    $graph->title->Set('Titre');
    $graph->SetBox(false);
    
    $graph->img->SetAntiAliasing();
    
    $graph->yaxis->HideZeroLabel();
    $graph->yaxis->HideLine(false);
    $graph->yaxis->HideTicks(false,false);
    
    $graph->xgrid->Show();
    $graph->xgrid->SetLineStyle("solid");
    $graph->xaxis->SetTickLabels(array('2001','2002','2003','2004'));
    $graph->xgrid->SetColor('#E3E3E3');
    
    // Create the first line
    $p1 = new LinePlot($datay1);
    $graph->Add($p1);
    $p1->SetColor("#6495ED");
    $p1->SetLegend('Line 1');
    
    
    
    $graph->legend->SetFrameWeight(1);
    
    // Output line
    $graph->Stroke();
    
    ?>
    J'ai vu sur le forum, pour ceux qui utilisent MySQL qu'il parle de session PLH à créer. Mais je ne sais pas comment cela fonctionne.

    Merci en tout de votre réponse. J'essaye de progresser en prog mois qui suit issu du monde universitaire/Géographie

  4. #4
    Membre éclairé Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    595
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 595
    Points : 879
    Points
    879
    Par défaut
    Je viens de tester et ça fonctionne parfaitement.
    Voici le fichier générant le graphique :
    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
    <?php
    require_once ("../include/jpgraph/jpgraph.php"); // remettre ton chemin
    require_once ("../include/jpgraph/jpgraph_line.php");
     
    $codgeo=$_REQUEST['codgeo']; // récupération de codgeo
    $datay1 = array(20,15,23,15);
     
     
    // Setup the graph
    $graph = new Graph(300,250);
    $graph->SetScale("textlin");
     
    $theme_class=new UniversalTheme;
     
    $graph->SetTheme($theme_class);
    $graph->img->SetAntiAliasing(false);
    $graph->title->Set($codgeo); // le titre s'affiche en provenance de codgeo fourni par le second fichier
    $graph->SetBox(false);
     
    $graph->img->SetAntiAliasing();
     
    $graph->yaxis->HideZeroLabel();
    $graph->yaxis->HideLine(false);
    $graph->yaxis->HideTicks(false,false);
     
    $graph->xgrid->Show();
    $graph->xgrid->SetLineStyle("solid");
    $graph->xaxis->SetTickLabels(array('2001','2002','2003','2004'));
    $graph->xgrid->SetColor('#E3E3E3');
     
    // Create the first line
    $p1 = new LinePlot($datay1);
    $graph->Add($p1);
    $p1->SetColor("#6495ED");
    $p1->SetLegend('Line 1');
     
    $graph->legend->SetFrameWeight(1);
     
    // Output line
    $graph->Stroke();
    ?>

    et le fichier appelant contient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo "<img src='./include/test_jpgraph_21.php?codgeo=123456789'>";
    Tu dois bien sur mettre le bon chemin mais chez moi ça donne :



    Tu peux remarquer que j'ai mis la valeur de codgeo en titre ...

    Yves.
    Images attachées Images attachées  
    Participez vous aussi !
    Message utile
    Discussion résolue

  5. #5
    Membre à l'essai
    Homme Profil pro
    Administrateur SIG
    Inscrit en
    Novembre 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Administrateur SIG
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2010
    Messages : 13
    Points : 10
    Points
    10
    Par défaut
    Ok super, ça marche pour cette étape.

    Je vais maintenant ressayer de faire ma connexion à la base pour récupérer les valeurs renvoyées pour le codgeo reçu.

    Merci bcp pour ton aide,

    Bonnes fêtes

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [carte graphique] Probleme avec une 6800GS
    Par OjBarbare dans le forum Composants
    Réponses: 5
    Dernier message: 14/09/2006, 09h35
  2. [JpGraph] Générer un graphique à partir d'une requête
    Par shun dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 31/01/2006, 19h24
  3. Pb ResultSet avec une connexion ODBC MS SQL Server
    Par Néo-Tony dans le forum JDBC
    Réponses: 17
    Dernier message: 24/01/2006, 13h48
  4. Problèmes d'accent avec une connexion ODBC et ADO
    Par michael.jacques dans le forum Bases de données
    Réponses: 3
    Dernier message: 10/03/2005, 15h36
  5. Champs BLOB avec une connexion ADO
    Par Ol' dans le forum Bases de données
    Réponses: 6
    Dernier message: 18/05/2004, 19h21

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