-
いくつかの Web サイトに画像の切り取り機能があるのを見て、それは素晴らしいと思いました。その後、専用のツールを見つけました。画像の切り抜きプラグイン、jquery.Jcrop.min.js を使用すると、この機能を簡単に実装できます。これを使用すると、画像上の選択範囲をマウスで囲んで切り取ることができます。選択した部分に画像を切り出す編集機能です。フロントエンド UI の共有
デモは 2 つの部分に分かれています: HTML と PHP:
パート 1、HTML コード:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><title>Jcrop实现图片裁剪</title><script src="../jquery-1.6.2.min.js"></script><script src="../jquery.Jcrop.min.js"></script><link rel="stylesheet" href="../jquery.Jcrop.min.css" type="text/css" /><style type="text/css">#preview{width:100px;height:100px;border:1px solid #000;overflow:hidden;}#imghead{filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);}</style><script language="Javascript">jQuery(function(){ jQuery('#imghead').Jcrop({ aspectRatio: 1, onSelect: updateCoords, //选中区域时执行对应的回调函数 onChange: updateCoords, //选择区域变化时执行对应的回调函数 });});function updateCoords(c){ jQuery('#x').val(c.x); //选中区域左上角横 jQuery('#y').val(c.y); //选中区域左上角纵坐标 //jQuery("#x2").val(c.x2); //选中区域右下角横坐标 //jQuery("#y2").val(c.y2); //选中区域右下角纵坐标 jQuery('#w').val(c.w); //选中区域的宽度 jQuery('#h').val(c.h); //选中区域的高度};function checkCoords(){ if (parseInt(jQuery('#w').val())>0) return true; alert('请选择需要裁切的图片区域.'); return false;};</script></head><body><img id="imghead" border=0 src='../image/b4.jpg' /><form action="crop.php" method="post" onsubmit="return checkCoords();"> <input type="text" id="x" name="x" /> <input type="text" id="y" name="y" /> <input type="text" id="w" name="w" /> <input type="text" id="h" name="h" /> <input type="submit" value="提交"></form></body></html>
?
パート 2: PHP 処理部分: jquery 共有
<?phpif ($_SERVER['REQUEST_METHOD'] == 'POST'){ $targ_w = $targ_h = 150; $jpeg_quality = 90; $src = '../image/b4.jpg'; $img_r = imagecreatefromjpeg($src); $dst_r = ImageCreateTrueColor( $targ_w, $targ_h ); imagecopyresampled($dst_r,$img_r,0,0,$_POST['x'],$_POST['y'], $targ_w,$targ_h,$_POST['w'],$_POST['h']); header('Content-type: image/jpeg'); imagejpeg($dst_r,null,$jpeg_quality); exit;}?>
?
上記 2 つのコード部分をそれぞれ 2 つのファイルとして、任意のファイル名で保存してください。