php+croppic.js实现剪切上传图片功能
技术  /  管理员 发布于 8年前   307
最近需要实现裁剪图片上传,想起之前公司用到的一个插件,却不知道叫什么名字了。 在网上找了有些时间,最终找到了这个网站。 http://www.croppic.net/ 因为官网文档全部都是英文,所以看起来有些吃力,可以大概看懂80%,但是缺少详细的案例说明,所以真正配置起来还是非常懵逼。 如果完全按照官网文档的步骤,大概就是这样的 下载安装 官网提供两种下载方式,第一种类似于SDK的whole website,另外一种 简洁版croppic。前者提供了完整的项目结构以及前后端案例,后者只有croppic.css、croppic.js、croppic.min.js三个文件。 基本使用 Options 参数 uploadUrl php处理时,和普通的上传文件一模一样,使用$_FILES['img']可以直接获取文件信息,上传并保存;使用$_REQUEST[]则直接可以获取js中uploadData中的数据。 php在处理完成后,根据成功状态返回如下json结构 成功时 注意:源图片宽高获取方式 list($width, $height) = getimagesize($_FILES["img"]["tmp_name"]); 失败时 cropUrl 接下来是裁切图片的请求,基本使用 请求php的参数基本如下: php 端使用 nezamy/route 的request类获取croppic.js裁切后发送过来的参数 其他参数就不用介绍了,文档上面可以看,如果看不懂或者不太清晰的可以直接下载案例做参照,比文档要详细些。接下来的重头戏在php端的处理。 PHP 各种操作图片GD库 JS各种配置 总结 以上所述是小编给大家介绍的php+croppic.js实现剪切上传图片功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!// css 部分#yourId { width: 200px; height: 150px; position:relative; /* or fixed or absolute */}// html 部分
uploadUrl:'制定上传的地址',uploadData:{ "dummyData":1, "dummyData2":"text"}
{ "status":"success", "url":"返回成功后的图片url地址", "width":源图片宽度, "height":源图片高度}
{ "status":"error", "message":"这里是你的失败提示信息"}
var cropperOptions = { uploadUrl:'裁切后请求的地址', uploadData:{ "dummyData":1, "dummyData2":"text" }}var cropperHeader = new Croppic('yourId', cropperOptions);
$request = app('request');// 上传服务器的图片路径$imgUrl = $request->body['imgUrl'];// 原始图片宽高$imgInitW = $request->body['imgInitW'];$imgInitH = $request->body['imgInitH'];// 新缩放的图片宽高$imgW = $request->body['imgW'];$imgH = $request->body['imgH'];// 与缩放图像相关的裁剪图像的左上角$imgY1 = $request->body['imgY1'];$imgX1 = $request->body['imgX1'];// 裁剪图像宽高$cropW = $request->body['cropW'];$cropH = $request->body['cropH'];// 角度$angle = $request->body['rotation'];
$temp_name = "crop_temp_" . uniqid();$temp_path = sys_get_temp_dir() . "/";$output_filename = $temp_path . $temp_name;$what = getimagesize($imgUrl);// 创建画布并载入图像switch (strtolower($what['mime'])) { case 'image/png': $source_image = imagecreatefrompng($imgUrl); $type = '.png'; break; case 'image/jpeg': $source_image = imagecreatefromjpeg($imgUrl); $type = '.jpeg'; break; case 'image/gif': $source_image = imagecreatefromgif($imgUrl); $type = '.gif'; break; default: throw new \Exception('不支持的图片类型');}if (!is_writable(dirname($output_filename))) { throw new \Exception('文件无法写入');}// 创建一幅真彩色的图像,从而支持更为丰富的色彩,gif文件不可使用$resizedImage = imagecreatetruecolor($imgW, $imgH);if ($type == '.png') { // 将黑色定义为透明色 imagecolortransparent($resizedImage, imagecolorallocate($resizedImage, 0, 0, 0));}imagecopyresampled($resizedImage, $source_image, 0, 0, 0, 0, $imgW, $imgH, $imgInitW, $imgInitH);// 旋转图像$rotated_image = $angle ? imagerotate($resizedImage, -$angle, 0) : $resizedImage;// 获取图像宽高$rotated_width = imagesx($rotated_image);$rotated_height = imagesy($rotated_image);// 旋转后 - 缩放后$dx = $rotated_width - $imgW;$dy = $rotated_height - $imgH;// 裁剪旋转后的图片到图像$cropped_rotated_image = imagecreatetruecolor($imgW, $imgH);if ($type == '.png') { // 设置黑色为透明 imagecolortransparent($cropped_rotated_image, imagecolorallocate($cropped_rotated_image, 0, 0, 0));}imagecopyresampled($cropped_rotated_image, $rotated_image, 0, 0, $dx / 2, $dy / 2, $imgW, $imgH, $imgW, $imgH);// 剪切图像到规定区域$final_image = imagecreatetruecolor($cropW, $cropH);if ($type == '.png') { imagecolortransparent($final_image, imagecolorallocate($final_image, 0, 0, 0));}imagecopyresampled($final_image, $cropped_rotated_image, 0, 0, $imgX1, $imgY1, $cropW, $cropH, $cropW, $cropH);// 最后输出图像到文件,就可以直接使用file_get_content('output_filename'.$type)获取图片了imagepng($final_image, $output_filename . $type);/** * 这里需要进行上传服务器操作 */echo json_encode([ 'status' => 'success', 'url' => $output_filename . $type,]);// 最后删除缓存图片//unlink($output_filename . $type);
var crop_image_src = 'image_src'; var croppedOptions = { cropUrl: 'http://deng.com/m/tool/crop_pic/crop', modal: true, doubleZoomControls: false, enableMousescroll: true, imgEyecandyOpacity: 0.4, rotateFactor: 90, zoomFactor: 20, outputUrlId: 'image_input', // loadPicture: '加dD片', processInline: true, loaderHtml: '
您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号