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

2015-01-24信息快讯网

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

我们经常可以看到一些网站上有图片剪切的功能,或许你会觉得这一功能炫目华丽,神秘莫测!但是今天介绍的一款专用于图片裁切的插件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本站下载地址:http://www.jb51.net/jiaoben/24768.html

jQuery Mobile + PHP实现文件上传
PHP使用header()输出图片缓存实例
Codeigniter框架实现获取分页数据和总条数的方法
Yii的CDbCriteria查询条件用法实例
Yii核心组件AssetManager原理分析
ThinkPHP采用原生query实现关联查询left join实例
PHP集成百度Ueditor 1.4.3
php中convert_uuencode()与convert_uuencode函数用法实例
ThinkPHP控制器里javascript代码不能执行的解决方法
PHP PDOStatement对象bindpram()、bindvalue()和bindcolumn之间的区别
PHP图像处理之imagecreate、imagedestroy函数介绍
php中time()与$_SERVER[REQUEST_TIME]用法区别
javascript some()函数用法详解
Laravel 4.2 中队列服务(queue)使用感受
php基于mcrypt的加密解密实例
jquery+php+ajax显示上传进度的多图片上传并生成缩略图代码
PHP实现根据设备类型自动跳转相应页面的方法
PHP 5.3新增魔术方法__invoke概述
php实现与erlang的二进制通讯实例解析
Yii使用CLinkPager分页实例详解
php.ini save_handler 修改不生效的解决办法
async和DOM Script文件加载比较
phpmailer发送邮件之后,返回收件人是否阅读了邮件的方法
完善CodeIgniter在IDE中代码提示功能的方法
linux下使用crontab实现定时PHP计划任务失败的原因分析
函数中使用require_once问题深入探讨 优雅的配置文件定义方法推荐
PHP和javascript常用正则表达式及用法实例
jQuery+PHP+ajax实现微博加载更多内容列表功能
JavaScript创建命名空间的5种写法
PHP中的多行字符串传递给JavaScript的两种方法
浅析ThinkPHP中execute和query方法的区别
smarty模板中使用get、post、request、cookies、session变量的方法
一个基于phpQuery的php通用采集类分享
php警告Creating default object from empty value 问题的解决方法
©2014-2024 dbsqp.com