显示来自Mysql表的php图表

时间:2013-01-17 07:43:25

标签: php mysql image dynamic-data

如何使用PHP图像函数动态显示存储在MySQL表中的数据的统计信息?我可以使用静态表上的计数查询以条形图的形式显示计数,但如图所示。我有动态存储服务器日志的数据库。

图像由3张桌子和图像&绘制php的功能

3 个答案:

答案 0 :(得分:1)

我不知道你是怎么想的。但是有一个很好的Jquery插件名为Highcharts。您可以使用它来创建各种类型的图形。如果您有兴趣,请参阅以下链接

http://www.highcharts.com/

答案 1 :(得分:0)

Rgraph也是一个非常好的HTML5 / Javascript Graph库,易于使用且有很多选项。

http://www.rgraph.net/

var data = ['<?php echo implode("','", $average); ?>']; 

function drawGraph(){
    RGraph.Clear(document.getElementById('myRadar'));
    var radar = new RGraph.Radar('myRadar', data);

这是你可以添加PHP数组的方法,$ average是带数字的数组,在这个例子中是雷达图。 implode函数在数组的值之间加上逗号。

答案 2 :(得分:0)

我用下面的代码用php创建一个简单的条形图。 您必须从数据库中获取条形值并将其放在$ data数组中。 接下来必须为图像大小设置$ height和$ width。 根据您的图片大小,您必须定位聊天。

<?php

$data = array('400', '2570', '245', '473', '1000', '3456', '780', '5000', '30', '420');
$sum = array_sum($data);

$height = 480;
$width  = 640;

$im         = imagecreate($width, $height);
$background = imagecolorallocate($im, 255, 255, 255);

$white  = imagecolorallocate($im, 255, 255, 255);
$black  = imagecolorallocate($im, 0, 0, 0);
$red    = imagecolorallocate($im, 255, 0, 0);
$green  = imagecolorallocate($im, 51, 153, 0);
$yellow = imagecolorallocate($im, 255, 255, 0);

imageline($im, 10, 5, 10, $height - 20, $black);
imageline($im, 10, $height - 20, 620, $height - 20, $black);

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

$x       = 11;
$y       = 459;
$x_width = 20;
$y_ht    = 0;

$max_i = count($data);
for ($i     = 0; $i < $max_i; $i++) {
    $y_ht = ($data[$i] / $sum) * $height;
    if ($data[$i] > 1000) {
        imagefilledrectangle($im, $x, $y, $x + $x_width, ($y - $y_ht), $green);
    } else if ($data[$i] > 500) {
        imagefilledrectangle($im, $x, $y, $x + $x_width, ($y - $y_ht), $yellow);
    } else {
        imagefilledrectangle($im, $x, $y, $x + $x_width, ($y - $y_ht), $red);
    }
    imagestring($im, 2, $x - 1, ($y - $y_ht - 15), $data[$i], $black);
    $x += ($x_width + 2);
}
imagepng($im);
imagedestroy($im);
?>

参考:http://www.talkphp.com/advanced-php-programming/1629-bar-chart-php.html