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

主頁 > 知識庫 > 深入研究HTML5實現圖片壓縮上傳功能

深入研究HTML5實現圖片壓縮上傳功能

熱門標簽:鶴壁手機自動外呼系統怎么安裝 鄭州電銷外呼系統違法嗎 中紳電銷智能機器人 ai電銷機器人連接網關 漳州人工外呼系統排名 農村住宅地圖標注 威海營銷外呼系統招商 濟南辦理400電話 跟電銷機器人做同事

上篇文章中提到移動端上傳圖片,我們知道現在流量還是挺貴的,手機的像素是越來越高,拍個照動不動就是好幾M,傷不起。雖然客戶端可以輕輕松松實現圖片壓縮再上傳,但是我們的應用還可能在瀏覽器里面打開,怎么辦呢,圖片壓縮。受以前PC上的開發思維影響,尼瑪js哪有權限去操作文件,哪有資格壓縮圖片啊,搞不了,你們客戶端去整吧。只能說自己還是有些井底之蛙了。在HTML5的影響下,前端能干的事情越來越多了,開發的功能逼格也越來越高了,H5萬歲!前端的魅力也在這,過去不可能的并不意味現在、以后不可能,努力吧,騷年!

js怎么壓縮圖片???潛意識里確實一開始是覺得實現不了,后來翻閱資料,研究了下,發現可行!搞起!

先說說H5以前我們怎么上傳,一般是借助插件、flash或者干脆一個文件form表單,少操不少心。

自從有了H5,老板再也不擔心我的開發了。

上篇文章提到圖片上傳用到了FileReader,FormData,實際上主要用這兩個我們基本能實現圖片的預覽和上傳了。實現圖片壓縮,我們需要借助canvas,是的,就是canvas!

大致思路是:

1、創建一個圖片和一個canvas

XML/HTML Code復制內容到剪貼板
  1. var image = new Image(),   
  2. canvas = document.createElement("canvas"),   
  3. ctx = canvas.getContext('2d');  

2、我們將input中選擇的圖片地址通過FileReader獲取后賦給新建的圖片對象,然后將圖片對象丟到canvas畫布上。

XML/HTML Code復制內容到剪貼板
  1. var file = obj.files[0];   
  2.                         var reader = new FileReader();//讀取客戶端上的文件   
  3.                         reader.onload = function() {   
  4.                             var url = reader.result;//讀取到的文件內容.這個屬性只在讀取操作完成之后才有效,并且數據的格式取決于讀取操作是由哪個方法發起的.所以必須使用reader.onload,   
  5.                             image.src=url;//reader讀取的文件內容是base64,利用這個url就能實現上傳前預覽圖片   
  6.                             ...   
  7.                         };   
  8.                         image.onload = function() {   
  9.                             var w = image.naturalWidth,   
  10.                                 h = image.naturalHeight;   
  11.                             canvas.width = w;   
  12.                             canvas.height = h;   
  13.                             ctx.drawImage(image, 0, 0, w, h, 0, 0, w, h);   
  14.                             fileUpload();   
  15.                         };   
  16.                         reader.readAsDataURL(file);  


這里需要注意的是,canvas將圖片畫到畫布上的時候需要確定canvas的尺寸,同時設定好drawImage的參數,具體如下:

XML/HTML Code復制內容到剪貼板
  1. void ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);  

dx源圖像的左上角在目標canvas上 X 軸的位置。

dy源圖像的左上角在目標canvas上 Y 軸的位置。

dWidth在目標canvas上繪制圖像的寬度。 允許對繪制的圖像進行縮放。 如果不說明, 在繪制時圖片寬度不會縮放。

dHeight在目標canvas上繪制圖像的高度。 允許對繪制的圖像進行縮放。 如果不說明, 在繪制時圖片高度不會縮放。

sx需要繪制到目標上下文中的,源圖像的矩形選擇框的左上角 X 坐標。

sy需要繪制到目標上下文中的,源圖像的矩形選擇框的左上角 Y 坐標。

sWidth需要繪制到目標上下文中的,源圖像的矩形選擇框的寬度。如果不說明,整個矩形從坐標的sx和sy開始,到圖像的右下角結束。

