用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);

   }

  }

(0)

相关推荐

  • 用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=@getimagesiz

  • Angular2 组件通信的实例代码

    1. 组件通信 我们知道Angular2应用程序实际上是有很多父子组价组成的组件树,因此,了解组件之间如何通信,特别是父子组件之间,对编写Angular2应用程序具有十分重要的意义,通常来讲,组件之间的交互方式主要有如下几种: 使用输入型绑定,把数据从父组件传到子组件 通过 setter 拦截输入属性值的变化 使用 ngOnChanges 拦截输入属性值的变化 父组件监听子组件的事件 父组件与子组件通过本地变量互动 父组件调用 ViewChild 父组件和子组件通过服务来通讯 本文会通过讲解着几

  • Angularjs2不同组件间的通信实例代码

    AngualrJs2官方方法是以@Input,@Output来实现组件间的相互传值,而且组件之间必须父子关系,下面给大家提供一个简单的方法,实现组件间的传值,不仅仅是父子组件,跨模块的组件也可以实现传值 /** *1.定义一个服务,作为传递参数的媒介 */ @Injectable() export class PrepService{ //定义一个属性,作为组件之间的传递参数,也可以是一个对象或方法 profileInfo: any; } /** *2.传递参数的组件,我这边简单演示,直接就在构

  • Angular动态添加、删除输入框并计算值实例代码

    Angular动态添加.删除输入框并计算值实例代码 摘要: 在学习群中交流时,有人分享了一个动态添加输入框的方法,我在其基础上进行了一些改进 这个功能本身并不复杂,但还是要注意,每个ng-model的对象必须是不同的,这样才能把它们分隔开. 下面是完整代码: JS: angular.module("myApp",[]) .controller("inputController",function($scope){ $scope.items=[]; //初始化数组,以

  • AngularJS Bootstrap详细介绍及实例代码

    AngularJS Bootstrap AngularJS 的首选样式表是 Twitter Bootstrap, Twitter Bootstrap 是目前最受欢迎的前端框架. 查看 Bootstrap教程. Bootstrap 你可以在你的 AngularJS 应用中加入 Twitter Bootstrap,你可以在你的 <head>元素中添加如下代码: <link rel="stylesheet" href="//maxcdn.bootstrapcdn.

  • 用Python登录好友QQ空间点赞的示例代码

    记得之前跟我女票说过,说要帮她空间点赞,点到999就不点了.刚开始还能天天记得,但是后来事情一多,就难免会忘记,前两天点赞的时候忽然觉得这样好枯燥啊,正好也在学Python,就在想能不能有什么方法能自动点赞. 以前学C借助win32API也干过操作其他应用程序的事,想想可行性还是挺高的,于是就去百度了一下.发现还真有类似的,说干就干,正好也是周末,那就直接熬夜"撸"起来吧.先上代码: def QQZan(qq): browser = webdriver.Chrome() browser

  • React-intl 实现多语言的示例代码

    最近在项目中添加了语言国际化的功能. 语言国际化,也有人说成是语言本地化,其实就是为Web App添加多语言,我们的项目当前包含了中文版和英文版,按理来说『逐字替换』也不是多大事儿,但是,这么Low的做法,有钱途吗? 一开始的时候,我考虑的是传统的为整个项目添加config文件,根据不同的语言和地区,加载不同的config文件,就能够达到界面语言切换的目的.当然,也正是因为这个想法太过于幼稚,所以才被称为『一开始』的想法.语言的国际化不仅仅是将界面上的UI文字翻译成另一种语言,还包括了日期&时间

  • 正则表达式匹配(URL、电话、手机、邮箱)的实例代码

    正则表达式,又称规则表达式.(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表通常被用来检索.替换那些符合某个模式(规则)的文本.下面通过实例代码给大家介绍正则表达式匹配(URL.电话.手机.邮箱)的实例代码,一起看看吧! 废话不多说了,直接给大家贴代码了,具体代码如下所示: <!DOCTYPE html> <html lang="en"> <head> <meta ch

  • 利用正则表达式将字符串分组示例代码

    前言 最近工作中遇到一个问题,需求是碰到'122333<<<<'这种字符串,要将其连贯的部分取出,得出['1', '22', '333', '<<<<']这样的列表,能想到的常规办法,遍历字符串,后一个与前一个逐个比较,这样真的很麻烦!又想到了另外两种方法,话不多说了,来一起看看详细的示例代码: 一.实际上可以借助itertools模块的groupby()方法来处理: import itertools Str = '122333<<<<

  • vue使用mint-ui实现下拉刷新和无限滚动的示例代码

    在开发web-app中,总会遇到v-for出来的li会有很多,当数据达几百上千条的时候,一起加载出来会造成用户体验很差的效果. 这时候我们可以使用无限滚动和下拉刷新来实现控制显示的数量,当刷新到底部的边界的时候会触发无限滚动的事件,再次加载一定数量的条目. 还是拿在项目中的功能来举栗子介绍. 有个列表,几千条数据,做分页查询,限制每次显示查询20条,每次拉到最后20条边缘的时候,触发无限滚动,这时候会出现加载图标,继续加载后续20条数据,加载到最后的时候会提示数据"加载完毕". 项目的

随机推荐