一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - php+croppic.js實現剪切上傳圖片功能

php+croppic.js實現剪切上傳圖片功能

2019-09-12 12:01mengchenchen PHP教程

最近做項目遇到這樣的需求,需要實現裁剪圖片上傳,接下來通過本文給大家分享基于php+croppic.js實現剪切上傳圖片功能,需要的朋友可以參考下

最近需要實現裁剪圖片上傳,想起之前公司用到的一個插件,卻不知道叫什么名字了。

在網上找了有些時間,最終找到了這個網站。

http://www.croppic.net/

因為官網文檔全部都是英文,所以看起來有些吃力,可以大概看懂80%,但是缺少詳細的案例說明,所以真正配置起來還是非常懵逼。

如果完全按照官網文檔的步驟,大概就是這樣的

下載安裝

php+croppic.js實現剪切上傳圖片功能

官網提供兩種下載方式,第一種類似于SDK的whole website,另外一種 簡潔版croppic。前者提供了完整的項目結構以及前后端案例,后者只有croppic.css、croppic.js、croppic.min.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($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);

 

JS各種配置

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: '加載圖片',
    processInline: true,
    loaderHtml: '<div class="loader bubblingG"><span id="bubblingG_1"></span><span id="bubblingG_2"></span><span id="bubblingG_3"></span></div> ',
    onBeforeImgUpload: function () {
      crop_image_src = $('#image_input').val();
    },
    onAfterRemoveCroppedImg: function () {
      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();
      }
    },
    onReset: function () {
      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('');
      }
    },
    onError: function (errormessage) {
      alert('onError:' + errormessage)
    }
  };
  var cropperBox = new Croppic('cropContainerEyecandy', croppedOptions);

總結

以上所述是小編給大家介紹的php+croppic.js實現剪切上傳圖片功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美操大逼视频 | 被强迫变性翘秘书 | 精品午夜寂寞黄网站在线 | 国产一区二区免费在线 | 国产一区在线免费观看 | 亚洲成人看片 | 久久视热频国产这里只有精品23 | 免费观看小视频 | 白俄罗斯bbbsss | 好爽好深好猛好舒服视频上 | 精品高潮呻吟99AV无码视频 | 国产欧美另类久久精品91 | 国产色图片 | 奇米影视77777| 顶级欧美做受xxx000 | 欧美最猛性xxxxx动态图 | 性做久久久久久 | 成人性爱视频在线观看 | 国产性做久久久久久 | 第一次破学生处破 | 猫扑俩性 | 天海翼最新作品 | 亚洲午夜久久久久影院 | 三年片韩国在线 | 欧美╳bbbb| 韩国黄色片网站 | 成人在线播放视频 | 亚洲国产精品久久网午夜小说 | 久久 这里只精品 免费 | 成人精品一区久久久久 | 欧美一区精品二区三区 | 日本孕妇与黑人xxxxxx | jzz大全部 | 国产精品日韩欧美在线 | 黑帮少爷爱上我第8集在线观看 | 欧美a欧美1级 | 婷婷麻豆| 激情视频激情小说 | 操动漫美女视频 | 青青青国产在线观看 | 精品久久久久久无码人妻国产馆 |