//読み込む画像の種類
//1 = GIF、2 = JPG、3 = PNG、4 = SWF、5 = PSD、6 = BMP、7 = TIFF (インテル バイト オーダー)、8 = TIFF(モトローラ バイト オーダー)、9 = JPC、10 = JP2、11 = JPX、12 = JB2、13 = SWC、14 = IFF
関数 GetImageType($filename ) {return (($imginfo=@getimagesize($filename))!=null ? $imginfo[2] : null);}
//画像の鮮明化
//$scr_im : 画像リソースハンドル、$degree: シャープ化度
関数 Sharp(&$src_im, &$dst_im, $degree)
{
$src_x = imagex($ src_im);
$src_y = imagey($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[ "赤"] $degree*($src_clr2["赤"]-$src_clr1["赤"]));
$g = intval($src_clr2["緑"] $degree* ($src_clr2 ["緑"]-$src_clr1["緑"]));
$b = intval($src_clr2["青"] $degree*($src_clr2["青"]-$ src_clr1["青"]));
$r = min(255, max($r, 0));
$g = min(255, max($g, 0) )) ;
$b = min(255, max($b, 0));
//エコー "r:$r, g:$g, b:$b
";
if (($dst_clr=imagecolorexact($dst_im, $r, $g, $b))==-1)
$dst_clr = Imagecolorallocate($ dst_im, $r, $g, $b); cnt).");
imagesetpixel($dst_im, $x, $y, $dst_clr);
}
return $dst_im;
}
$ImageFunctions = array("imagecreatefromwbmp", "imagecreatefromgif", "imagecreatefromjpeg", "imagecreatefrompng"); > 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)));
シャープ($im1, $im2, $_POST[" ]);
header("Content-type: image/png");
imagepng($im2);
imagedestroy($im2);
}
>
入力画像の本地路径または URL:
" size=32>
锐化度数(例:0.6、3.0):
<入力名="Degree" type="text" value="=$_POST["Degree"]?>">
修正一下、省了一$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
";
if (($new_clr=imagecolorexact($im, $r, $g, $b))==-1)
$new_clr = Imagecolorallocate($im, $r, $ g、$b);
$cnt ;
if ($new_clr==-1) die("$x, $y ($cnt) でカラー割り当てに失敗しました。");
imagesetpixel($im, $x, $y, $new_clr);
}
}