PHP генерирует PNG гистограмму - PullRequest
0 голосов
/ 09 января 2012

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

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

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

<?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 месяцами, я хочу исправить это, как только у меня будет график, построенный по значениям из базы данных

1 Ответ

0 голосов
/ 31 июля 2012

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

после mysql_query():

$values = array();
while ($row = mysql_fetch($query) {
  $values[substr($row['month'], 0, 3)] = $row['total'];
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...