我们经常可以看到一些网站上有图片剪切的功能,或许你会觉得这一功能炫目华丽,神秘莫测!但是今天介绍的一款专用于图片裁切的插件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 ; } ?> |