php生成bmp图像,BMP 文件或 URL 新建图像 imagecreatefrombmp

[php]代码库function imagecreatefrombmp($file)

{

global $CurrentBit, $echoMode;

$f=fopen($file,"r");

$Header=fread($f,2);

if($Header=="BM")

{

$Size=freaddword($f);

$Reserved1=freadword($f);

$Reserved2=freadword($f);

$FirstByteOfImage=freaddword($f);

$SizeBITMAPINFOHEADER=freaddword($f);

$Width=freaddword($f);

$Height=freaddword($f);

$biPlanes=freadword($f);

$biBitCount=freadword($f);

$RLECompression=freaddword($f);

$WidthxHeight=freaddword($f);

$biXPelsPerMeter=freaddword($f);

$biYPelsPerMeter=freaddword($f);

$NumberOfPalettesUsed=freaddword($f);

$NumberOfImportantColors=freaddword($f);

if($biBitCount<24)

{

$img=imagecreate($Width,$Height);

$Colors=pow(2,$biBitCount);

for($p=0;$p

{

$B=freadbyte($f);

$G=freadbyte($f);

$R=freadbyte($f);

$Reserved=freadbyte($f);

$Palette[]=imagecolorallocate($img,$R,$G,$B);

}

if($RLECompression==0)

{

$Zbytek=(4-ceil(($Width/(8/$biBitCount)))%4)%4;

for($y=$Height-1;$y>=0;$y--)

{

$CurrentBit=0;

for($x=0;$x

{

$C=freadbits($f,$biBitCount);

imagesetpixel($img,$x,$y,$Palette[$C]);

}

if($CurrentBit!=0) {freadbyte($f);}

for($g=0;$g

freadbyte($f);

}

}

}

if($RLECompression==1) //$BI_RLE8

{

$y=$Height;

$pocetb=0;

while(true)

{

$y--;

$prefix=freadbyte($f);

$suffix=freadbyte($f);

$pocetb+=2;

$echoit=false;

if($echoit)echo "Prefix: $prefix Suffix: $suffix
";

if(($prefix==0)and($suffix==1)) break;

if(feof($f)) break;

while(!(($prefix==0)and($suffix==0)))

{

if($prefix==0)

{

$pocet=$suffix;

$Data.=fread($f,$pocet);

$pocetb+=$pocet;

if($pocetb%2==1) {freadbyte($f); $pocetb++;}

}

if($prefix>0)

{

$pocet=$prefix;

for($r=0;$r

$Data.=chr($suffix);

}

$prefix=freadbyte($f);

$suffix=freadbyte($f);

$pocetb+=2;

if($echoit) echo "Prefix: $prefix Suffix: $suffix
";

}

for($x=0;$x

{

imagesetpixel($img,$x,$y,$Palette[ord($Data[$x])]);

}

$Data="";

}

}

if($RLECompression==2) //$BI_RLE4

{

$y=$Height;

$pocetb=0;

/*while(!feof($f))

echo freadbyte($f)."_".freadbyte($f)."
";*/

while(true)

{

//break;

$y--;

$prefix=freadbyte($f);

$suffix=freadbyte($f);

$pocetb+=2;

$echoit=false;

if($echoit)echo "Prefix: $prefix Suffix: $suffix
";

if(($prefix==0)and($suffix==1)) break;

if(feof($f)) break;

while(!(($prefix==0)and($suffix==0)))

{

if($prefix==0)

{

$pocet=$suffix;

$CurrentBit=0;

for($h=0;$h

$Data.=chr(freadbits($f,4));

if($CurrentBit!=0) freadbits($f,4);

$pocetb+=ceil(($pocet/2));

if($pocetb%2==1) {freadbyte($f); $pocetb++;}

}

if($prefix>0)

{

$pocet=$prefix;

$i=0;

for($r=0;$r

{

if($i%2==0)

{

$Data.=chr($suffix%16);

}

else

{

$Data.=chr(floor($suffix/16));

}

$i++;

}

}

$prefix=freadbyte($f);

$suffix=freadbyte($f);

$pocetb+=2;

if($echoit) echo "Prefix: $prefix Suffix: $suffix
";

}

for($x=0;$x

{

imagesetpixel($img,$x,$y,$Palette[ord($Data[$x])]);

}

$Data="";

}

}

if($biBitCount==24)

{

$img=imagecreatetruecolor($Width,$Height);

$Zbytek=$Width%4;

for($y=$Height-1;$y>=0;$y--)

{

for($x=0;$x

{

$B=freadbyte($f);

$G=freadbyte($f);

$R=freadbyte($f);

$color=imagecolorexact($img,$R,$G,$B);

if($color==-1) $color=imagecolorallocate($img,$R,$G,$B);

imagesetpixel($img,$x,$y,$color);

}

for($z=0;$z

freadbyte($f);

}

}

return $img;

}

fclose($f);

}

function freadbyte($f)

{

return ord(fread($f,1));

}

function freadword($f)

{

$b1=freadbyte($f);

$b2=freadbyte($f);

return $b2*256+$b1;

}

function freaddword($f)

{

$b1=freadword($f);

$b2=freadword($f);

return $b2*65536+$b1;

}

694748ed64b9390909c0d88230893790.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值