JQuery Jcrop实现图片裁剪的代码

2013-05-08 22:19:46来源:西部e网作者:icech

Jcrop是一个非常棒的图片裁剪JQuery插件,用鼠标在图片上自由拖动,就可以完成图片的裁剪。下面就来实现这个Demo的代码:

Jcrop是一个非常棒的图片裁剪JQuery插件,用鼠标在图片上自由拖动,就可以完成图片的裁剪。

Demo地址:http://deepliquid.com/projects/Jcrop/demos.php?demo=live_crop

下面就来实现这个Demo的代码:

注意:图片地址为红色,两处都要修改。

效果图:

\

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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Jcrop实现图片裁剪 - 西部e网(weste.net)</title>
<script src="../styles/jquery-1.7.2.min.js"></script>
<script src="../styles/jquery.Jcrop.min.js"></script>
<link rel="stylesheet" href="../styles/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>

PHP文件代码(crop.php):

<?php
if ($_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;
}
?>

赞助商链接: