導航:首頁 > 編程語言 > 在線圖片壓縮顯示js

在線圖片壓縮顯示js

發布時間:2023-05-26 16:29:06

① 如何實現js中圖片壓縮方法

1.這個用PS轉換成JPG或者GIF或png比較大小選用。

② 怎麼用javaScript在線壓縮圖片

主要用了兩個html5的 API,一個file,一個canvas,壓縮主要使用cnavas做的,file是讀取文件,之後把壓縮好的照片放入內存,最後內存轉入表單下img.src,隨著表單提交。
照片是自己用單反拍的,5M多,壓縮下面3張分別是600多kb,400多kb,300kb的最後那張失真度很大了,壓縮效率蠻高的。

<!DOCTYPE html>
<html><head> <meta charset="utf-8"/> <title>File API Test</title> <script type="text/javascript" src="js/jquery-1.11.0.min.js"></script> <script type="text/javascript" src="js/JIC.js"></script> <style> #test{ display: none; } </style></head><body><input type="file" id="fileImg" ><form> <img src="" id="test" alt=""></form><script> function handleFileSelect (evt) { // var filebtn = document.getElementById(id); // console.log(filebtn); // var files = filebtn.target.files; // console.log(filebtn.target); // console.log(files); var files = evt.target.files; for (var i = 0, f; f = files[i]; i++) { // Only process image files. if (!f.type.match('image.*')) { continue; } var reader = new FileReader(); // Closure to capture the file information. reader.onload = (function(theFile) { return function(e) { // Render thumbnail. // console.log(evt.target.files[0]); // console.log(e.target); console.log(e.target.result); var i = document.getElementById("test"); i.src = event.target.result; console.log($(i).width()); console.log($(i).height()); $(i).css('width',$(i).width()/10+'px'); //$(i).css('height',$(i).height()/10+'px'); console.log($(i).width()); console.log($(i).height()); var quality = 50; i.src = jic.compress(i,quality).src; console.log(i.src); i.style.display = "block"; }; })(f); // Read in the image file as a data URL. reader.readAsDataURL(f); } } document.getElementById('fileImg').addEventListener('change', handleFileSelect, false);</script></body></html>

