JpGraph 画图

1:官网

        http://jpgraph.net/

2:配置

首先要保证PHP打开了Gd2的扩展:

  打开PHP.ini,定位到extension=php_gd2.dll,把前面的分号删掉。

  然后下载Jpgraph,http://www.aditus.nu/jpgraph/,解压到一个文件夹中。如 E:\Software\web\www\jpgraph。

  打开PHP.ini,修改include_path参数,增加Jpgraph的路径,如include_path=",;E:\Software\web\www\jpgraph",重启Apache服务。

  这样环境就配好了。

 3:列子

     1):柱型图(未解决中文问题)

    

<?php 
require_once ('Examples/jpgraph/jpgraph.php'); //载入基本类
require_once ('Examples/jpgraph/jpgraph_bar.php');//载入柱形图类
$datay=array(300,230,400);//你要显示的数据
$graph = new Graph(400,250);//创建一个图,参数为宽度和高度
$graph->SetScale("textlin");
$graph->img->SetMargin(25,15,25,15);//设置图标边距
$graph->title->SetFont(FF_SIMSUN,FS_BOLD,24); //设置字体,类型,大小
$graph->title->Set('www.phpddt.com');//图片头部标题
$graph->title->SetColor('red');//标题字体颜色
$graph->xaxis->SetFont(FF_FONT1);//设置英文字体
$graph->yaxis->SetFont(FF_FONT1); 
$bplot = new BarPlot($datay);
$bplot->SetWidth(0.4);//柱状的宽度
$bplot->SetFillGradient("navy","lightsteelblue",GRAD_MIDVER);
$bplot->SetColor("navy");
$graph->Add($bplot);
$graph->Stroke();
?>

    2)折线图

<?php 

include ("jpgraph.php"); 
include ("jpgraph_bar.php"); 
include ("jpgraph_line.php");
// y 轴数据,以数组形式赋值
 $ydata = array(12,4,9,15,11,10,9,7,15,7);
 
 // 创建 Graph 类,350 为宽度,250 长度,auto:表示生成的缓存文件名是该文件的文件名+扩展名(.jpg .png .gif ……)
$graph = new Graph(350,250,"auto");

// 设置刻度类型,x轴刻度可作为文本标注的直线刻度,y轴为直线刻度
 $graph->SetScale("textlin");

// 创建坐标类,将y轴数据注入
$lineplot=new LinePlot($ydata);
 
 // y 轴连线设定为蓝色
 $lineplot->SetColor("blue");
 
 // 坐标类注入图标类
 $graph->Add($lineplot);
 
// 显示图
$graph->Stroke();                                    
?>

 3):流量图

include ('jpgraph/jpgraph.php');

include ("jpgraph/jpgraph_line.php");

include ("jpgraph/jpgraph_date.php");

$graph = new Graph(900, 150, "auto");
//$graph->title->Set("$title");
$graph->SetScale('datlin'); // 以时间来自适应X刻度
$graph->xgrid->Show(); // 显示网格
$graph->SetMarginColor('[email protected]');
$graph->SetMargin(45, 10, 5, 25);
$graph->xaxis->SetTickSide(SIDE_BOTTOM);
$graph->yaxis->SetTickSide(SIDE_LEFT);
$graph->yaxis->title->Set("$danwei");
$p_transmit = new LinePlot($data_arr);
$p_transmit->SetColor("#006600");
$p_transmit->SetFillColor('#006600');
$graph->xaxis->SetTickLabels($xdata);
$graph->Add($p_transmit);
$graph->xaxis->SetLabelAngle(90);
$graph->Stroke();

 4:处理中文乱码

    1):设置中文字体(在linux中)

    

在jpgraph.php中有以下这样一段代码是设置字体文件路径的
if (!defined('TTF_DIR')) {
if (strstr( PHP_OS, 'WIN') ) {
$sroot = getenv('SystemRoot');
if( empty($sroot) ) {
$t = new ErrMsgText();
$msg = $t->Get(12,$file,$lineno);
die($msg);
}
else {
define('TTF_DIR', $sroot.'/fonts/');
}
} else {
define('TTF_DIR','/usr/share/fonts/truetype/');ç (我的作法是将windows下的fonts文件夹下的字体全部COPY到/usr/local/fonts/truetype)
}
}

     2):php中显示中文

        方法一:

$title="流量图";
$title = iconv("UTF-8", "gb2312", $title);
$graph->title->Set($title);
$graph->title->SetFont(FF_SIMSUN,FS_BOLD,14);

        方法二:(未验证)

修改源文件jpgraph_ttf.inc.php
在第99-106行,改成下面这样子
elseif( $aFF === FF_SIMSUN ) {
// Do Chinese conversion
/*
if( $this->g2312 == null ) {
include_once 'jpgraph_gb2312.php' ;
$this->g2312 = new GB2312toUTF8();
}
return $this->g2312->gb2utf8($aTxt);
*/
return $aTxt;
}

 补充:

    jpgraph默认显示汉字时是把汉字编码认为gb2312,转化为utf-8以后再显示。
    这样的话,如果你的文件编码是gb2312,SetFont方法的第一个参数为FF_SIMSUN即可。
    如果你是utf-8编码你还需要先把汉字编码转化为gb2312,这样你的汉字才可以正常显示。

     3):代码

<?php
include_once("jpgraph.php");
include_once("jpgraph_line.php");

// y 轴数据,以数组形式赋值  
$ydata = array(11,3,8,12,5,1,9,13,5,7);
  
// 创建 Graph 类,350 为宽度,250 长度,auto:表示生成的缓存文件名是该文件的文件名+扩展名(.jpg .png .gif ……)  
$graph = new Graph(350,250,"auto");  
$title="流量图";
$title = iconv("UTF-8", "gb2312", $title);
$graph->title->Set($title);
$graph->title->SetFont(FF_SIMSUN,FS_BOLD,14);
  
// 设置刻度类型,x轴刻度可作为文本标注的直线刻度,y轴为直线刻度  
$graph->SetScale("textlin");  
  
// 创建坐标类,将y轴数据注入  
$lineplot=new LinePlot($ydata);  
  
// y 轴连线设定为蓝色  
$lineplot->SetColor("blue");  
  
// 坐标类注入图标类  
$graph->Add($lineplot);  
  
// 显示图  
$graph->Stroke();              
?>

 5:颜色处理

1:通过颜色名称来指定颜色
SetColor(’white’)
SetFillColor(’orange’)
2:通过RGB值来指定颜色
SetColor( array(0xff,0xff,0xff))
SetFillColor( array(0×44,0×54,0xa4))
3:使用HTML颜色指定
SetColor(’#12be7a’)
SetFillColor(’#99eff5′)
4:颜色的微调处理
SetFillColor(’[email protected]′), 稍透明的红色
SetFillColor(’[email protected]′), 几乎全透明的颜色
5:使用jpgraph调整亮度
SetColor(’red:1.5′), 明亮的hongse
SetColor(’#3485a9:1.8), 明亮的蓝绿色
6:SetColor(’[email protected]:1.2′)
SetFillColor(’#[email protected]:1.5′)
@后的第一个数值代表透明度,第二个数值代表亮度


 

你可能感兴趣的:(Graph)