2012-01-09 3 views
0

У меня есть база данных с заказами и вам нужно создать график PNG, чтобы показать общее количество заказов, размещенных каждый месяц. Я могу заставить это работать из обычного массива, однако я не могу заставить его работать из моего запроса к базе данных.PHP, генерирующий гистограмму PNG

Я думаю, что код, который нуждается в изменении, является третьим и четвертым для циклов, так как это код, который, как я думаю, генерирует имена и столбцы месяца.

Вот код, который работает через массив, с запросом SQL мне нужно использовать объявил под массив $ значений:

<?php 

require_once(DATABASE CONNECTOR REMOVED); 

//Set the values 
$values=array(
    "Jan" => 1100, 
    "Feb" => 1300, 
    "Mar" => 2150, 
    "Apr" => 810, 
    "May" => 3100, 
    "Jun" => 1100, 
    "Jul" => 1900, 
    "Aug" => 1750, 
    "Sep" => 3900, 
    "Oct" => 2860, 
    "Nov" => 1500, 
    "Dec" => 1960 
); 

$query = mysql_query("SELECT SUM(order_total) AS total, MONTHNAME(FROM_UNIXTIME(order_date)) AS month FROM orders GROUP BY YEAR (order_date), MONTH(order_date)") or die ('Error: '.mysql_error()); 

$img_width=600; 
$img_height=400; 
$margins=35; 
$graph_width=$img_width - $margins * 2; 
$graph_height=$img_height - $margins * 2; 

$img=imagecreatetruecolor($img_width,$img_height); 

$bar_width=20; 
$total_bars=count($values); 
$gap= ($graph_width- $total_bars * $bar_width)/($total_bars +1); 

$bar_color=imagecolorallocate($img,70,85,96); 
$background_color=imagecolorallocate($img,255,255,255); 
$border_color=imagecolorallocate($img,200,200,200); 
$line_color=imagecolorallocate($img,70,85,96); 

imagefilledrectangle($img,1,1,$img_width-2,$img_height-2,$border_color); 
imagefilledrectangle($img,$margins,$margins,$img_width-1-$margins,$img_height-1-$margins,$background_color); 

$max_value=max($values); 
$ratio= $graph_height/$max_value; 

$horizontal_lines=20; 
$horizontal_gap=$graph_height/$horizontal_lines; 
for($i=1;$i<=$horizontal_lines;$i++){ 
    $y=$img_height - $margins - $horizontal_gap * $i ; 
    imageline($img,$margins,$y,$img_width-$margins,$y,$line_color); 
    $v='£'.intval($horizontal_gap * $i /$ratio); 
    imagettftext($img, 8, 0, 2 ,$y+5, $bar_color, 'includes/trebuc.ttf', $v); 
} 

for($i=1;$i<=$horizontal_lines;$i++){ 
    $y=$img_height - $margins - $horizontal_gap * $i ; 
    imageline($img,$margins,$y,$img_width-$margins,$y,$line_color); 
    $v='£'.intval($horizontal_gap * $i /$ratio); 
    imagettftext($img, 8, 0, 2 ,$y+5, $bar_color, 'includes/trebuc.ttf', $v); 
} 


    for($i=0;$i< $total_bars; $i++){ 
     list($key,$value)=each($values); 
     $x1= $margins + $gap + $i * ($gap+$bar_width) ; 
     $x2= $x1 + $bar_width; 
     $y1=$margins +$graph_height- intval($value * $ratio) ; 
     $y2=$img_height-$margins; 
     imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color); 
     imagettftext($img, 10, 0, $x1,$img_height - 14, $bar_color, 'includes/trebuc.ttf', $key); 
} 



for($i=0;$i< $total_bars; $i++){ 
    list($key,$value)=each($values); 
    $x1= $margins + $gap + $i * ($gap+$bar_width) ; 
    $x2= $x1 + $bar_width; 
    $y1=$margins +$graph_height- intval($value * $ratio) ; 
    $y2=$img_height-$margins; 
    imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color); 
    imagettftext($img, 10, 0, $x1,$img_height - 14, $bar_color, 'includes/trebuc.ttf', $key); 
} 

header("Content-type:image/png"); 
imagepng($img); 

?> 

EDIT

Я знаю, что это не будет просто ограничьте себя до последних 12 месяцев, я хочу исправить это, как только у меня будет построенный график по значениям из базы данных.

+0

вы не должны смотреть на то, что вы получаете из базы данных вместо того, чтобы разместить этот код? – dmitry

+0

Я использовал while ($ fetch = mysql_fetch_array ($ query)) {echo 'Month vs total:'. $ Fetch ["month"]. ' - '. $ fetch ["total"].'
'; }, чтобы проверить вывод и выводит «Месяц против всего: ноябрь - 1155.50
» и т. д., как и ожидалось. –

+0

Сначала ваш код беспорядочен с вызовами gd, которые, как кажется, не связаны с вашей проблемой: код работает с данным встроенным массивом, но не с данными базы данных. Правильно? Итак, проверьте данные базы данных. Извлеките его в массив, как в коде, и повторите попытку. Вы можете отлаживать свой код, а остальные - здесь. (+ несколько советов: взгляните на библиотеку графа: [jpgraph] (http://jpgraph.net/)) – dmitry

ответ

0

Вы должны получить результаты и заполнить массив $values:

после mysql_query():

$values = array(); 
while ($row = mysql_fetch($query) { 
    $values[substr($row['month'], 0, 3)] = $row['total']; 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^