当前位置:首页 > PHP教程 > php应用 > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-03-24 16:34:34 浏览: 评论:0 

这篇文章主要介绍了PHP结合JQueryJcrop实现图片裁切实例,非常实用的一个功能,需要的朋友可以参考下

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

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

第一部分,HTML代码:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  2. <html xmlns="http://www.w3.org/1999/xhtml"> 
  3. <head> 
  4. <title>Jcrop实现图片裁剪</title> 
  5. <script src="./jquery-1.6.2.min.js"></script> 
  6. <script src="./jquery.Jcrop.min.js"></script> 
  7. <link rel="stylesheet" href="./jquery.Jcrop.min.css" rel="external nofollow" type="text/css" /> 
  8. <style type="text/css"> 
  9. #preview{width:100px;height:100px;border:1px solid #000;overflow:hidden;} 
  10. #imghead{filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);} 
  11. </style> 
  12. <script language="Javascript"> 
  13. jQuery(function(){ 
  14.  jQuery('#imghead').Jcrop({ 
  15.  aspectRatio: 1, 
  16.  onSelect: updateCoords, //选中区域时执行对应的回调函数 
  17.  onChange: updateCoords, //选择区域变化时执行对应的回调函数 
  18.  }); 
  19. }); 
  20. function updateCoords(c) 
  21.  jQuery('#x').val(c.x); //选中区域左上角横 
  22.  jQuery('#y').val(c.y); //选中区域左上角纵坐标 
  23.  //jQuery("#x2").val(c.x2); //选中区域右下角横坐标 
  24.  //jQuery("#y2").val(c.y2); //选中区域右下角纵坐标 
  25.  jQuery('#w').val(c.w); //选中区域的宽度 
  26.  jQuery('#h').val(c.h); //选中区域的高度 
  27. }; 
  28. function checkCoords() 
  29.  if (parseInt(jQuery('#w').val())>0) return true; 
  30.  alert('请选择需要裁切的图片区域.'); 
  31.  return false; 
  32. }; 
  33. </script> 
  34. </head> 
  35. <body> 
  36. <img id="imghead" border=0 src='./image/b4.jpg' /> 
  37. <form action="crop.php" method="post" onsubmit="return checkCoords();"> 
  38.  <input type="text" id="x" name="x" /> 
  39.  <input type="text" id="y" name="y" /> 
  40.  <input type="text" id="w" name="w" /> 
  41.  <input type="text" id="h" name="h" /> 
  42.  <input type="submit" value="提交"> 
  43. </form> 
  44. </body> 
  45. </html> 

第二部分:PHP处理部分crop.php:

  1. <?php 
  2. if ($_SERVER['REQUEST_METHOD'] == 'POST'
  3.  $targ_w = $targ_h = 150; 
  4.  $jpeg_quality = 90; 
  5.  $src = './image/b4.jpg'
  6.  $img_r = imagecreatefromjpeg($src); 
  7.  $dst_r = ImageCreateTrueColor( $targ_w$targ_h ); 
  8.  imagecopyresampled($dst_r,$img_r,0,0,$_POST['x'],$_POST['y'], 
  9.  $targ_w,$targ_h,$_POST['w'],$_POST['h']); 
  10.  header('Content-type: image/jpeg'); 
  11.  imagejpeg($dst_r,null,$jpeg_quality); 
  12.  exit
  13. ?> 

Tags: JQueryJcrop PHP图片裁切

分享到: