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


Posted in PHP onJuly 24, 2014

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

PHP 相关文章推荐
PHP下MAIL的另一解决方案
Oct 09 PHP
PHP-MySQL教程归纳总结
Jun 07 PHP
PHP 网页过期时间的控制代码
Jun 29 PHP
php面向对象全攻略 (七) 继承性
Sep 30 PHP
linux系统上支持php的 iconv()函数的方法
Oct 01 PHP
PHP+Ajax检测用户名或邮件注册时是否已经存在实例教程
Aug 23 PHP
ThinkPHP分页实例
Oct 15 PHP
Yii框架中memcache用法实例
Dec 03 PHP
CodeIgniter针对数据库的连接、配置及使用方法
Mar 03 PHP
php微信开发之谷歌测距
Jun 14 PHP
Laravel框架处理用户的请求操作详解
Dec 20 PHP
php操作redis命令及代码实例大全
Nov 19 PHP
PHP 5.3新增魔术方法__invoke概述
Jul 23 #PHP
php实现与erlang的二进制通讯实例解析
Jul 23 #PHP
PHP使用CURL实现对带有验证码的网站进行模拟登录的方法
Jul 23 #PHP
Yii使用CLinkPager分页实例详解
Jul 23 #PHP
ThinkPHP单字母函数(快捷方法)使用总结
Jul 23 #PHP
PHP中的use关键字概述
Jul 23 #PHP
ThinkPHP实现将SESSION存入MYSQL的方法
Jul 22 #PHP
You might like
Fatal error: Call to undefined function curl_init()解决方法
2010/04/09 PHP
数组与类使用PHP的可变变量名需要的注意的问题
2013/06/20 PHP
使用正则去除php代码中的注释方法
2016/11/03 PHP
javascript 避免闭包引发的问题
2009/03/17 Javascript
jQuery 数据缓存data(name, value)详解及实现
2010/01/04 Javascript
用jquery实现自定义风格的滑动条实现代码
2011/04/26 Javascript
阻止事件(取消浏览器对事件的默认行为并阻止其传播)
2013/11/03 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
2013/11/14 Javascript
JQuery $.each遍历JavaScript数组对象实例
2014/09/01 Javascript
JavaScript获取网页、浏览器、屏幕高度和宽度汇总
2014/12/18 Javascript
JS使用ajax从xml文件动态获取数据显示的方法
2015/03/24 Javascript
jQuery插件实现带圆点的焦点图片轮播切换
2016/01/18 Javascript
javascript实现随机显示星星特效
2016/01/28 Javascript
jquery zTree异步加载、模糊搜索简单实例分享
2016/03/24 Javascript
js友好的时间返回函数
2016/08/24 Javascript
Vue-Access-Control 前端用户权限控制解决方案
2017/12/01 Javascript
JS中双击和单击事件冲突的解决方法
2018/04/09 Javascript
vue中使用echarts制作圆环图的实例代码
2018/07/27 Javascript
Vue项目部署在Spring Boot出现页面空白问题的解决方案
2018/11/26 Javascript
Javascript迭代、递推、穷举、递归常用算法实例讲解
2019/02/01 Javascript
js实现简单扫雷
2020/11/27 Javascript
python读写文件操作示例程序
2013/12/02 Python
Python 常用的安装Module方式汇总
2017/05/06 Python
Python操作csv文件实例详解
2017/07/31 Python
解决Pycharm界面的子窗口不见了的问题
2019/01/17 Python
解决Python3 被PHP程序调用执行返回乱码的问题
2019/02/16 Python
python网络爬虫 Scrapy中selenium用法详解
2019/09/28 Python
Python如何使用vars返回对象的属性列表
2020/10/17 Python
用python写一个带有gui界面的密码生成器
2020/11/06 Python
关于canvas.toDataURL 在iOS运行失败的问题解决
2020/09/16 HTML / CSS
斯巴达比赛商店:Spartan Race
2019/01/08 全球购物
个性大学生自我评价
2013/12/04 职场文书
电子专业毕业生自荐信
2014/05/25 职场文书
预备党员群众路线教育实践活动思想汇报2014
2014/10/25 职场文书
css3 实现文字闪烁效果的三种方式示例代码
2021/04/25 HTML / CSS
浅析MySQL如何实现事务隔离
2021/06/26 MySQL