sHeight需要繪制到目標上下文中的,源圖像的矩形選擇框的高度。

為了上傳完整的圖片,這里dx,dy必須設置為0,dWidth和dHeight必須設置為原始圖片的寬度和高度。這就是為什么我們需要等image對象下載完畢后獲取其原始尺寸,這很關鍵!

3、圖片上傳

XML/HTML Code復制內容到剪貼板
  1. function fileUpload() {   
  2.      var data = canvas.toDataURL("image/jpeg", quality);   
  3.      //dataURL 的格式為 “data:image/png;base64,****”,逗號之前都是一些說明性的文字,我們只需要逗號之后的就行了   
  4.     datadata = data.split(',')[1];   
  5.     data = window.atob(data);   
  6.     var ia = new Uint8Array(data.length);   
  7.     for (var i = 0; i < data.length; i++) {   
  8.           ia[i] = data.charCodeAt(i);   
  9.     };   
  10.      //canvas.toDataURL 返回的默認格式就是 image/png   
  11.     var blob = new Blob([ia], {   
  12.      type: "image/jpeg"   
  13.     });   
  14.     var fd = new FormData();   
  15.         fd.append('myFile', blob);   
  16.     var xhr = new XMLHttpRequest();   
  17.     xhr.addEventListener("load", opts.success, false);   
  18.     xhr.addEventListener("error", opts.error, false);   
  19.     xhr.open("POST", opts.url);   
  20.     xhr.send(fd);   
  21.  }  

這里用的關鍵方法是canvas.toDataURL

XML/HTML Code復制內容到剪貼板
  1. canvas.toDataURL(type, encoderOptions);  

官方的說明是The HTMLCanvasElement.toDataURL() method returns a data URI containing a representation of the image in the format specified by the type parameter (defaults to PNG). The returned image is in a resolution of 96 dpi.實際上就是讀取canvas畫布上圖片的數據。其默認是png格式,如果第一個參數type是image/jpeg的話,第二個參數encoderOptions就可以用來設置圖片的壓縮質量,經過測試,如果是png格式,100%的寬高經過該方法還有可能使圖片變大~~~~適得其反,所以我們可以在canvas.drawImage的時候適當設置sWidth和sHeight,比如同比例縮小1.5倍等,圖片質量其實并不太影響查看,尤其對尺寸比較大的圖片來說。

上面還有比較陌生的方法atob,其作用是做解碼,因為圖片格式的base64.

XML/HTML Code復制內容到剪貼板
  1. var encodedData = window.btoa("Hello, world"); // encode a string   
  2. var decodedData = window.atob(encodedData); // decode the string  

該方法解碼出來可能是一堆亂碼,Uint8Array返回的是8進制整型數組。

Blob是存儲二進制文件的容器,典型的Blob對象是一個圖片或者聲音文件,其默認是PNG格式。

XML/HTML Code復制內容到剪貼板
  1. var blob = new Blob([ia], {   
  2.      type: "image/jpeg"   
  3.     });  

最后通過ajax將Blob對象發送到server即可。

整個流程大致如上,但是~~~實現以后測試跑來說:“你不是說圖片壓縮了嗎,為什么圖片還是上傳那么慢!”,哥拿起手機對妹紙演示了一下,明明很快嘛,于是反道“是你手機不行或者網絡不好吧,你下載圖片看明明變小了,比之前肯定快,你看我秒傳”。呵呵,說歸說,還是偷偷檢查代碼,在瀏覽器中打時間log,對比沒壓縮之前的,尼瑪?。?!居然才快了幾百毫秒!!折騰了半天,之前的代碼也重構了,玩我呢。

細心的大神看了上面的代碼估計能猜出問題在哪,沒錯,獲取本地圖片長寬尺寸的時候出了問題。

我去,獲取本地4M大小的圖片尺寸花了3174ms??!,圖片越大時間也越久~

JavaScript Code復制內容到剪貼板
  1. image.onload = function() {   
  2.         var w = image.naturalWidth,   
  3.           h = image.naturalHeight;   
  4.         canvas.width = w / 1.5;   
  5.         canvas.height = h / 1.5;   
  6.         ctx.drawImage(image, 0, 0, w, h, 0, 0, w / 1.5, h / 1.5);   
  7.         Upload.fileUpload(type);   
  8. };  

