欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP结合JQueryJcrop实现图片裁切实例详解

程序员文章站 2022-05-14 11:02:03
我们经常可以看到一些网站上有图片剪切的功能,或许你会觉得这一功能炫目华丽,神秘莫测!但是今天介绍的一款专用于图片裁切的插件jquery.jcrop.min.js就将揭开图片...

我们经常可以看到一些网站上有图片剪切的功能,或许你会觉得这一功能炫目华丽,神秘莫测!但是今天介绍的一款专用于图片裁切的插件jquery.jcrop.min.js就将揭开图片剪切的神秘面纱。使用这个插件可以很方便的实现这一功能,使用时仅需鼠标在图片上圈选出选区,即可把图片裁切成所选部分,非常适合用于头像的裁切编辑功能。

本实例演示分为html和php两部分:

第一部分,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" rel="external nofollow" 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;
}
?>

补充:jquery.jcrop.min.js本站下载地址: