首页 > 网站 > 建站经验 > 正文

PHP结合JQuery Jcrop实现头像图片裁切实例代码

2024-04-25 20:36:50
字体:
来源:转载
供稿:网友

看到一些网站上有图片剪切的功能,觉得挺炫,后来找了一款专用于图片裁切的插件,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" 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处理部分:

<?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;

}

?>

请将上述两部分代码分别另存为两个文件,文件名自拟。

 

 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表