Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

CRÉATION D'UNE IMAGE DE STATISTIQUE : LE CAMEMBERT


Information sur la source

Catégorie :Graphique Classé sous : camembert, gd, statistique, graphique, image Niveau : Initié Date de création : 23/09/2005 Date de mise à jour : 23/09/2005 19:53:09 Vu : 12 255

Note :
8,13 / 10 - par 8 personnes
8,13 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (19)
Ajouter un commentaire et/ou une note

Description

Cliquez pour voir la capture en taille normale
Un petit camembert parametrable pour les stats ;)

(parametrables :
?id1=nb1&id2=nb2&id3=nb3&id4=nb4&id5=nb5&pid1=nom1&pid2=nom2&pid3=nom3&pid4=nom4&pid5=nom5 )
 

Source

  • <?
  • if(isset($_GET['id1']) && isset($_GET['id2']) && isset($_GET['id3']) && isset($_GET['id4']) && isset($_GET['id5']) && isset($_GET['pid1']) && isset($_GET['pid2']) && isset($_GET['pid3']) && isset($_GET['pid4']) && isset($_GET['pid5']))
  • {
  • /*
  • ** Graphique sectoriel au format GIF
  • */
  • /*
  • ** Convertir les degrés en radians
  • */
  • function radians($degrees)
  • {
  • return($degrees * (pi()/180.0));
  • }
  • /*
  • ** prendre x,y dans le cercle,
  • ** centre = 0,0
  • */
  • function circle_point($degrees, $diameter)
  • {
  • $x = cos(radians($degrees)) * ($diameter/2);
  • $y = sin(radians($degrees)) * ($diameter/2);
  • return (array($x, $y));
  • }
  • //remplir les paramètres
  • $ChartDiameter = 300;
  • $ChartFont = 5;
  • $ChartFontHeight = imagefontheight($ChartFont);
  • $ChartData = array($_GET['id1'], $_GET['id2'],
  • $_GET['id3'], $_GET['id4'], $_GET['id5']);
  • $ChartLabel = array($_GET['pid1'], $_GET['pid2'],
  • $_GET['pid3'], $_GET['pid4'], $_GET['pid5']);
  • //déterminer la taille du graphique
  • $ChartWidth = $ChartDiameter + 20;
  • $ChartHeight = $ChartDiameter + 20 +
  • (($ChartFontHeight + 2) * count($ChartData));
  • $ChartTotal = "";
  • //détermine le total de toutes les valeurs
  • for($index = 0; $index < count($ChartData); $index++)
  • {
  • $ChartTotal += $ChartData[$index];
  • }
  • $ChartCenterX = $ChartDiameter/2 + 10;
  • $ChartCenterY = $ChartDiameter/2 + 10;
  • //image
  • $image = imagecreate($ChartWidth, $ChartHeight);
  • //couleurs
  • $colorBody = imagecolorallocate($image, 0xFF, 0xFF, 0xFF);
  • $colorBorder = imagecolorallocate($image, 0x00, 0x00, 0x00);
  • $colorText = imagecolorallocate($image, 0x00, 0x00, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0xFF, 0x00, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0xFF, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0x00, 0xFF);
  • $colorSlice[] = imagecolorallocate($image, 0xFF, 0xFF, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0xFF, 0x00, 0xFF);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0xFF, 0xFF);
  • $colorSlice[] = imagecolorallocate($image, 0x99, 0x00, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0x99, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0x00, 0x99);
  • $colorSlice[] = imagecolorallocate($image, 0x99, 0x99, 0x00);
  • $colorSlice[] = imagecolorallocate($image, 0x99, 0x00, 0x99);
  • $colorSlice[] = imagecolorallocate($image, 0x00, 0x99, 0x99);
  • //arrière-plan
  • imagefill($image, 0, 0, $colorBody);
  • /*
  • ** Dessiner chaque portion
  • */
  • $Degrees = 0;
  • for($index = 0; $index < count($ChartData); $index++)
  • {
  • $StartDegrees = round($Degrees);
  • $Degrees += (($ChartData[$index]/$ChartTotal)*360);
  • $EndDegrees = round($Degrees);
  • $CurrentColor = $colorSlice[$index%(count($colorSlice))];
  • //dessiner un arc
  • imagearc($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • $ChartDiameter,
  • $ChartDiameter,
  • $StartDegrees,
  • $EndDegrees,
  • $CurrentColor);
  • //Tracer le début de la ligne à partir du centre
  • list($ArcX, $ArcY) = circle_point($StartDegrees, $ChartDiameter);
  • imageline($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • floor($ChartCenterX + $ArcX),
  • floor($ChartCenterY + $ArcY),
  • $CurrentColor);
  • //dessiner la fin de la ligne
  • list($ArcX, $ArcY) = circle_point($EndDegrees, $ChartDiameter);
  • imageline($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • ceil($ChartCenterX + $ArcX),
  • ceil($ChartCenterY + $ArcY),
  • $CurrentColor);
  • //remplir les portions
  • $MidPoint = round((($EndDegrees - $StartDegrees)/2) + $StartDegrees);
  • list($ArcX, $ArcY) = circle_point($MidPoint, $ChartDiameter/2);
  • imagefilltoborder($image,
  • floor($ChartCenterX + $ArcX),
  • floor($ChartCenterY + $ArcY),
  • $CurrentColor,
  • $CurrentColor);
  • }
  • //la bordure
  • imagearc($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • $ChartDiameter,
  • $ChartDiameter,
  • 0,
  • 180,
  • $colorBorder);
  • imagearc($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • $ChartDiameter,
  • $ChartDiameter,
  • 180,
  • 360,
  • $colorBorder);
  • imagearc($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • $ChartDiameter+7,
  • $ChartDiameter+7,
  • 0,
  • 180,
  • $colorBorder);
  • imagearc($image,
  • $ChartCenterX,
  • $ChartCenterY,
  • $ChartDiameter+7,
  • $ChartDiameter+7,
  • 180,
  • 360,
  • $colorBorder);
  • imagefilltoborder($image,
  • floor($ChartCenterX + ($ChartDiameter/2) + 2),
  • $ChartCenterY,
  • $colorBorder,
  • $colorBorder);
  • //la légende
  • for($index = 0; $index < count($ChartData); $index++)
  • {
  • $CurrentColor = $colorSlice[$index%(count($colorSlice))];
  • $LineY = $ChartDiameter + 20 + ($index*($ChartFontHeight+2));
  • //la couleur des boîtes
  • imagerectangle($image,
  • 10,
  • $LineY,
  • 10 + $ChartFontHeight,
  • $LineY+$ChartFontHeight,
  • $colorBorder);
  • imagefilltoborder($image,
  • 12,
  • $LineY + 2,
  • $colorBorder,
  • $CurrentColor);
  • //Les titres
  • imagestring($image,
  • $ChartFont,
  • 20 + $ChartFontHeight,
  • $LineY,
  • "$ChartLabel[$index]: $ChartData[$index]",
  • $colorText);
  • }
  • //afficher l'image
  • header("Content-type: image/gif");
  • imagegif($image);
  • }else{
  • echo '<fieldset style="position:absolute;border-color:#0000FF;border:1 solid"><b>Une erreur c\'est produite lors de la création du graphique :<br><li><font color=red>Tout les Arguments ne sont pas spécifier</b></font></fieldset>';
  • }
  • ?>
