source: branches/1.5/admin/images/monthly_stats.img.php @ 27569

Last change on this file since 27569 was 918, checked in by volcom, 19 years ago

2005-10-30 volcom

  • bug 190 fixed: issue in stats.tpl display
  • bug fixed: labels of monthly, daily graph fixed
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.3 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | PhpWebGallery - a PHP based picture gallery                           |
4// | Copyright (C) 2002-2003 Pierrick LE GALL - pierrick@phpwebgallery.net |
5// | Copyright (C) 2003-2005 PhpWebGallery Team - http://phpwebgallery.net |
6// +-----------------------------------------------------------------------+
7// | branch        : BSF (Best So Far)
8// | file          : $RCSfile$
9// | last update   : $Date: 2005-10-30 20:35:39 +0000 (Sun, 30 Oct 2005) $
10// | last modifier : $Author: volcom $
11// | revision      : $Revision: 918 $
12// +-----------------------------------------------------------------------+
13// | This program is free software; you can redistribute it and/or modify  |
14// | it under the terms of the GNU General Public License as published by  |
15// | the Free Software Foundation                                          |
16// |                                                                       |
17// | This program is distributed in the hope that it will be useful, but   |
18// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
19// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
20// | General Public License for more details.                              |
21// |                                                                       |
22// | You should have received a copy of the GNU General Public License     |
23// | along with this program; if not, write to the Free Software           |
24// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
25// | USA.                                                                  |
26// +-----------------------------------------------------------------------+
27//----------------------------------------------------------- include
28define('PHPWG_ROOT_PATH','../../');
29define('IN_ADMIN', true);
30include_once( PHPWG_ROOT_PATH.'include/common.inc.php' );
31include_once( PHPWG_ROOT_PATH.'admin/include/isadmin.inc.php' );
32include_once( 'phpBarGraph.php' );
33
34//------------------------------------------------ variable definition
35$outputFormat = "png";
36$legend = $lang['stats_monthly_graph_title'];
37$imageHeight = 256;
38$imageWidth = 512;
39$sql = '
40SELECT DISTINCT COUNT(*)
41     , DAYOFMONTH(date)
42  FROM '.HISTORY_TABLE.'
43  WHERE YEAR(date) = '.$_GET['year'].'
44    AND MONTH(date) = '.$_GET['month'].'
45  GROUP BY DATE_FORMAT(date, \'%Y-%m-%d\') DESC
46;';
47
48//------------------------------------------------ Image definition
49$image = ImageCreate($imageWidth, $imageHeight);
50//$image = ImageCreateTrueColor($imageWidth, $imageHeight);
51// Fill it with your favorite background color..
52$backgroundColor = ImageColorAllocate($image, 184, 184, 184);
53ImageFill($image, 0, 0, $backgroundColor);
54$white = ImageColorAllocate($image, 0, 0, 0);
55
56// Interlace the image..
57Imageinterlace($image, 1);
58
59// Create a new BarGraph..
60$myBarGraph = new PhpBarGraph;
61$myBarGraph->SetX(10);              // Set the starting x position
62$myBarGraph->SetY(10);              // Set the starting y position
63$myBarGraph->SetWidth($imageWidth-20);    // Set how wide the bargraph will be
64$myBarGraph->SetHeight($imageHeight-20);  // Set how tall the bargraph will be
65$myBarGraph->SetNumOfValueTicks(3); // Set this to zero if you don't want to show any. These are the vertical bars to help see the values.
66
67
68// You can try uncommenting these lines below for different looks.
69
70// $myBarGraph->SetShowLabels(false);  // The default is true. Setting this to false will cause phpBarGraph to not print the labels of each bar.
71$myBarGraph->SetShowValues(false);  // The default is true. Setting this to false will cause phpBarGraph to not print the values of each bar.
72// $myBarGraph->SetBarBorder(false);   // The default is true. Setting this to false will cause phpBarGraph to not print the border of each bar.
73// $myBarGraph->SetShowFade(false);    // The default is true. Setting this to false will cause phpBarGraph to not print each bar as a gradient.
74// $myBarGraph->SetShowOuterBox(false);   // The default is true. Setting this to false will cause phpBarGraph to not print the outside box.
75$myBarGraph->SetBarSpacing(5);     // The default is 10. This changes the space inbetween each bar.
76
77
78// Add Values to the bargraph..
79$result = pwg_query($sql)
80or die(mysql_errno().": ".mysql_error()."<BR>".$sql);
81
82$days = array();
83for ($i = 1; $i <= 31; $i++)
84{
85  $days[$i] = 0;
86}
87
88while ($r = mysql_fetch_row($result))
89{ 
90  $days[$r[1]]= $r[0];
91}
92$o=0;
93while (list ($key,$value) = each($days ))
94{
95  $myBarGraph->AddValue($key, $value);
96}
97
98//$myBarGraph->SetDebug(true);
99// Set the colors of the bargraph..
100$myBarGraph->SetStartBarColor("6666ff");  // This is the color on the top of every bar.
101$myBarGraph->SetEndBarColor("2222aa");    // This is the color on the bottom of every bar. This is not used when SetShowFade() is set to false.
102$myBarGraph->SetLineColor("000000");      // This is the color all the lines and text are printed out with.
103
104// Print the BarGraph to the image..
105$myBarGraph->DrawBarGraph($image);
106Imagestring($image, 2, 2, $imageHeight-14, $legend, $white);
107   
108//------------------------------------------------ Image output
109if ($outputFormat == "png")
110{
111  header("Content-type: image/png");
112  ImagePNG($image);
113}
114else if ($outputFormat == "jpg")
115{
116  header("Content-type: image/jpeg");
117  Imagejpeg($image);
118}
119// Destroy the image.
120Imagedestroy($image);
121?> 
Note: See TracBrowser for help on using the repository browser.