温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何在php中利用croppic.js对图片进行剪切并上传

发布时间:2021-01-30 16:41:02 阅读:295 作者:Leah 栏目:开发技术
PHP开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章将为大家详细讲解有关如何在php中利用croppic.js对图片进行剪切并上传,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

使用

// css 部分
#yourId {
  width: 200px;
  height: 150px;
  position:relative; /* or fixed or absolute */
}
// html 部分
<div id="yourId"></div>
// js部分
var options = [
  uploadUrl:'图片上传地址',
  cropUrl: '图片裁切后发送的地址',
  // 等等各种参数配置信息
];
var cropperHeader = new Croppic('yourId',options);

Options 参数

uploadUrl

uploadUrl:'制定上传的地址',
uploadData:{
  "dummyData":1,
  "dummyData2":"text"
}

php处理时,和普通的上传文件一模一样,使用$_FILES['img']可以直接获取文件信息,上传并保存;使用$_REQUEST[]则直接可以获取js中uploadData中的数据。

php在处理完成后,根据成功状态返回如下json结构

成功时

{
   "status":"success",
  "url":"返回成功后的图片url地址",
  "width":源图片宽度, 
   "height":源图片高度
}

注意:源图片宽高获取方式 list($width, $height) = getimagesize($_FILES["img"]["tmp_name"]);

失败时

{
 "status":"error",
 "message":"这里是你的失败提示信息"
}

cropUrl

接下来是裁切图片的请求,基本使用

var cropperOptions = {
  uploadUrl:'裁切后请求的地址',
  uploadData:{
   "dummyData":1,
   "dummyData2":"text"
  }
}
var cropperHeader = new Croppic('yourId', cropperOptions);

请求php的参数基本如下:

如何在php中利用croppic.js对图片进行剪切并上传 

php 端使用 nezamy/route 的request类获取croppic.js裁切后发送过来的参数

$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'];

其他参数就不用介绍了,文档上面可以看,如果看不懂或者不太清晰的可以直接下载案例做参照,比文档要详细些。接下来的重头戏在php端的处理。

PHP 各种操作图片GD库

$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($resizedImageimagecolorallocate($resizedImage000));
}
imagecopyresampled($resizedImage$source_image0000$imgW$imgH$imgInitW$imgInitH);
// 旋转图像
$rotated_image $angle imagerotate($resizedImage, -$angle0) : $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_imageimagecolorallocate($cropped_rotated_image000));
}
imagecopyresampled($cropped_rotated_image$rotated_image00$dx 2$dy 2$imgW$imgH$imgW$imgH);
// 剪切图像到规定区域
$final_image imagecreatetruecolor($cropW$cropH);
if ($type == '.png') {
  imagecolortransparent($final_imageimagecolorallocate($final_image000));
}
imagecopyresampled($final_image$cropped_rotated_image00$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);

JS各种配置

var crop_image_src = 'image_src';
  var croppedOptions = {
    cropUrl'http://deng.com/m/tool/crop_pic/crop',
    modaltrue,
    doubleZoomControlsfalse,
    enableMousescrolltrue,
    imgEyecandyOpacity0.4,
    rotateFactor90,
    zoomFactor20,
    outputUrlId'image_input',
    // loadPicture: '加載圖片',
    processInlinetrue,
    loaderHtml'<div class="loader bubblingG"><span id="bubblingG_1"></span><span id="bubblingG_2"></span><span id="bubblingG_3"></span></div> ',
    onBeforeImgUploadfunction () {
      crop_image_src = $('#image_input').val();
    },
    onAfterRemoveCroppedImgfunction () {
      var res = confirm('您是要使用原图还是清除图片?\n\r[确认]使用原图,[取消]清除图片');
      if (res) {
        $('#image_input').val(crop_image_src);
        $('#cropContainerEyecandy').prepend('<img class="croppedImg" src=' + crop_image_src + ' width="100%">');
      } else {
        $('#image_input').val('');
        $('.croppedImg').remove();
      }
    },
    onResetfunction () {
      var res = confirm('您是要使用原图还是清除图片?\n\r[确认]使用原图,[取消]清除图片');
      if (res) {
        $('#image_input').val(crop_image_src);
        $('#cropContainerEyecandy').prepend('<img class="croppedImg" src=' + crop_image_src + ' width="100%">');
      } else {
        $('#image_input').val('');
      }
    },
    onErrorfunction (errormessage) {
      alert('onError:' + errormessage)
    }
  };
  var cropperBox = new Croppic('cropContainerEyecandy', croppedOptions);

关于如何在php中利用croppic.js对图片进行剪切并上传就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI

开发者交流群×