<?


if(isset($_GET['id1']) && isset($_GET['id2']) && isset($_GET['id3']) && isset($_GET['id4']) && isset($_GET['id5']) && isset($_GET['pid1']) && isset($_GET['pid2']) && isset($_GET['pid3']) && isset($_GET['pid4']) && isset($_GET['pid5']))
{

    /*
    ** Graphique sectoriel au format GIF
    */


    /*
    ** Convertir les degrés en radians
    */
    function radians($degrees)
    {
        return($degrees * (pi()/180.0));
    }

    /*
    ** prendre x,y dans le cercle,
    ** centre = 0,0
    */
      function circle_point($degrees, $diameter)
      {
        $x = cos(radians($degrees)) * ($diameter/2);
        $y = sin(radians($degrees)) * ($diameter/2);

        return (array($x, $y));
      }


    //remplir les paramètres
    $ChartDiameter = 300;
    $ChartFont = 5;
    $ChartFontHeight = imagefontheight($ChartFont);
	$ChartData = array($_GET['id1'], $_GET['id2'],
        $_GET['id3'], $_GET['id4'], $_GET['id5']);
    $ChartLabel = array($_GET['pid1'], $_GET['pid2'],
        $_GET['pid3'], $_GET['pid4'], $_GET['pid5']);


    //déterminer la taille du graphique
    $ChartWidth = $ChartDiameter + 20;
    $ChartHeight = $ChartDiameter + 20 +
        (($ChartFontHeight + 2) * count($ChartData));

	$ChartTotal = "";	

    //détermine le total de toutes les valeurs
    for($index = 0; $index < count($ChartData); $index++)
    {
        $ChartTotal += $ChartData[$index];
    }

    $ChartCenterX = $ChartDiameter/2 + 10;
    $ChartCenterY = $ChartDiameter/2 + 10;


    //image
    $image = imagecreate($ChartWidth, $ChartHeight);

    //couleurs
    $colorBody = imagecolorallocate($image, 0xFF, 0xFF, 0xFF);
    $colorBorder = imagecolorallocate($image, 0x00, 0x00, 0x00);
    $colorText = imagecolorallocate($image, 0x00, 0x00, 0x00);

    $colorSlice[] = imagecolorallocate($image, 0xFF, 0x00, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0xFF, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0x00, 0xFF);
    $colorSlice[] = imagecolorallocate($image, 0xFF, 0xFF, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0xFF, 0x00, 0xFF);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0xFF, 0xFF);
    $colorSlice[] = imagecolorallocate($image, 0x99, 0x00, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0x99, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0x00, 0x99);
    $colorSlice[] = imagecolorallocate($image, 0x99, 0x99, 0x00);
    $colorSlice[] = imagecolorallocate($image, 0x99, 0x00, 0x99);
    $colorSlice[] = imagecolorallocate($image, 0x00, 0x99, 0x99);

    //arrière-plan
    imagefill($image, 0, 0, $colorBody);


    /*
    ** Dessiner chaque portion
    */
    $Degrees = 0;
    for($index = 0; $index < count($ChartData); $index++)
    {
        $StartDegrees = round($Degrees);
        $Degrees += (($ChartData[$index]/$ChartTotal)*360);
        $EndDegrees = round($Degrees);

        $CurrentColor = $colorSlice[$index%(count($colorSlice))];

        //dessiner un arc
        imagearc($image,
            $ChartCenterX,
            $ChartCenterY,
            $ChartDiameter,
            $ChartDiameter,
            $StartDegrees,
            $EndDegrees,
            $CurrentColor);

        //Tracer le début de la ligne à partir du centre
        list($ArcX, $ArcY) = circle_point($StartDegrees, $ChartDiameter);
        imageline($image,
            $ChartCenterX,
            $ChartCenterY,
            floor($ChartCenterX + $ArcX),
            floor($ChartCenterY + $ArcY),
            $CurrentColor);


        //dessiner la fin de la ligne
        list($ArcX, $ArcY) = circle_point($EndDegrees, $ChartDiameter);
        imageline($image,
            $ChartCenterX,
            $ChartCenterY,
            ceil($ChartCenterX + $ArcX),
            ceil($ChartCenterY + $ArcY),
            $CurrentColor);

        //remplir les portions
        $MidPoint = round((($EndDegrees - $StartDegrees)/2) +  $StartDegrees);
        list($ArcX, $ArcY) = circle_point($MidPoint, $ChartDiameter/2);
        imagefilltoborder($image,
            floor($ChartCenterX + $ArcX),
            floor($ChartCenterY + $ArcY),
            $CurrentColor,
            $CurrentColor);

    }


    //la bordure
    imagearc($image,
        $ChartCenterX,
        $ChartCenterY,
        $ChartDiameter,
        $ChartDiameter,
        0,
        180,
        $colorBorder);

    imagearc($image,
        $ChartCenterX,
        $ChartCenterY,
        $ChartDiameter,
        $ChartDiameter,
        180,
        360,
        $colorBorder);


    imagearc($image,
        $ChartCenterX,
        $ChartCenterY,
        $ChartDiameter+7,
        $ChartDiameter+7,
        0,
        180,
        $colorBorder);

    imagearc($image,
        $ChartCenterX,
        $ChartCenterY,
        $ChartDiameter+7,
        $ChartDiameter+7,
        180,
        360,
        $colorBorder);


    imagefilltoborder($image,
        floor($ChartCenterX +  ($ChartDiameter/2) +  2),
        $ChartCenterY,
        $colorBorder,
        $colorBorder);


    //la légende
    for($index = 0; $index < count($ChartData); $index++)
    {
        $CurrentColor = $colorSlice[$index%(count($colorSlice))];
        $LineY = $ChartDiameter + 20 +  ($index*($ChartFontHeight+2));

        //la couleur des boîtes
        imagerectangle($image,
            10,
            $LineY,
            10 + $ChartFontHeight,
            $LineY+$ChartFontHeight,
            $colorBorder);

        imagefilltoborder($image,
            12,
            $LineY + 2,
            $colorBorder,
            $CurrentColor);

        //Les titres
        imagestring($image,
            $ChartFont,
            20 + $ChartFontHeight,
            $LineY,
            "$ChartLabel[$index]: $ChartData[$index]",
            $colorText);


    }


    //afficher l'image
    header("Content-type: image/gif");
    imagegif($image);

}else{


	echo '<fieldset style="position:absolute;border-color:#0000FF;border:1 solid"><b>Une erreur c\'est produite lors de la création du graphique :<br><li><font color=red>Tout les Arguments ne sont pas spécifier</b></font></fieldset>';


}


?>

Historique

23 septembre 2005 19:52:08 :
rajout de l'url :)
23 septembre 2005 19:53:09 :
 

Commentaires et avis

signaler à un administrateur
Commentaire de wizard512 le 24/09/2005 14:39:22

Idéale pour les statistiques (ou pour les impots ^^) nan ?

signaler à un administrateur
Commentaire de Lucyberad le 24/09/2005 17:27:58

bel exemple d'utilisation de la librairie GD.
merci pour cette belle source.

L U C Y I3 E R @ D

signaler à un administrateur
Commentaire de wizard512 le 24/09/2005 17:47:50

Merci :)

signaler à un administrateur
Commentaire de Shisui le 24/09/2005 22:56:17

Vu, revu et re-revu sur le net ce code, le leech c'est mal :p
Rien qu'en cherchant cette ligne :
for($index = 0; $index < count($ChartData); $index++)
sur google on trouve des dizaines de sites qui proposent exactement ce code, certains datant de 2001 ...
Exemple sur : http://members.shaw.ca/webstudy/php/makepie.htm
Je note pas encore, des fois que ca soit vraiment ton code ce qui m'étonnerait fortement, mais si c'est pas le tient alors 2 c'est la note maximale à te mettre pour la traduction (et encore, que des commentaires et elle est mauvaise ...) et le rajout d'une condition ...