var jic = { /** * Receives an Image Object (can be JPG OR PNG) and returns a new Image Object compressed * @param {Image} source_img_obj The source Image Object * @param {Integer} quality The output quality of Image Object * @return {Image} result_image_obj The compressed Image Object */ compress: function(source_img_obj, quality, output_format){ var mime_type = "image/jpeg"; if(output_format!=undefined && output_format=="png"){ mime_type = "image/png"; } var cvs = document.createElement('canvas'); //naturalWidth真實圖片的寬度 cvs.width = source_img_obj.naturalWidth; cvs.height = source_img_obj.naturalHeight; var ctx = cvs.getContext("2d").drawImage(source_img_obj, 0, 0); var newImageData = cvs.toDataURL(mime_type, quality/100); var result_image_obj = new Image(); result_image_obj.src = newImageData; return result_image_obj; }, function ****(***)

③ js壓縮圖片 到固定像素以內,500k為例

本文旨在探究js壓縮圖片的兩種方式: 改變圖片長寬 改變圖片質量 ,和結合了以上兩者的 最終方案

首先,閱讀本文需要知道canvas的兩個方法

這兩個方法具體的說明可以在MDN上查看,關於圖片壓縮,也有很多現成的博客可以直接用。但是那些博客都有個問題,並沒有關心之後圖片的壓縮質量。
我試著用一個現成的例子去跑了一下,一個1.7M的圖片壓縮到了23k,堪稱像素級毀滅性破壞。

假如一張大圖可能包含著很多文字等關鍵信息,必須上傳之後使用方能清晰辨認。所以要壓縮之後質量盡可能接近500k的。500k像素以內,就是若一張圖寬度為1024,則高度不能超過500。因為圖片有其他的信息,也是要佔大小的。即不得大於 1024*500

所以激答,根據需求,上傳圖片不能超過500k的情況下盡可能保留圖片的清晰度。當然如果可以的情況下用上面提到的 canvas.toDataURL 設置壓縮程度為0.9,0.8試試看,圖片質量可以接受,大小會有大幅度的縮小。

如果不壓縮,靠調整圖片長寬去控制上傳大小呢?
原理很簡單,就是靠不斷地縮小限定的最大寬高,直到最終長寬的積小於規定的大小。
這種方法有可能最後得出的圖片的大小會略大於規定大小,原因上文也提到過了,如果想使用這種方法,可自行再調整一下。

上面的方法有個問題,就是改變了圖片的原始長寬。如果一個圖的長寬足夠大,壓縮圖片質量,糊一點但是內容看得清也是ok的嘛。所以,跟上面同理,我們可以不斷調整圖片的質量設定直到大小合適,那麼,如何在圖片上傳之前知道圖片的大小呢?
首先,需要知道的一點是,壓縮之後拿到的base64字元串會轉成blob對象,然後傳給服務端。
可以查閱文檔,blob對象有個屬性是size

這個size就是上傳之後實際的文件大小。
參照上面的思路,可以每次改變 canvas.toDataURL('image/' + fileType, level); level的值,去調整壓縮圖片質量,然後用blob對象的size去驗證是否滿足500k以內的需求。
關於 canvas.toDataURL 的level到底是怎麼計算的,MDN文檔里也沒說,寫了個循環一次減少0.1的level壓縮了幾個圖片

用加減乘除算了一下,沒找到規律,數學不好放棄了(這個東西好像也不是能觀察出來的,看結果跟初始大小沒啥關系)。
這里要注意的是,有可能遇到超大圖片悶早,0.1的level可能不足以壓縮到500k,所以小於0.1的時候,改變level遞減的差值繼續壓縮下去

在開始接收到圖片的時候給一個loading增加用戶的耐心好了,loading萬歲~

其實單純的壓縮質量遇到稍大的圖片,會導致頁面高頻計算,然後頁面基本就用不了了- -。有嘗試過用iphone的一個屏幕截圖(10M左右),壓的時候稍過一會,整個手機都在發燙,只能殺進程。

所以,若對長度沒有特殊的限制,可以做一個縮放,去加快壓縮的進度螞鉛雀,提高能壓縮的圖片大小上限。

頁面到了ios上還是不行- -,可以看到最後圖片level為0.001,最長邊為764。
問題還是循環次數還是過多,計算頻率太高。從圖中可看出,對於大圖來說,初始設定的level和圖片尺寸過於寬松,可以優化一下初始level和尺寸。

有的時候還會遇到一張圖片無論如何也壓不到500k,就是上一次和這次的壓縮後大小沒有變化,這種情況需要拋錯,不讓循環繼續。

大圖片的等待時間稍長,可以給用戶先預覽一個base64的圖片增加等待耐心,方法名為 getImgBase64 ,這里都一並給出了

解決的隱患:上面這個方案會出現我需要一個500k的照片,壓到了520k之後,再壓了一次。有時候這最後的一次會特別誇張,直接將圖片弄到了幾十k。
參考了: https://github.com/WangYuLue/image-conversion
這個庫裡面有個方法 compressAccurately ,這個方法可以比較精準地壓縮。偷偷翻了一下源碼。

其實上一個方案的痛點就在於,如何在每一個壓縮循環里處理尺寸和壓縮比例。

總結

如有紕漏,歡迎指正

④ 怎樣在客戶端 利用js 壓縮圖片 大小,然後上傳至伺服器比如2M壓縮成幾十KB

無法實現,js沒有許可權去修改本地文件的,只能是將大圖上傳到伺服器後再壓縮

⑤ 使用compressorjs圖片壓縮提示The current browser does notsupport image compression

`compressorjs` 是一個基於 JavaScript 的圖片壓縮庫,它使用瀏覽器原生的 Canvas API 來進行圖片壓縮。但是,返仔磨並不是所有的瀏覽器都支持漏斗 Canvas API 中的圖片壓縮功能,因此在某些瀏覽器上,`compressorjs` 可能會提示 "The current browser does not support image compression"。
如果你遇到了這個問題,可以考慮使用其他的圖片壓縮庫,例如 TinyPNG、Kraken、ImageOptim 等,它們提供了更廣泛的瀏覽器戚虧兼容性。此外,如果你確定你的瀏覽器支持 Canvas API,但仍然遇到了問題,你可以嘗試更新你的瀏覽器或清除瀏覽器緩存,以解決問題。

⑥ 網頁開發,怎麼動態壓縮圖片顯示縮略圖

現在有智能在線圖片壓縮的工具,你只需要輸入你期此如望壓縮後的KB大小就搞定,下面講一下他的使用方法:

1、瀏覽器輸入森戚啟「秒會壓縮大師」->圖片壓縮 ->圖片改大小。
2、輸入你期望壓縮後的KB大小,寬高可以默認也可以根據你的需要進行更改。
3、有兩種圖片壓縮模式可供選擇,智能壓縮&指仔舉定大小壓縮。
4、拖入或添加圖片,稍等片刻即可壓縮完成,並且顯示壓縮後的圖片參數。
5、建議使用電腦瀏覽器。

⑦ 有什麼在線圖片縮小的方法

在線智能壓縮圖片大小

▼ 在線一鍵壓縮圖片步驟:

一、首先點擊加號添加需要壓縮的圖片。目前已知支持對jpg、png等多種常見的圖片格式進行壓縮,如果上傳圖片並壓縮成功,則代表支持該圖片格式。
二、可以自行修改圖片需要被壓縮到的最大寬高尺寸,默認為圖片原始的寬高尺寸,且寬高比例是自動鎖定的。
三、必須設置圖片被壓縮後,期望輸出的圖片文件的最大佔用空間。(必填項)
四、選擇圖片生成的演算法。默認為混合優先演算法,絕大多數情況下使用默認演算法即可。
五、壓縮的設定值不能小於1Kb,但圖片壓縮的最終效果可以小於1Kb。

⑧ 如何利用JS或者CSS樣式來自動調整圖片大小

js版和css版自動按比例調整圖片大小方法,分別如下:

<title>javascript圖片大小處理函數</title>
<scriptlanguage=Javascript>
varproMaxHeight=150;
varproMaxWidth=110;
functionproDownImage(ImgD){
varimage=newImage();
image.src=ImgD.src;
if(image.width>0&&image.height>0){
varrate=(proMaxWidth/image.width<proMaxHeight/image.height)?proMaxWidth/image.width:proMaxHeight/image.height;
if(rate<=1){
ImgD.width=image.width*rate;
ImgD.height=image.height*rate;
}
else{
ImgD.width=image.width;
ImgD.height=image.height;
}
}
}
</script>
</head>
<body>
<imgsrc="999.jpg"border=0width="150"height="110"onload=proDownImage(this);/>
<imgsrc="room.jpg"border=0width="150"height="110"onload=proDownImage(this);/>
</body>

純css的防止圖片撐破頁面的代碼,圖片會自動按比例縮小:

<styletype="text/css">
.content-width{MARGIN:auto;WIDTH:600px;}
.content-widthimg{MAX-WIDTH:100%!important;HEIGHT:auto!important;width:expression(this.width>600?"600px":this.width)!important;}
</style>


<divclass="content-width">
<p><imgsrc="/down/js/images/12567247980.jpg"/></p>
<p><imgsrc="/down/js/images/12567247981.jpg"/></p>
</div>

⑨ js 壓縮圖片

不可能,貌似你說的這個用單純的腳本沒有能做到的

這個...我還真是不知道,因為對js不是很熟悉,我所知道的是可以用第三方組件,比如aspjpeg之類的可以實現

⑩ js對從伺服器取得的圖片進行壓縮顯示

瀏覽器前端裡面跑js沒辦法壓縮圖片的,js沒io,只能載入圖片,無法讀入真正的圖片數據

閱讀全文

與在線圖片壓縮顯示js相關的資料

熱點內容
不用網路載入的單機游戲有哪些 瀏覽:608
數據線插頭怎麼接頭 瀏覽:577
網路載入視頻失敗是怎麼回事 瀏覽:805
傳奇賬號在哪個文件夾里 瀏覽:346
百度app在哪裡安裝 瀏覽:587
如何設置路由器網路不斷網 瀏覽:471
傳到qq群里的文件怎麼刪除 瀏覽:861
索尼安卓71更新日誌 瀏覽:234
怎麼找手機里的垃圾app 瀏覽:540
2015藍橋杯代碼填空 瀏覽:698
安卓資料庫dbexecSQL 瀏覽:227
doc重命名文件格式 瀏覽:728
getscreen截圖工具下載 瀏覽:719
共識數據是什麼時候開始的 瀏覽:96
數碼管顯示電壓程序 瀏覽:479
資料庫文件有哪個 瀏覽:543
途強儲存在哪個文件夾 瀏覽:172
如何恢復被覆蓋文件 瀏覽:611
iphone5用哪個版本最好 瀏覽:327
extjsgrid禁用 瀏覽:426

友情鏈接