您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“將文件壓縮成PNG圖像存儲(chǔ)方法是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
這樣可以做到很高的壓縮比,到底有多高,下面會(huì)提到。這種方法用到了 canvas 控件,這也意味著只有支持 canvas 控件的瀏覽器下才有效。
現(xiàn)在你可以看到,上面的圖像類似一個(gè)噪聲圖像,但它實(shí)際上是一個(gè)由124K的 prototype 框架代碼轉(zhuǎn)化成的30K的8位PNG圖像(壓縮比還不錯(cuò)吧)。
其實(shí),要將代碼轉(zhuǎn)化為圖像的格式存儲(chǔ),可以轉(zhuǎn)化成GIF和PNG格式。PNG格式的圖像有24位和8位,用24位的RGB圖像,每個(gè)像素可以存儲(chǔ)3字節(jié)的數(shù)據(jù),如果是用8位的RGB圖像,每個(gè)像素可以存儲(chǔ)1字節(jié)的數(shù)據(jù)。
在PHOTOSHOP中做測試發(fā)現(xiàn):一個(gè)300x100的純色雜點(diǎn)8位圖像可以壓縮到5K,而同樣的純色雜點(diǎn)圖像,如果是100x100的24位圖像只能壓縮到20K。如果是同樣圖案的8位GIF圖像,壓縮效果比PNG要差一些。所以,我們選擇用8位的PNG圖像作為壓縮和解壓縮的存儲(chǔ)格式。
現(xiàn)在,我們就需要開始?jí)嚎s圖像了,下面是用PHP寫的壓縮文件地址。
<? $filename = "prototype-1.6.0.2.js"; if (file_exists($filename)) { $iFileSize = filesize($filename); $iWidth = ceil(sqrt($iFileSize / 1)); $iHeight = $iWidth; $im = imagecreatetruecolor($iWidth, $iHeight); $fs = fopen($filename, "r"); $data = fread($fs, $iFileSize); fclose($fs); $i = 0; for ($y=0;$y<$iHeight;$y++) { for ($x=0;$x<$iWidth;$x++) { $ord = ord($data[$i]); imagesetpixel($im, $x, $y, imagecolorallocate($im, $ord, $ord, $ord ) ); $i++; } } header("Content-Type: image/png"); imagepng($im); imagedestroy($im); } ?>
它讀取JS文件并創(chuàng)建一個(gè)PNG圖像,圖像中的每個(gè)像素中是一個(gè)0-255之間的值,而這個(gè)值對(duì)應(yīng)的是JS字符的ascII的值。
當(dāng)然,除了壓縮,還要有解壓縮,也就是將圖像讀取為JS文件的過程。這個(gè)函數(shù)是用JS寫的,可以從下面的位置下載這個(gè)文件。
function loadPNGData(strFilename, fncCallback) { // test for canvas and getImageData var bCanvas = false; var oCanvas = document.createElement("canvas"); if (oCanvas.getContext) { var oCtx = oCanvas.getContext("2d"); if (oCtx.getImageData) { bCanvas = true; } } if (bCanvas) { var oImg = new Image(); oImg.style.position = "absolute"; oImg.style.left = "-10000px"; document.body.appendChild(oImg); oImg.onload = function() { var iWidth = this.offsetWidth; var iHeight = this.offsetHeight; oCanvas.width = iWidth; oCanvas.height = iHeight; oCanvas.style.width = iWidth+"px"; oCanvas.style.height = iHeight+"px"; var oText = document.getElementById("output"); oCtx.drawImage(this,0,0); var oData = oCtx.getImageData(0,0,iWidth,iHeight).data; var a = []; var len = oData.length; var p = -1; for (var i=0;i<len;i+=4) { if (oData[i] > 0) a[++p] = String.fromCharCode(oData[i]); }; var strData = a.join(""); if (fncCallback) { fncCallback(strData); } document.body.removeChild(oImg); } oImg.src = strFilename; return true; } else { return false; } }
“將文件壓縮成PNG圖像存儲(chǔ)方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。