signaler à un administrateur
Commentaire de Lucyberad le 25/09/2005 01:38:29

c'est peut-etre du revu mais c du bon quand meme,
ce code as la particularité de bien faire ressortir l'algorythme, il as une bonne structure. il est de ce fait tres abordable sur la creaion de form en librairie GD pour les debutant. il existent des camenbert 3d mais la c'est moins clair pour ceux la.
donc nous avons un code propre que je n'ai pas vraiment cu sur les autre camenberts.
sinon je tien a souligner quand meme (sauf si c'est du copier auquel cas je trouve ca navrant) que wizard nous fourni une source, crachons pas dessus !
critiquons, disont c'est de la doube ou c'est bien en justifiant bien sur.
donc cette fourine fourni de bonne base au debutant.
par contre je me repete mais si la source est du copié d'une autre de ce site c navrant, si elle est pas sur ce site mais vien d'une autre presonne, ca aurait été bien de le signaler.

sur ce
@+
L U C Y I3 E R @ D

signaler à un administrateur
Commentaire de wizard512 le 25/09/2005 10:36:33

Merci L U C Y I3 E R @ D je tien a préciser que cette source n'ai :

1) pas de moi
2) pas du copier coller (j'ai taper chaque caractère [je l'ai trouver sur un des livres que jai acheter])

signaler à un administrateur
Commentaire de Shisui le 25/09/2005 11:20:20

C'est bien de le préciser mais t'aurait pu le dire avant dans la présentation de ta source :p

Et je n'ai pas dit que cette source était une daube, j'ai dit que c'etait navrant de présenter une source qui n'est pas la sienne :) Donc bon elle est pas de toi donc je noterais pas mais la prochaine donne tes sources ca évitera les confusions :p

signaler à un administrateur
Commentaire de wizard512 le 25/09/2005 11:22:37

dls c'est de ma faute :p
Mais dans toutes les source que j'ai déposer ils y en a que 2 qui ne sont pas de moi celle la et puis l'autre graphique (CRÉATION D'UN HISTOGRAMMES IDÉALE POUR LES STATISTIQUE) voila ^^

signaler à un administrateur
Commentaire de wizard512 le 25/09/2005 11:26:21

Cette source est issu d'un livre se nommant "Programmation en PHP (nouvelle edition)"  CampusPress Référence et a été écrit par LEON ATKINSON sortie en 2000 (vachement vieu mais éfficasse)

signaler à un administrateur
Commentaire de Lucyberad le 25/09/2005 13:59:23

Shisui >> 100% d'accord avec toi

signaler à un administrateur
Commentaire de wizard512 le 25/09/2005 15:19:45

Merci ;)

