我们经常可以看到一些网站上有图片剪切的功能,或许你会觉得这一功能炫目华丽,神秘莫测!但是今天介绍的一款专用于图片裁切的插件jquery.Jcrop.min.js就将揭开图片剪切的神秘面纱。使用这个插件可以很方便的实现这一功能,使用时仅需鼠标在图片上圈选出选区,即可把图片裁切成所选部分,非常适合用于头像的裁切编辑功能。
本实例演示分为HTML和php两部分:
第一部分,HTML代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
<!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:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<?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 ;
}
?>
|