瀏覽器在本地取圖片的時候是沒法直接像file.size一樣獲取其長寬的,只能通過FileReader拿到內容后賦值給新建的image對象,新建的image對象下載需要時間!怎么破?不就是獲取本地圖片的尺寸嗎,難道沒有別的辦法了?

于是想到了之前研究過的快速獲取圖片長寬的博文,點擊進入 ,demo地址:http://jsbin.com/jivugadure/edit?html,js,output,定時去查詢圖片加載過程中的高度或者寬度,不用等整個圖片加載完畢。

測了下,還是不行,因為定時查詢這種方法對常規的server返回的圖片有作用,這里圖片地址是base64,貌似時間還更久了~哭。


小結一下:

1、用HTML5來壓縮圖片上傳是可行的,在移動端我們不用依賴客戶端或者插件,目前主流瀏覽器支持程度已經很高了。

2、壓縮圖片一方面是想減少用戶上傳等待的時間,另外也減少用戶為此犧牲的流量,從整體時間來看,因為獲取圖片尺寸導致多一次下載需要耗時,其實壓不壓縮時間差別并不是特別大。除非大神們找到合適的方法能夠直接獲取圖片的尺寸,麻煩也告知我一聲,萬分感謝;

3、既然時間成本差不多,但是我們壓縮了圖片,減少了圖片的大小,減少了流量的消耗,存儲空間以及下次獲取該圖片的時間,所以還是值得的。

 補充源代碼:

JavaScript Code復制內容到剪貼板
  1. (function($) {   
  2.     $.extend($.fn, {   
  3.         fileUpload: function(opts) {   
  4.             this.each(function() {   
  5.                 var $self = $(this);   
  6.                 var quality = opts.quality ? opts.quality / 100 : 0.2;   
  7.                 var dom = {   
  8.                     "fileToUpload": $self.find(".fileToUpload"),   
  9.                     "thumb": $self.find(".thumb"),   
  10.                     "progress": $self.find(".upload-progress")   
  11.                 };   
  12.                 var image = new Image(),   
  13.                     canvas = document.createElement("canvas"),   
  14.                     ctx = canvas.getContext('2d');   
  15.                 var funs = {   
  16.                     setImageUrl: function(url) {   
  17.                         image.src = url;   
  18.                     },   
  19.                     bindEvent: function() {   
  20.                         console.log(dom.fileToUpload)   
  21.                         dom.fileToUpload.on("change"function() {   
  22.                             funs.fileSelect(this);   
  23.                         });   
  24.                     },   
  25.                     fileSelect: function(obj) {   
  26.                         var file = obj.files[0];   
  27.                         var reader = new FileReader();   
  28.                         reader.onload = function() {   
  29.                             var url = reader.result;   
  30.                             funs.setImageUrl(url);   
  31.                             dom.thumb.html(image);   
  32.                         };   
  33.                         image.onload = function() {   
  34.                             var w = image.naturalWidth,   
  35.                                 h = image.naturalHeight;   
  36.                             canvas.width = w;   
  37.                             canvas.height = h;   
  38.                             ctx.drawImage(image, 0, 0, w, h, 0, 0, w, h);   
  39.                             funs.fileUpload();   
  40.                         };   
  41.                         reader.readAsDataURL(file);   
  42.                     },   
  43.                     fileUpload: function() {   
  44.                         var data = canvas.toDataURL("image/jpeg", quality);   
  45.                         //dataURL 的格式為 “data:image/png;base64,****”,逗號之前都是一些說明性的文字,我們只需要逗號之后的就行了   
  46.                         data = data.split(',')[1];   
  47.                         data = window.atob(data);   
  48.                         var ia = new Uint8Array(data.length);   
  49.                         for (var i = 0; i < data.length; i++) {   
  50.                             ia[i] = data.charCodeAt(i);   
  51.                         };   
  52.                         //canvas.toDataURL 返回的默認格式就是 image/png   
  53.                         var blob = new Blob([ia], {   
  54.                             type: "image/jpeg"  
  55.                         });   
  56.                         var fd = new FormData();   
  57.                         fd.append('myFile', blob);   
  58.                         var xhr = new XMLHttpRequest();   
  59.                         xhr.addEventListener("load", opts.success, false);   
  60.                         xhr.addEventListener("error", opts.error, false);   
  61.                         xhr.open("POST", opts.url);   
  62.                         xhr.send(fd);   
  63.                     }   
  64.                 };   
  65.                 funs.bindEvent();   
  66.             });   
  67.         }   
  68.     });   
  69. })(Zepto);  

