校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > php+croppic.js實現剪切上傳圖片功能

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

熱門標簽:太原400電話申請流程 萍鄉商鋪地圖標注 宿州正規外呼系統軟件 桂陽公司如何做地圖標注 神龍斗士電話機器人 電信外呼系統多少錢一個月 代理打電話機器人 合肥企業外呼系統線路 企業400電話辦理多少費用

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

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

http://www.croppic.net/

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

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

下載安裝

 

官網提供兩種下載方式,第一種類似于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 端使用 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實現剪切上傳圖片功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • 原生JS實現前端本地文件上傳
  • JS實現可視化文件上傳
  • js實現文件上傳功能 后臺使用MultipartFile
  • JS+Struts2多文件上傳實例詳解
  • vue.js 圖片上傳并預覽及圖片更換功能的實現代碼
  • JavaScript使用享元模式實現文件上傳優化操作示例
  • JS實現圖片上傳多次上傳同一張不生效的處理方法
  • js實現圖片上傳并預覽功能
  • vue.js圖片轉Base64上傳圖片并預覽的實現方法
  • Angularjs實現多圖片上傳預覽功能
  • JavaScript實現異步圖像上傳功能
  • SpringBoot+Vue.js實現前后端分離的文件上傳功能
  • node.js自動上傳ftp的腳本分享
  • JS實現的文件拖拽上傳功能示例
  • Vue2.0實現調用攝像頭進行拍照功能 exif.js實現圖片上傳功能
  • JS和Canvas實現圖片的預覽壓縮和上傳功能
  • JavaScript代碼實現txt文件的上傳預覽功能
  • js 實現 input type="file" 文件上傳示例代碼
  • js實現上傳圖片預覽的方法
  • Servlet+Jsp實現圖片或文件的上傳功能具體思路及代碼
  • 上傳圖片預覽JS腳本 Input file圖片預覽的實現示例
  • JS實現上傳圖片的三種方法并實現預覽圖片功能
  • js實現圖片上傳并正常顯示
  • 一個簡單的jQuery插件ajaxfileupload.js實現ajax上傳文件例子
  • JS中使用FormData上傳文件、圖片的方法
  • 客戶端js判斷文件類型和文件大小即限制上傳大小
  • js獲取上傳文件的絕對路徑實現方法
  • 原生JS和jQuery版實現文件上傳功能
  • 微信JSSDK上傳圖片
  • 簡單實現js上傳文件功能
  • JS文件上傳神器bootstrap fileinput詳解
  • js實現上傳圖片之上傳前預覽圖片
  • Javascript圖片上傳前的本地預覽實例
  • 學習使用AngularJS文件上傳控件
  • JS簡單實現文件上傳實例代碼(無需插件)
  • 分享5個好用的javascript文件上傳插件

標簽:白銀 廊坊 衡陽 鄂州 崇左 辛集 太原 綏化

