12樓 巨大八爪鱼
2014-9-30 23:34
以下为根据bin文件生成波形图的php程序代码: 【portcheck.php】 <?php /* 根据EEPROM内容生成I/O口波形图像 * 作者:巨大八爪鱼 * 时间:2013年9月30日15:08:06 **/ define("US_PER_PX",50); //每像素表示多少微秒 define("FILENAME","错误的红外发射.bin"); header("Content-type:image/png");
function BIT($n) { return 1<<$n; }
$file=fopen(FILENAME,"rb"); # 打开文件 $time=fread($file,480); # 持续时间 $port_states=fread($file,30); # 高低电平标识 fread($file,1); # 该位始终是0x3d,跳过 $length=ord(fread($file,1)); # 长度
# 计算图片宽度 $width=0; for ($i=0;$i<$length;$i++) { $t=ord($time[$i*2])*256+ord($time[$i*2+1]); $width+=$t; } $width=ceil($width/US_PER_PX);
$im=imagecreatetruecolor($width,64); $back_color=imagecolorallocate($im,251,252,205); imagefill($im,10,5,$back_color); # 背景颜色
$color=imagecolorallocate($im,0,64,0); $x=$y=0; for ($i=0;$i<$length;$i++) { $lasty=$y; $y=10; if (ord($port_states[(int)floor($i/8)])&BIT($i%8)) $y=50; # 如果该位是高电平 # 电平发生跳变时加竖线 if ($y!=$lasty && $i>0) imageline($im,$x,11,$x,49,$color); # 从第二个电平开始更换颜色 if ($i==1) $color=imagecolorallocate($im,0,0,128); $t=ord($time[$i*2])*256+ord($time[$i*2+1]); $t/=US_PER_PX; imageline($im,$x,$y,$x+$t,$y,$color); # 绘制水平线 $x+=$t; }
fclose($file);
imagepng($im); imagedestroy($im); ?>
|