調用方式:

JavaScript Code復制內容到剪貼板
  1. $(".fileUpload").fileUpload({   
  2.                 "url""savetofile.php",   
  3.                 "file""myFile",   
  4.                 "success":function(evt){   
  5.                     console.log(evt.target.responseText)   
  6.                 }   
  7. });  

希望大家能找到更好的辦法,多多交流!感謝!

以上這篇深入研究HTML5實現圖片壓縮上傳功能就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

原文地址:http://www.cnblogs.com/hutuzhu/p/5265023.html

標簽:甘南 文山 惠州 紅河 咸陽 營口 蘇州 萍鄉

巨人網絡通訊聲明:本文標題《深入研究HTML5實現圖片壓縮上傳功能》,本文關鍵詞  深入研究,HTML5,實現,圖片,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入研究HTML5實現圖片壓縮上傳功能》相關的同類信息!
  • 本頁收集關于深入研究HTML5實現圖片壓縮上傳功能的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩欧美国产不卡| 欧洲色大大久久| 亚洲一区二区三区小说| 日韩一区二区在线观看| 在线播放日韩导航| 中文字幕av一区 二区| 懂色av一区二区夜夜嗨| 亚洲免费观看高清完整| 国产精品白丝jk白祙喷水网站| 精品一区二区三区免费毛片爱| 久久99精品久久久久久动态图| 久久 天天综合| 蜜桃久久久久久久| 久久精品72免费观看| 韩国女主播成人在线观看| 日韩一区二区三区三四区视频在线观看 | 久久久美女毛片| 欧美日韩国产综合视频在线观看| 欧美三级在线视频| 久久伊99综合婷婷久久伊| 综合激情网...| 图片区小说区区亚洲影院| 国产精品羞羞答答xxdd| 欧美日韩国产首页在线观看| 欧美精品一区二区三| 亚洲综合成人网| 国产乱码精品一品二品| 欧美人狂配大交3d怪物一区| 国产欧美精品区一区二区三区| 亚洲成人在线网站| 99久久精品久久久久久清纯| 久久久亚洲精品石原莉奈| 亚洲欧美日韩中文播放| 成人亚洲一区二区一| 日本一区二区免费在线| 一区二区三区在线视频免费| 日韩影院精彩在线| 亚洲成av人片一区二区梦乃 | 高清av一区二区| 综合欧美亚洲日本| 亚洲一区二区三区美女| 日韩毛片视频在线看| 亚洲一二三四久久| 国产精品一区二区你懂的| 色久综合一二码| 久久久精品一品道一区| 亚洲欧美日韩电影| 精品在线播放免费| 欧美日韩一区二区三区在线看 | 亚洲色图都市小说| 国产ts人妖一区二区| 日韩毛片视频在线看| 91丨九色porny丨蝌蚪| 亚洲国产高清aⅴ视频| 国产一区二区在线观看免费| 久久久夜色精品亚洲| 不卡在线视频中文字幕| 国产精品久久久久一区二区三区共| 亚洲图片你懂的| 欧美xxxxx牲另类人与| 国产成人亚洲综合a∨婷婷图片| 国产精品国产三级国产aⅴ中文 | 国产日产欧产精品推荐色| 韩国成人福利片在线播放| 国产精品午夜在线| 欧美一区二区在线免费播放 | 91精品1区2区| 精品在线免费观看| 久久91精品国产91久久小草 | 亚洲一区二区不卡免费| 97精品久久久久中文字幕 | 亚洲国产电影在线观看| 欧美日韩成人一区| 日本一区二区免费在线 | 色综合久久九月婷婷色综合| 国产精品免费人成网站| 成人高清视频在线观看| 国产精品欧美综合在线| 成人午夜私人影院| 国产精品视频九色porn| 中文字幕一区二区三区精华液 | 国产精品免费av| 国产亚洲一区二区在线观看| 国内精品伊人久久久久av一坑| 亚洲h在线观看| 亚洲制服丝袜在线| 一区二区三区不卡在线观看 | 一片黄亚洲嫩模| 亚洲精品国久久99热| 亚洲一区二区在线免费看| 亚洲欧美在线观看| 亚洲日本一区二区三区| 亚洲国产sm捆绑调教视频 | 久久久精品黄色| 久久精品一区二区| 亚洲伦理在线精品| 图片区小说区国产精品视频| 青青青爽久久午夜综合久久午夜| 日韩国产欧美在线播放| 麻豆91在线观看| 99久久伊人网影院| 在线观看av一区二区| 精品国产免费视频| 精品1区2区在线观看| 国产91高潮流白浆在线麻豆| 欧美日韩国产经典色站一区二区三区| 亚洲欧美另类图片小说| 懂色av一区二区三区免费观看 | 丝瓜av网站精品一区二区| 91免费版在线看| 亚洲精品视频在线观看网站| 国产成人av电影在线| 欧美精品乱码久久久久久按摩| av中文字幕不卡| 亚洲另类在线制服丝袜| 国产欧美一区二区三区在线老狼| 欧美精品乱人伦久久久久久| 久久久久久久久久久久电影| 色老综合老女人久久久| 激情亚洲综合在线| 亚洲一区二区视频| 国产精品每日更新| 欧美一区二区三区四区视频| 成人动漫一区二区在线| 男女性色大片免费观看一区二区| 欧美国产激情一区二区三区蜜月| 91女人视频在线观看| 亚洲精品福利视频网站| 成人免费毛片a| 自拍偷拍欧美精品| 91国产视频在线观看| 亚洲午夜电影网| 欧美一区二区日韩一区二区| 久久激情五月激情| 精品人伦一区二区色婷婷| 久久99久国产精品黄毛片色诱| xvideos.蜜桃一区二区| 亚洲精品视频一区二区| 色综合一区二区| 亚洲成va人在线观看| 欧美色涩在线第一页| 美女视频黄免费的久久 | 免费久久精品视频| 欧美理论在线播放| 韩日精品视频一区| 一区二区三区高清在线| 欧美日韩一级黄| 国产一区二区三区av电影| 中文字幕一区二区三中文字幕| 欧美刺激午夜性久久久久久久| 狠狠狠色丁香婷婷综合激情| 国产精品毛片大码女人| 在线一区二区三区四区五区| 免费观看在线综合色| 国产精品嫩草影院av蜜臀| 国产精品视频免费看| 欧美精品久久久久久久多人混战 | 国产一区二区三区黄视频 | 成人动漫在线一区| 国产成人99久久亚洲综合精品| 国产在线视视频有精品| 精品一区二区日韩| 国产一区二区三区黄视频 | 欧美二区三区91| 94-欧美-setu| 色噜噜狠狠一区二区三区果冻| 亚洲不卡一区二区三区| 91精品欧美福利在线观看| 91视频.com| 欧美日韩一区二区三区免费看| 欧美麻豆精品久久久久久| 日韩一级成人av| 国产精品一区二区视频| 免费亚洲电影在线| 在线播放91灌醉迷j高跟美女| 五月激情综合网| 日韩一区二区免费高清| 国产一区二区三区在线看麻豆| 日韩精品中文字幕在线不卡尤物| 欧美一级精品大片| 久久一夜天堂av一区二区三区| 欧美大肚乱孕交hd孕妇| 欧美系列日韩一区| 欧美不卡在线视频| 综合电影一区二区三区| 国产精一区二区三区| 精品免费99久久| 久久久亚洲综合| 国产精品国产自产拍高清av| 亚洲综合视频在线观看| 麻豆成人久久精品二区三区红| 成人av电影观看| 91精品国产色综合久久不卡蜜臀| 国产午夜三级一区二区三| 亚洲一级在线观看| 国产成人在线免费观看| 欧美色倩网站大全免费| 亚洲国产精品激情在线观看| 亚洲综合成人在线| 成人av午夜影院|