1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
<?
include "include/config.inc";
# PARAMETERS:
# itemid
# period
# from
if(!isset($period))
{
$period=0;
}
if(!isset($from))
{
$from=0;
}
$sizeX=900;
$sizeY=200;
$shiftX=10;
$shiftY=13;
$nodata=1;
// Header( "Content-type: text/html");
Header( "Content-type: image/png");
Header( "Expires: Mon, 17 Aug 1998 12:51:50 GMT");
$im = imagecreate($sizeX+$shiftX+61,$sizeY+2*$shiftY+10);
$red=ImageColorAllocate($im,255,0,0);
$green=ImageColorAllocate($im,0,255,0);
$darkgreen=ImageColorAllocate($im,0,150,0);
$blue=ImageColorAllocate($im,0,0,255);
$yellow=ImageColorAllocate($im,255,255,0);
$cyan=ImageColorAllocate($im,0,255,255);
$black=ImageColorAllocate($im,0,0,0);
$gray=ImageColorAllocate($im,150,150,150);
$x=imagesx($im);
$y=imagesy($im);
ImageFilledRectangle($im,0,0,$sizeX+$shiftX+61,$sizeY+2*$shiftY+10,$black);
for($i=0;$i<=$sizeY;$i+=50)
{
ImageDashedLine($im,$shiftX,$i+$shiftY,$sizeX+$shiftX,$i+$shiftY,$darkgreen);
}
for($i=0;$i<=$sizeX;$i+=50)
{
ImageDashedLine($im,$i+$shiftX,$shiftY,$i+$shiftX,$sizeY+$shiftY,$darkgreen);
}
$from_time = time(NULL)-$period-3600*$from;
$to_time = time(NULL)-3600*$from;
$result=DBselect("select count(clock),min(clock),max(clock),min(value),max(value) from history where itemid=$itemid and clock>$from_time and clock<$to_time ");
$count=DBget_field($result,0,0);
if($count>0)
{
$nodata=0;
$minX=DBget_field($result,0,1);
$maxX=DBget_field($result,0,2);
$minY=DBget_field($result,0,3);
$maxY=DBget_field($result,0,4);
}
else
{
$maxX=-1000000000;
$maxY=-1000000000;
$minX=1000000000;
$minY=1000000000;
}
// echo "MIN/MAX:",$minX," - ",$maxX," - ",$minY," - ",$maxY,"<Br>";
if(($minX!=$maxX)&&($minY!=$maxY))
{
$result=DBselect("select clock,value from history where itemid=$itemid and clock>$from_time and clock<$to_time order by clock");
for($i=0;$i<DBnum_rows($result)-1;$i++)
{
$x=DBget_field($result,$i,0);
$x_next=DBget_field($result,$i+1,0);
$y=DBget_field($result,$i,1);
$y_next=DBget_field($result,$i+1,1);
$x1=$sizeX*($x-$minX)/($maxX-$minX);
$y1=$sizeY*($y-$minY)/($maxY-$minY);
$x2=$sizeX*($x_next-$minX)/($maxX-$minX);
$y2=$sizeY*($y_next-$minY)/($maxY-$minY);
$y1=$sizeY-$y1;
$y2=$sizeY-$y2;
// echo $x1," - ",$x2," - ",$y1," - ",$y2,"<Br>";
ImageLine($im,$x1+$shiftX,$y1+$shiftY,$x2+$shiftX,$y2+$shiftY,$green);
}
}
else
{
ImageLine($im,$shiftX,$shiftY+$sizeY/2,$sizeX+$shiftX,$shiftY+$sizeY/2,$green);
}
if($nodata == 0)
{
for($i=0;$i<=$sizeY;$i+=50)
{
ImageString($im, 1, $sizeX+5+$shiftX, $sizeY-$i-4+$shiftY, $i*($maxY-$minY)/$sizeY+$minY , $red);
}
// date("dS of F Y h:i:s A",DBget_field($result,0,0));
ImageString($im, 1,10, $sizeY+$shiftY+5, date("dS of F Y h:i:s A",$minX) , $red);
ImageString($im, 1,$sizeX+$shiftX-168,$sizeY+$shiftY+5, date("dS of F Y h:i:s A",$maxX) , $red);
}
else
{
ImageString($im, 2,$sizeX/2 -50, $sizeY+$shiftY+3, "NO DATA FOUND FOR THIS PERIOD" , $red);
}
ImageStringUp($im,0,2*$shiftX+$sizeX+40,$sizeY+2*$shiftY, "http://zabbix.sourceforge.net", $gray);
ImagePng($im);
ImageDestroy($im);
?>
|