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

主頁 > 知識庫 > php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能

php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能

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

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

在網(wǎng)上找了有些時間,最終找到了這個網(wǎng)站。

http://www.croppic.net/

因?yàn)楣倬W(wǎng)文檔全部都是英文,所以看起來有些吃力,可以大概看懂80%,但是缺少詳細(xì)的案例說明,所以真正配置起來還是非常懵逼。

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

下載安裝

 

官網(wǎng)提供兩種下載方式,第一種類似于SDK的whole website,另外一種 簡潔版croppic。前者提供了完整的項(xiàng)目結(jié)構(gòu)以及前后端案例,后者只有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: '圖片裁切后發(fā)送的地址',
  // 等等各種參數(shù)配置信息
];
var cropperHeader = new Croppic('yourId',options);

Options 參數(shù)

uploadUrl

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

php處理時,和普通的上傳文件一模一樣,使用$_FILES['img']可以直接獲取文件信息,上傳并保存;使用$_REQUEST[]則直接可以獲取js中uploadData中的數(shù)據(jù)。

php在處理完成后,根據(jù)成功狀態(tài)返回如下json結(jié)構(gòu)

成功時

{
   "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的參數(shù)基本如下:

 

php 端使用 nezamy/route 的request類獲取croppic.js裁切后發(fā)送過來的參數(shù)

$request = app('request');
// 上傳服務(wù)器的圖片路徑
$imgUrl = $request->body['imgUrl'];
// 原始圖片寬高
$imgInitW = $request->body['imgInitW'];
$imgInitH = $request->body['imgInitH'];
// 新縮放的圖片寬高
$imgW = $request->body['imgW'];
$imgH = $request->body['imgH'];
// 與縮放圖像相關(guān)的裁剪圖像的左上角
$imgY1 = $request->body['imgY1'];
$imgX1 = $request->body['imgX1'];
// 裁剪圖像寬高
$cropW = $request->body['cropW'];
$cropH = $request->body['cropH'];
// 角度
$angle = $request->body['rotation'];

其他參數(shù)就不用介紹了,文檔上面可以看,如果看不懂或者不太清晰的可以直接下載案例做參照,比文檔要詳細(xì)些。接下來的重頭戲在php端的處理。

PHP 各種操作圖片GD庫

$temp_name    = "crop_temp_" . uniqid();
$temp_path    = sys_get_temp_dir() . "/";
$output_filename = $temp_path . $temp_name;
$what      = getimagesize($imgUrl);
// 創(chuàng)建畫布并載入圖像
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('文件無法寫入');
}
// 創(chuàng)建一幅真彩色的圖像,從而支持更為豐富的色彩,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);
// 旋轉(zhuǎn)圖像
$rotated_image = $angle ? imagerotate($resizedImage, -$angle, 0) : $resizedImage;
// 獲取圖像寬高
$rotated_width = imagesx($rotated_image);
$rotated_height = imagesy($rotated_image);
// 旋轉(zhuǎn)后 - 縮放后
$dx = $rotated_width - $imgW;
$dy = $rotated_height - $imgH;
// 裁剪旋轉(zhuǎn)后的圖片到圖像
$cropped_rotated_image = imagecreatetruecolor($imgW, $imgH);
if ($type == '.png') {
  // 設(shè)置黑色為透明
  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);
// 剪切圖像到規(guī)定區(qū)域
$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);
/**
 * 這里需要進(jìn)行上傳服務(wù)器操作
 */
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[確認(rèn)]使用原圖,[取消]清除圖片');
      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[確認(rèn)]使用原圖,[取消]清除圖片');
      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);

總結(jié)

以上所述是小編給大家介紹的php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

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