signaler à un administrateur
Commentaire de EMSIEN le 25/09/2005 17:33:53

je serais ammené à travailler avec Jpgraph dès demain pour mon stage et je ne trouve qu'une doc en anglais si vous avez une bonne donc en fr ça sera cool merci.
http://ntic.blogspirit.com

signaler à un administrateur
Commentaire de wizard512 le 25/09/2005 17:41:58

http://www.google.fr/search?hl=fr&as_qdr=all&q=Jpgraph+filetype%3Apdf&btnG=Rechercher&meta=lr%3Dlang_fr

signaler à un administrateur
Commentaire de volixium le 25/10/2005 18:06:57

Very Well...j'aime beaucoup ! Parfait pour les stats de mon Fox

signaler à un administrateur
Commentaire de quebectech le 06/12/2005 14:02:01

C'est tu possible davoir le meme script mais cette fois ci pas délémité a 5, ce que je veux dire, tout dépendant de la requete, il peut y avoir 5, 6, 7 ou meme 20 colone créé dynamiquement. sans avoir a délémité dans le $GraphData et $GraphLabel

signaler à un administrateur
Commentaire de wizard512 le 07/12/2005 13:52:43

Comme dit dans l'autre source je vais essayer de te le bricoler et je te préviendrai.

signaler à un administrateur
Commentaire de espada le 22/06/2007 11:39:43

j sais pas pour koi ça marche pas, ça degage une erreur fatale : Fatal error: Call to undefined function: imagefontheight()

signaler à un administrateur
Commentaire de wizard512 le 23/12/2007 22:33:03

normale il faut activer la librairy de gestions des images

signaler à un administrateur
Commentaire de crazygogo le 07/08/2008 14:42:27

http://www.phpcs.com/code.aspx?ID=47171

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

générer des miniatures avec gd 1.6 [ par vegetaline ] muhaha alors là c'est rigolo, un super défi pour les programmeurs fous!ok j'ai le code pour générer des miniatures grâce au php, mais ça marche qu'ave texte sur image... librairie GD ? [ par ozitoun ] Bonjour bonjour,voili voilou, je cherche à mettre une texte sur une image (jpeg).j'ai essayé les imagestring, imagechar... mais à chaque fois les exem Couper le bas d'une image (GD PHP) [ par dezeque ] bonjour,j'aimerai savoir comment faire pour couper le bas d'une image ?elle fais 600X800 et j'aimerai enlver les 50 dernirers pixels du bas pour quell Problème d'affichage avec la libraire GD [ par CMOIPOPO ] Salut &#224; tous,Je souhaite dessiner tout b&#234;tement un rectangle en php (je travaille en local)&nbsp;&#224; l'aide de la libraire GD. Pour cela, [BLOB->GD] Redimensionner un "flux image binaire"... [ par arnal69130 ] Bonjour &#224; tous,Je cherche &#224; faire une page pour afficher la carte d'identit&#233; d'un "agent", pour simplifier disons juste son nom et sa p Librairie GD, Besoin d'aide !!! [ par Astalavista ] &nbsp;&nbsp;&nbsp; Bon, je post ca, car je n'arrive pas a trouver ... :( Je cherche un moyen de fair un Stretch sur une image, C'est a dir de deformer Librairie GD [ par Stephan45120 ] J'orai besoin de superposer 2 images. La première en arrière plan et l'autre en calque par dessus(transparente à certain endroit). Ce que je veux arri Librairie GD et perspective [ par MatiZ ] 'lutJe m'interesse un peu beaucoup à la librairie GD en ce moment et j'aurais voulu créer une perspective d'une image, mais je n'ai rien trouver. Donc Image GD et php ! prob d'affichage [ par riecola ] Bonjour tout le monde. Voil&#224; mon probl&#232;me : mon utilisateur selectionne une image et un texte au choix dans un formulaire ensuite une page s Recolorisation d'une image avec la lib. GD [ par fanfouer ] Bonjour, Je cherche a faire un petit script &#224; l'aide de la librairie GD pour changer les couleurs d'une image que je lui passe &#224; l'aide d'un


Nos sponsors

Sondage...

CalendriCode

Janvier 2009
LMMJVSD
   1234
567891011
12131415161718
19202122232425
262728293031 

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,406 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.