posts - 101,  comments - 29,  trackbacks - 0

          你有沒有想過:為了壓縮js文件,把js文件轉(zhuǎn)化成PNG圖像,然后用 canvas 控件中的 getImageData() 函數(shù)將圖像再重新讀成js文件。我昨天在這里發(fā)表的JS文件快速加載的文章中提到了這一方法,有網(wǎng)友對(duì)這個(gè)做法很感興趣,于是今天詳細(xì)解讀一下。

          這樣可以做到很高的壓縮比,到底有多高,下面會(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中做測(cè)試發(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寫的壓縮文件地址。
          http://www.cleanthem.com/code/20120620/js-to-png.txt

          它讀取JS文件并創(chuàng)建一個(gè)PNG圖像,圖像中的每個(gè)像素中是一個(gè)0-255之間的值,而這個(gè)值對(duì)應(yīng)的是JS字符的ascII的值。

          當(dāng)然,除了壓縮,還要有解壓縮,也就是將圖像讀取為JS文件的過程。這個(gè)函數(shù)是用JS寫的,可以從下面的位置下載這個(gè)文件。
          http://www.cleanthem.com/code/20120620/pngdata.txt

          最后給出在線測(cè)試地址,在這個(gè)網(wǎng)頁上,您可以在列表中選擇一個(gè)PNG圖像文件,點(diǎn)擊 load file 按鈕可以在網(wǎng)頁上看到這個(gè)圖像,在圖像的下面是由這個(gè)圖像所讀出來的代碼文件。

          http://www.nihilogic.dk/labs/canvascompress/

           

          注:轉(zhuǎn)載請(qǐng)注明出處,覺得有用就推薦一下吧~

          posted on 2012-08-05 01:26 mixer-a 閱讀(2334) 評(píng)論(4)  編輯  收藏

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 札达县| 新河县| 呼玛县| 元朗区| 临汾市| 万州区| 富裕县| 修水县| 邯郸市| 永嘉县| 高安市| 习水县| 汽车| 青海省| 遂川县| 海盐县| 永济市| 托里县| 库尔勒市| 楚雄市| 新乡市| 桦甸市| 石嘴山市| 麻栗坡县| 巴南区| 七台河市| 商南县| 开封市| 阿鲁科尔沁旗| 南城县| 乌什县| 灌云县| 勐海县| 西盟| 汤阴县| 贵南县| 右玉县| 濮阳市| 措勤县| 同仁县| 新乐市|