巨人網絡通訊聲明:本文標題《php+croppic.js實現剪切上傳圖片功能》,本文關鍵詞  php+croppic.js,實現,剪切,上傳,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php+croppic.js實現剪切上傳圖片功能》相關的同類信息!
  • 本頁收集關于php+croppic.js實現剪切上傳圖片功能的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    美女一区二区三区| 91免费看片在线观看| 久久夜色精品一区| 国产精品亚洲人在线观看| 中文字幕久久午夜不卡| 91美女福利视频| 图片区小说区国产精品视频| 7777精品伊人久久久大香线蕉的 | 久久超碰97人人做人人爱| 日韩视频在线你懂得| 国产精品一区免费在线观看| 中文一区一区三区高中清不卡| av中文字幕亚洲| 亚洲香肠在线观看| 日韩片之四级片| 成人夜色视频网站在线观看| 自拍视频在线观看一区二区| 7777女厕盗摄久久久| 国产一区999| 亚洲欧美另类在线| 91麻豆精品国产91久久久| 国产一区二区免费看| 亚洲男帅同性gay1069| 欧美日韩色一区| 国产精品影视网| 亚洲欧美日韩国产综合| 91精品午夜视频| 国产成人av电影免费在线观看| 亚洲乱码中文字幕| 欧美一区二区三区视频在线| 国产乱码精品一区二区三| 亚洲精品国产一区二区精华液 | 日韩激情视频在线观看| 国产日产亚洲精品系列| 91国产免费观看| 久久99国产精品麻豆| 综合在线观看色| 欧美一区永久视频免费观看| 国产99久久久精品| 五月婷婷色综合| 国产精品久久久久精k8| 91麻豆精品国产91久久久久久| 国产成人在线观看免费网站| 亚洲在线视频免费观看| 久久久一区二区| 在线观看视频91| 国产成人在线免费| 天天爽夜夜爽夜夜爽精品视频| 欧美激情一区二区三区四区 | 欧美欧美午夜aⅴ在线观看| 国产精品羞羞答答xxdd| 午夜精品在线看| 国产精品无圣光一区二区| 日韩一区二区三区三四区视频在线观看 | 国产欧美日韩不卡免费| 欧美三级日本三级少妇99| 国产精品一二三四五| 亚洲成av人片在线| 国产精品久久久久一区二区三区共| 欧美一区二区三区视频免费 | 欧美视频一区二区三区在线观看 | 日本精品一区二区三区高清| 韩国午夜理伦三级不卡影院| 亚洲一区电影777| 国产欧美日韩三区| 日韩精品在线网站| 欧美午夜精品久久久久久孕妇| 成人性生交大片免费看中文| 久久99国产精品尤物| 午夜精品一区二区三区免费视频| 亚洲欧洲精品成人久久奇米网| 欧美电影免费观看高清完整版| 在线观看成人小视频| 北岛玲一区二区三区四区| 美女诱惑一区二区| 婷婷久久综合九色综合伊人色| 亚洲欧美乱综合| 国产精品视频麻豆| 久久久天堂av| 在线看日韩精品电影| 成人精品在线视频观看| 国产一区久久久| 蜜臀av性久久久久蜜臀aⅴ| 亚洲乱码中文字幕综合| 中文字幕永久在线不卡| 国产欧美一区二区精品忘忧草| 欧美成人精精品一区二区频| 欧美精三区欧美精三区| 欧美午夜不卡在线观看免费| 99精品久久99久久久久| 国产成人超碰人人澡人人澡| 久久精品国产**网站演员| 三级一区在线视频先锋| 香蕉乱码成人久久天堂爱免费| 亚洲乱码中文字幕综合| 亚洲欧美日韩中文字幕一区二区三区 | 久久国产精品无码网站| 日韩中文字幕亚洲一区二区va在线| 亚洲欧美另类综合偷拍| 亚洲男人的天堂一区二区| 国产精品成人一区二区三区夜夜夜| 久久亚洲欧美国产精品乐播| 久久免费国产精品| 久久久精品蜜桃| 久久久久国产免费免费 | 中文无字幕一区二区三区| 26uuu久久天堂性欧美| 精品1区2区在线观看| 2017欧美狠狠色| 精品日本一线二线三线不卡| 欧美变态tickle挠乳网站| 日韩女优电影在线观看| 精品日韩一区二区| 久久精品综合网| 国产精品每日更新| 中文字幕综合网| 亚洲综合一区二区三区| 午夜天堂影视香蕉久久| 日韩电影在线一区二区三区| 免费成人性网站| 久久国产成人午夜av影院| 国产一区二区三区免费| 国产精品一品二品| caoporn国产精品| 日本韩国一区二区三区| 欧美日韩国产综合视频在线观看| 一区二区三区四区视频精品免费 | 日韩欧美久久久| 精品少妇一区二区三区视频免付费 | 国产精品综合一区二区三区| 国产精品夜夜嗨| 99久久精品免费| 欧美网站一区二区| 欧美一区二区三区思思人| 久久综合狠狠综合久久综合88| 欧美激情在线一区二区三区| 亚洲三级视频在线观看| 亚洲成在人线免费| 麻豆专区一区二区三区四区五区| 国产专区欧美精品| 99久久久久免费精品国产| 欧美日韩激情在线| 久久久九九九九| 夜夜爽夜夜爽精品视频| 日本欧美久久久久免费播放网| 韩国av一区二区三区在线观看| 成人黄色小视频在线观看| 日本韩国欧美在线| 欧美一区二区啪啪| 国产精品美女一区二区| 亚洲亚洲人成综合网络| 精品一区二区三区免费| 99视频在线精品| 欧美精品三级日韩久久| 久久久久久免费| 亚洲激情综合网| 看电视剧不卡顿的网站| 成人福利在线看| 欧美喷潮久久久xxxxx| 亚洲国产精品国自产拍av| 亚洲一级在线观看| 国产精华液一区二区三区| 欧美性色黄大片手机版| 2014亚洲片线观看视频免费| 亚洲人成7777| 裸体歌舞表演一区二区| 99免费精品视频| 日韩一级大片在线观看| 中文字幕中文字幕一区| 麻豆成人久久精品二区三区红| eeuss鲁一区二区三区| 91精品福利在线一区二区三区| 国产精品第13页| 久草中文综合在线| 日本精品视频一区二区三区| 久久老女人爱爱| 日一区二区三区| 成人激情图片网| 精品日产卡一卡二卡麻豆| 亚洲女与黑人做爰| 国产一区高清在线| 欧美男男青年gay1069videost | 欧美成人猛片aaaaaaa| 亚洲女同一区二区| 国产大片一区二区| 日韩一二三区视频| 一区二区三区91| 成人综合婷婷国产精品久久 | 成人一道本在线| 666欧美在线视频| 亚洲少妇屁股交4| 国产一二精品视频| 91精品在线一区二区| 亚洲伦理在线免费看| 粉嫩欧美一区二区三区高清影视 | 亚洲一区二区三区在线| 风间由美一区二区三区在线观看| 欧美一级一级性生活免费录像| av不卡在线观看| 久久精品一区二区三区四区|