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

jQuery Discussion :

Fllot jQuery et php


Sujet :

jQuery

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2014
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2014
    Messages : 39
    Par défaut Fllot jQuery et php
    Bonjour à tous et toutes,



    Je suis étudiant en première année de BTS SIO (anciennement IG) et je suis actuellement en stage de fin d'année.

    Durant ce stage nous devont essayer de réaliser un projet, qui jusqu'à hier semblait plutôt "simple" car il suffisait de récupérer des valeurs d'une base de données (le nombre de fiches indexées) et une période (variant de 10j à 182j avant la date du jour) et mettre tout ceci dans un tableau (en 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
    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
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
     
    <?php
    // Connexion, sélection de la base de données
    include ('../connect.php');
    ?>
     
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
            <head>
                    <script language="javascript" type="text/javascript" src="jquery.js"></script>
                    <script language="javascript" type="text/javascript" src="jquery.flot.js"></script>
            </head>
            <body>
                    <form method="post" action="">
                            <?php
                                    // Transfert de la valeur de la DATE recuperee par le GET
                                    $jourj = $_GET['date'];
                                    echo "Date selectionnee : $jourj";
                            ?>
                            <br/>
                            <?php
                                    // Transfert de la valeur du num SAGES recupere par le GET
                                    $sages = $_GET['sages'];
                                    echo "Numero du SAGES : $sages";
                            ?>
                            <br/>
                            <p>
                                    Choisissez une periode pour votre graphique :
                                    <select name="menu_periode">
                                            <option value="0">- Selectionnez une periode -</option>
                                            <option value="10">Sur les 10j precedents</option>
                                            <option value="30">Sur les 30j precedents</option>
                                            <option value="60">Sur les 60j precedents</option>
                                            <option value="182">Sur les 180j precedents</option>
                                    </select>
                                    <br/>
                                    <input type="submit" value="Valider" title="Valider pour aller a la page selectionnee" />
                            </p>
                    </form>
    <?php
    if (isset($_POST['menu_periode']))
    {
    echo "--".$_POST['menu_periode']."--";
    }
    ?>
     
                    <table style="border-collapse: collapse">
                            <?php
                                    // Vérification si menu_periode existe
     
                                    if (isset($_POST['menu_periode']))
                                    {
                                            if ( $_POST['menu_periode'] == 10 )
                                            {
                                                    // Initialisation du jour envoyé dans le GET MOINS la periode selectionnee
                                                    $jourtableau=date('d-m-Y', strtotime($jourj. "-" .$_POST['menu_periode']. "DAY"));
                                                    $k = 1;
     
                                                    // Affiche la periode selectionnee
                                                    $jourj=date('d-m-Y',strtotime($jourj));
                                                    $jourperiode=date('d-m-Y', strtotime($jourtableau. "+ 1 DAY"));
                                                    echo "Periode du $jourperiode au $jourj";
     
                                                    echo "<td style=\"border:2px solid green\">PER PHY</td>";
                                                    while( $k < 11 )
                                                    {
                                                            // Initialisation des variables
                                                            $a=100;
                                                            $lu ="0";
                                                            $contenu="0";
                                                            $req="";
     
                                                            // Ajoute 1 jour a la date selectionnee
                                                            $jourfinw=date('d-m-Y', strtotime($jourtableau."+" .$k. "DAY"));
                                                            echo "<td style=\"border:2px solid green\">".substr($jourfinw,0,5)."";
     
    							// Requete SQL
                                                            $req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$
                                                            $res = pg_query($req);
                                                            // On met les valeurs obtenues dans un tableau
                                                            while ( $lu = pg_fetch_row ($res) )
                                                            {
                                                            $contenu="$lu[0]";
                                                            }
                                                            echo "<br/>$contenu</td>";
                                                            $k++;
     
    //#####################################################
    //##                                                 ##
    //##      MISE EN PLACE DU GRAPHIQUE                 ##
    //##                                                 ##
    //#####################################################
                                                    }
     
                                                    }
                                            }
     
                                            elseif ( $_POST['menu_periode'] == 30 )
                                            {
                                                    // Initialisation du jour envoyé dans le GET MOINS la periode selectionnee
                                                    $jourtableau=date('d-m-Y', strtotime($jourj. "-" .$_POST['menu_periode']. "DAY"));
                                                    $k = 1;
     
                                                    // Affiche la periode selectionnee
                                                    $jourj=date('d-m-Y',strtotime($jourj));
                                                    $jourperiode=date('d-m-Y', strtotime($jourtableau. "+ 1 DAY"));
                                                    echo "Periode du $jourperiode au $jourj";
     
                                                    echo "<td style=\"border:2px solid green\">PER PHY</td>";
                                                    // Boucle qui ajoute 1 jour pour atteindre le jour envoye dans le GET
                                                    while( $k < 31 )
                                                    {
                                                            // Initialisation des variables
                                                            $lu ="";
                                                            $contenu="0";
                                                            $req="";
     
                                                            // Ajoute 1 jour a la date selectionnee
                                                            $jourfinw=date('d-m-Y', strtotime($jourtableau."+" .$k. "DAY"));
                                                            echo "<td style=\"border:2px solid green\">".substr($jourfinw,0,5)."";
     
                                                            // Requete SQL
                                                            $req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$
                                                            $res = pg_query($req);
     
                                                            // On met les valeurs obtenues dans un tableau
                                                            while ($lu = pg_fetch_row ($res))
                                                            {
                                                            $contenu=$lu[0];
                                                            }
                                                            echo "<br/>$contenu</td>";
                                                            $k++;
                                                    }
                                            }
     
                                            elseif ( $_POST['menu_periode'] == 60 )
                                            {
                                                    // Initialisation du jour envoyé dans le GET MOINS la periode selectionnee
     
                                                    $jourtableau=date('d-m-Y', strtotime($jourj. "-" .$_POST['menu_periode']. "DAY"));
                                                    $k = 1;
     
                                                    // Affiche la periode selectionnee
                                                    $jourj=date('d-m-Y',strtotime($jourj));
                                                    $jourperiode=date('d-m-Y', strtotime($jourtableau. "+ 1 DAY"));
                                                    echo "Periode du $jourperiode au $jourj";
     
                                                    echo "<td style=\"border:2px solid green\">PER PHY</td>";
                                                    while( $k < 61 )
                                                    {
     
                                                            // Initialisation des variables
                                                            $lu ="";
                                                            $contenu="0";
                                                            $req="";
     
                                                            // Ajoute 1 jour a la date selectionnee
                                                            $jourfinw=date('d-m-Y', strtotime($jourtableau."+" .$k. "DAY"));
                                                            echo "<td style=\"border:2px solid green\">".substr($jourfinw,0,5)."";
                                                            // Requete SQL
                                                            $req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$
                                                            $res = pg_query($req);
     
                                                            // On met les valeurs obtenues dans un tableau
     
                                                            while ($lu = pg_fetch_row ($res))
                                                            {
                                                            $contenu=$lu[0];
                                                            }
                                                            echo "<br/>$contenu</td>";
                                                            $k++;
                                                    }
                                            }
     
                                            elseif ( $_POST['menu_periode'] == 182 )
                                            {
                                                    // Initialisation du jour envoyé dans le GET MOINS la periode selectionnee
                                                    $jourtableau=date('d-m-Y', strtotime($jourj. "-" .$_POST['menu_periode']. "DAY"));
                                                    $k = 7;
     
                                                    // Affiche la periode selectionnee
                                                    $jourj=date('d-m-Y',strtotime($jourj));
                                                    $jourperiode=date('d-m-Y', strtotime($jourtableau. "+ 7 DAY"));
                                                    echo "Periode du $jourperiode au $jourj (7j par 7j)";
     
                                                    echo "<td style=\"border:2px solid green\">PER PHY</td>";
                                                    while( $k < 183 )
                                                    {
                                                            // Initialisation des variables
                                                            $lu ="";
                                                            $contenu="0";
                                                            $req="";
     
                                                            // Ajoute 7 jours a la date selectionnee
                                                            $jourfinw=date('d-m-Y', strtotime($jourtableau."+" .$k. "DAY"));
                                                            echo "<td style=\"border:2px solid green\">".substr($jourfinw,0,5)."";
                                                            // Requete SQL
                                                            $req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$
                                                            $res = pg_query($req);
     
                                                            // On met les valeurs obtenues dans un tableau
                                                            while ($lu = pg_fetch_row ($res))
                                                            {
                                                            $contenu=$lu[0];
                                                            }
                                                            echo "<br/>$contenu</td>";
                                                            $k=$k+7;
                                                    }
                                            }
     
                            ?>
     
                    </table>
            </body>
    </html>
    (désolé pour le manque de soin mais notre tuteur étant revenu 2 semaines avant la fin du stage alors que nous n'avons pas encore eu le sujet du projet j'ai fais au plus vite)

    Et maintenant il me demande de tracer une courbe avec Javascript (jquery), n'ayant aucunes notions en javascript, j'ai tourner un peu à droite et à gauche pour trouver quelque chose pour m'aider mais rien...

    Mon tuteur n'utilise pas javascript (ou peu) donc je n'ai pas réellement d'aide autour de moi.

    J'ai essayé de mettre ce code (au niveau de l'insertion du graphique) mais rien à y faire :

    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
     
    //#####################################################
    //##                                                 ##
    //##      MISE EN PLACE DU GRAPHIQUE                 ##
    //##                                                 ##
    //#####################################################
                                                    }
                            ?>
                                                            <div id="placeholder" style="width:800px;height:500px;"></div>
                                                            <script type="text/javascript">
                                                                    $(function () {
                                                                            //var d1 = [];
                                                                            //for (var i = 0; i < 14; i += 0,5)
                                                                            //    d1.push([i, Math.sin(i)]);
     
                                                                            var d2 = [[0, 6], [1, 8], [3, 5], [4, 13]];
                                                                            var d4 = 
                                                                                    [
                                                                                    [0, 0],
                                                                                    [<?php echo $jourfinw ; ?>, <?php echo $contenu ;?>]
                                                                                    ];
                                                                            var d5 =
                                                                                    [
                                                                                    [10,10],
                                                                                    [15,15],
                                                                                    [20,20]
                                                                                    ];
     
                                                                            // a null signifies separate line segments
                                                                            var d3 = [[0, 12], [7, 12], null, [7, 2.5], [12, 2.5]];
     
                                                                            //  AFFICHE LES COURBES
                                                                            //$.plot($("#placeholder"), [ d1 ]);
                                                                            $.plot($("#placeholder"), [ d2, d4, d5, d3 ]);
                                                                    });
                                                            </script>
                            <?php

    Mon but est d'obtenir une courbe avec les valeurs dans $contenu et pouvoir afficher en abscisse (x) les dates sous la forme 12-06.



    Je m'en remet à vous pour toutes aides qui vous pourriez m'apporter

    Merci,

    Cordialement,

    Tanaes.

  2. #2
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2014
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2014
    Messages : 39
    Par défaut
    J'ai réussi à récupérer les valeurs de $contenu , sauf quand sa valeur vaut "0", elle ne s'affiche pas dans le graphique...

    Quelqu'un aurait une idée ?

    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
     
    <div id="graph1" style="width:800px;height:500px;"></div>
    <script type="text/javascript">
    $(function () {
       <!--var d3 = [[0, 6], [1, 8], [3, 5], [4, 13]];-->
       <!--$.plot($("#placeholder3"), [ d3 ]);-->
     
    var options = {
     
    points: {
            show: true,
            radius: 3
        }
    };
     
    <?php
    //echo "   var d3 = [[0, 6], [1, 8], [3, 0], [4, 13], [5, 50]];";
    echo "   var data = [";
    $cpt=0;
     
    include ('../connect.php');
    // Requete SQL
    //$req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$jourfinw.' 00:00:00\' and \''.$jourfinw.' 23:59:59\'';
    $req = 'select "SPP_NB_IND" from "STAT_PERPHY" where "SPP_SAGES" = \''.$sages.'\' AND "SPP_DATE" between \''.$jourtableau.' 00:00:00\' and \''.$jourfinw.' 23:59:59\'';
    $res = pg_query($req);
    // On met les valeurs obtenues dans un table
    while ( $row = pg_fetch_assoc ($res) )
    {
     //echo $row['SPP_NB_IND']."<br>"; 
     $var=$row['SPP_NB_IND']; 
     echo "[$cpt,$var],";
     $cpt++;
    }
    echo "];";
     
     
    echo "   $.plot($(\"#graph1\"), [ data, options ]);";
     
     
    ?>
    });   
    </script>
    Et second soucis, je n'arrive pas à afficher les points sur la courbes avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    var options = {
     
    points: {
            show: true,
            radius: 3
        }
    };
    est-ce à cause que ma méthode ne prenne pas compte de la valeur "0" ?



    Cordialement.

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

Discussions similaires

  1. Récupérer des données de jquery avec php
    Par Mo_Poly dans le forum jQuery
    Réponses: 3
    Dernier message: 08/10/2009, 17h54
  2. Réponses: 8
    Dernier message: 08/10/2009, 11h31
  3. Jquery,Ajax,PHP et transfert de donnée
    Par Samolo dans le forum jQuery
    Réponses: 2
    Dernier message: 14/09/2009, 05h36
  4. Encodage de JQUERY vers PHP
    Par mica94 dans le forum jQuery
    Réponses: 2
    Dernier message: 26/08/2009, 20h15
  5. jQuery + Ajax + PHP (PB avec l'url)
    Par JeePI196 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 25/04/2009, 19h22

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