標(biāo)簽:白銀 廊坊 衡陽 鄂州 崇左 辛集 太原 綏化

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能》,本文關(guān)鍵詞  php+croppic.js,實(shí)現(xiàn),剪切,上傳,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于php+croppic.js實(shí)現(xiàn)剪切上傳圖片功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产精品进线69影院| 精品午夜一区二区三区在线观看| 国产成人精品亚洲777人妖| 欧美久久久一区| 亚洲成人av在线电影| 欧美日韩国产免费一区二区| 亚洲国产毛片aaaaa无费看| 欧美色男人天堂| 日本美女一区二区| 久久久国际精品| 91丨porny丨首页| 欧美96一区二区免费视频| 欧美不卡一二三| 色综合久久综合| 久久精品国产99| 亚洲欧洲综合另类在线| 91精品国产综合久久精品性色| 久久www免费人成看片高清| 久久精品欧美一区二区三区麻豆| 国产成人精品1024| 亚洲成在人线在线播放| 精品人伦一区二区色婷婷| 国产成人自拍网| 亚洲va国产天堂va久久en| 精品99一区二区| 欧美日韩精品免费观看视频| 国产做a爰片久久毛片| 一卡二卡欧美日韩| 欧美国产日韩精品免费观看| 在线播放91灌醉迷j高跟美女 | 欧美久久一二区| 97成人超碰视| 韩国女主播一区| 亚洲成av人**亚洲成av**| 亚洲天堂2016| 欧美极品少妇xxxxⅹ高跟鞋| 欧美一区二区三区影视| 一本大道综合伊人精品热热| 国产中文一区二区三区| 日韩电影在线免费看| 亚洲另类色综合网站| 国产日韩欧美麻豆| 久久久99精品久久| 精品国产污网站| 精品捆绑美女sm三区| 3atv一区二区三区| 91精品婷婷国产综合久久性色| 欧美亚洲尤物久久| 在线日韩国产精品| 欧洲av一区二区嗯嗯嗯啊| 国产成人精品影视| 处破女av一区二区| 国产成人综合在线| 国产高清久久久久| 成人性色生活片免费看爆迷你毛片| 麻豆免费精品视频| 老司机精品视频导航| 麻豆久久久久久| 国产在线精品免费| 风间由美中文字幕在线看视频国产欧美| 韩日av一区二区| 美国十次综合导航| 精品一区二区av| 丁香激情综合国产| 欧美色偷偷大香| 欧美亚洲综合色| 欧美日韩视频第一区| 正在播放一区二区| 337p粉嫩大胆色噜噜噜噜亚洲| 久久精品日产第一区二区三区高清版 | 偷拍亚洲欧洲综合| 裸体健美xxxx欧美裸体表演| 久久国产生活片100| 国产成人精品一区二区三区四区| 暴力调教一区二区三区| 99在线热播精品免费| 99精品欧美一区二区三区小说| 婷婷国产在线综合| 国产美女久久久久| 国产成人超碰人人澡人人澡| 韩国成人在线视频| 日韩激情一二三区| 日韩和欧美一区二区| 精品一区二区免费在线观看| 国产九色精品成人porny| 国产呦萝稀缺另类资源| 国产.欧美.日韩| 欧美男同性恋视频网站| 亚洲一二三四区| 99re热这里只有精品视频| 欧美精品在欧美一区二区少妇| 青青草国产精品亚洲专区无| 五月婷婷激情综合| 日韩一级大片在线| 91偷拍与自偷拍精品| 色婷婷综合久久久久中文| 欧美96一区二区免费视频| 精品综合久久久久久8888| 国产成人精品影视| 亚洲综合在线电影| 国产精品一区二区三区四区| 欧美性猛片xxxx免费看久爱| 久久色在线视频| 性做久久久久久久免费看| 大美女一区二区三区| 欧美一级生活片| 亚洲一区二区三区小说| 国产.欧美.日韩| 久久综合久久久久88| 一个色在线综合| 99国产精品国产精品毛片| 日韩精品一区二| 五月婷婷欧美视频| 91搞黄在线观看| 亚洲欧美偷拍另类a∨色屁股| 国产精品一区在线| 久久综合网色—综合色88| 日日夜夜一区二区| 欧美日韩亚洲综合| 亚洲成在人线在线播放| 在线观看日韩毛片| 亚洲免费观看高清完整版在线观看熊| 国产不卡视频一区| 国产亚洲精品bt天堂精选| 激情深爱一区二区| 精品国产乱码久久久久久图片| 青青国产91久久久久久| 欧美日韩三级视频| 香蕉影视欧美成人| 在线不卡的av| 久久97超碰色| 久久久久久久综合狠狠综合| 狠狠色丁香久久婷婷综合_中| 日韩欧美电影在线| 国产一区二区主播在线| 久久色在线观看| 9i看片成人免费高清| 亚洲嫩草精品久久| 欧美日韩午夜精品| 全国精品久久少妇| 久久久久久久综合狠狠综合| 福利电影一区二区| 亚洲另类一区二区| 欧美亚洲动漫制服丝袜| 日韩影视精彩在线| 久久综合一区二区| 91原创在线视频| 午夜视频久久久久久| 91国偷自产一区二区三区观看 | 丁香六月综合激情| 久久青草欧美一区二区三区| 美女在线视频一区| 精品国产露脸精彩对白| 国产精品一线二线三线| 国产无人区一区二区三区| 国产1区2区3区精品美女| 欧美日韩一区国产| 91久久线看在观草草青青| 国产精品网站在线| 日本黄色一区二区| 捆绑变态av一区二区三区| 91精品国产麻豆| wwww国产精品欧美| 麻豆精品在线看| 日本vs亚洲vs韩国一区三区 | 免费在线看成人av| 久久婷婷色综合| 国产激情一区二区三区| 亚洲日本青草视频在线怡红院 | 欧美一区二区视频在线观看2020 | 久久狠狠亚洲综合| 国产精品色眯眯| 欧美精品丝袜久久久中文字幕| 国产乱子伦视频一区二区三区| 亚洲特级片在线| 91精品国产福利在线观看| 国产精品系列在线观看| 一区二区三区四区亚洲| 26uuu色噜噜精品一区二区| bt7086福利一区国产| 五月婷婷综合在线| 亚洲图片激情小说| 26uuu亚洲综合色欧美| 色女孩综合影院| 久久99精品久久久久久动态图 | 久久综合狠狠综合久久综合88| 99久久er热在这里只有精品15 | 成人午夜短视频| 日本欧美肥老太交大片| 亚洲视频1区2区| 国产色一区二区| 这里只有精品视频在线观看| 99精品久久免费看蜜臀剧情介绍| 日韩黄色一级片| 夜夜精品视频一区二区| 中文字幕的久久| www久久精品| 欧美大片顶级少妇| 欧美视频你懂的| 欧美吻胸吃奶大尺度电影|