用PHP实现图象锐化代码

yipeiwu_com6年前PHP代码库
<?  

//读取图像的类型  

  //1 = GIF, 2 = JPG, 3 = PNG, 4 = SWF, 5 = PSD, 6 = BMP, 7 = TIFF(intel byte order), 8 = TIFF(motorola byte order), 9 = JPC, 10 = JP2, 11 = JPX, 12 = JB2, 13 = SWC, 14 = IFF  

  function GetImageType($filename) {return (($imginfo=@getimagesize($filename))!=null ? $imginfo[2] : null);}     

  //图像锐化  

  //$scr_im:图像资源句柄,$degree:锐化度数  

  function Sharp(&$src_im, &$dst_im, $degree)  

  {  

   $src_x = imagesx($src_im);  

   $src_y = imagesy($src_im);  

   //$dst_im = imagecreate($src_x, $src_y);  

   //imagecopy($dst_im, $src_im, 0, 0, 0, 0, $src_x, $src_y);  

   $cnt = 0;  

   for ($x=1; $x<$src_x; $x++)  

   for ($y=1; $y<$src_y; $y++)  

   {  

   $src_clr1 = imagecolorsforindex($src_im, imagecolorat($src_im, $x-1, $y-1));  

   $src_clr2 = imagecolorsforindex($src_im, imagecolorat($src_im, $x, $y));  

   $r = intval($src_clr2["red"]+$degree*($src_clr2["red"]-$src_clr1["red"]));  

   $g = intval($src_clr2["green"]+$degree*($src_clr2["green"]-$src_clr1["green"]));  

   $b = intval($src_clr2["blue"]+$degree*($src_clr2["blue"]-$src_clr1["blue"]));  

   $r = min(255, max($r, 0));  

   $g = min(255, max($g, 0));  

   $b = min(255, max($b, 0));  

   //echo "r:$r, g:$g, b:$b<br/>";  

   if (($dst_clr=imagecolorexact($dst_im, $r, $g, $b))==-1)  

   $dst_clr = Imagecolorallocate($dst_im, $r, $g, $b);  

   $cnt++;  

   if ($dst_clr==-1) die("color allocate faile at $x, $y ($cnt).");  

   imagesetpixel($dst_im, $x, $y, $dst_clr);  

   }  

   return $dst_im;  

  }     

  $ImageFunctions = array("imagecreatefromwbmp", "imagecreatefromgif", "imagecreatefromjpeg", "imagecreatefrompng");   

  if (!empty($_POST["ImageName"]))  

  {   

   set_time_limit(10*60);  

   if (($ImageType=GetImageType($_POST["ImageName"]))==false)  

   die("指定文件不存在或不是有效的图片或不支持类型!");  

   if ($ImageType==6) $ImageType = 0;  

   if ($ImageType>3) die("不支持的图片类型!");  

   $im1 = $ImageFunctions[$ImageType]($_POST["ImageName"]);  

   $im2 = $ImageFunctions[$ImageType]($_POST["ImageName"]);  

   //print_r(imagecolorsforindex($im, imagecolorat($im, 10, 10)));  

   Sharp($im1, $im2, $_POST["Degree"]);  

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

   imagepng($im2);  

   imagedestroy($im1);  

   imagedestroy($im2);  

  }   

  ?>  

  <form name="FormName" action="" method="post">  

  请输入图片的本地路径或URL:<br/>  

  <input name="ImageName" type="text" value="<?=$_POST["ImageName"]?>" size=32><br/>  

  锐化度数(例:0.6、3.0):<br/>  

  <input name="Degree" type="text" value="<?=$_POST["Degree"]?>"><br/>  

  <input type="submit" value="提交">  

  </form>   

   改了一下,省了一个$im:    

   function Sharp2(&$im, $degree)  

  {  

   $cnt = 0;  

   for ($x=imagesx($im)-1; $x>0; $x--)  

   for ($y=imagesy($im)-1; $y>0; $y--)  

   {  

   $clr1 = imagecolorsforindex($im, imagecolorat($im, $x-1, $y-1));  

   $clr2 = imagecolorsforindex($im, imagecolorat($im, $x, $y));  

   $r = intval($clr2["red"]+$degree*($clr2["red"]-$clr1["red"]));  

   $g = intval($clr2["green"]+$degree*($clr2["green"]-$clr1["green"]));  

   $b = intval($clr2["blue"]+$degree*($clr2["blue"]-$clr1["blue"]));  

   $r = min(255, max($r, 0));  

   $g = min(255, max($g, 0));  

   $b = min(255, max($b, 0));  

   //echo "r:$r, g:$g, b:$b<br>";  

   if (($new_clr=imagecolorexact($im, $r, $g, $b))==-1)  

   $new_clr = Imagecolorallocate($im, $r, $g, $b);  

   $cnt++;  

   if ($new_clr==-1) die("color allocate faile at $x, $y ($cnt).");  

   imagesetpixel($im, $x, $y, $new_clr);  

   }  

  }

相关文章

php中隐形字符65279(utf-8的BOM头)问题

今天在CSDN看到一个php输出空白隐形字符65279的问题,在网上找了下,发下这个65279字符是php用来标记文件是utf-8编码的,输出的时候会一起输出到客户端,导致客户端如果使用...

PHP中new static()与new self()的区别异同分析

本文实例讲述了PHP中new static()与new self()的区别异同,相信对于大家学习PHP程序设计能够带来一定的帮助。 问题的起因是本地搭建一个站。发现用PHP 5.2 搭建...

PHP中cookies使用指南

综述    Cookie是在HTTP协议下,服务器或脚本可以维护客户工作站上信息的一种方式。Cookie是由Web服务器保存在用户浏览器上的小文件,它可以包含有关用户的信息(如...

PHP中防止SQL注入方法详解

问题描述:   如果用户输入的数据在未经处理的情况下插入到一条SQL查询语句,那么应用将很可能遭受到SQL注入攻击,正如下面的例子: 复制代码 代码如下: $unsafe_variabl...

php HandlerSocket的使用

Memcache数据一致性的问题:当MySQL数据变化后,如果不能及时有效的清理掉过期的数据,就会造成数据不一致。这在强调即时性的Web2.0时代,不可取。 Memcache崩溃后的...