使用ImageMagick如何對圖片進行全面壓縮

Images as a percentage of page weight for the Alexa top 10 global web sites  
圖片在網站所佔的比重越來越重。更好的優化圖片可以提高網站速度。減少寬帶流量。 

1.對用戶上傳圖片進行縮放 

    對於用戶自己上傳的圖片不能簡單的 用css限制大小,因爲這樣每次加載圖片時候還是會加載整幅大圖。佔用多餘的寬帶,並且影響頁面加載速度。應該根據實際顯示需要進行縮放。比如我想要用戶相冊裏的圖片大小不能超過500x300: 

用ImageMagick處理起來很簡單 

  1. convert -resize "500x300>" input.jpg  output.jpg #如果圖片比500x300小就保持原樣,以防小圖片被放大失真。    

2.生成不同比例縮略圖 

    一般相冊等應用,都會提供縮略圖和預覽圖,這些縮略圖同樣不能簡單的用css來限制大小,要爲每個圖片生成不同比例的預覽圖。 

3.去除多餘信息 

    Exif信息是數碼相機在拍攝過程中採集的一系列信息,這些信息放置在我們熟知的jpg文件的頭部,也就是說Exif信息是鑲嵌在JPEG圖像文件格式內的一組拍攝參數,主要包括攝影時的光圈、快門、ISO、日期時間等各種與當時攝影條件相關的訊息,相機品牌型號,色彩編碼,拍攝時錄製的聲音以及全球定位系統(GPS)等信息。簡單的說,它就好像是傻瓜相機的日期打印功能一樣,只不過Exif信息所記錄的資訊更爲詳盡和完備。不過,具有Exif信息的JPEG圖像文件要比普通的JPEG文件略大一點。還有就是像PS這種軟件處理過的圖片會有“program comments”。如果不是專業的攝影類網站,這些信息是沒有用的,可以去掉: 

  1. convert -strip input.jpg output.jpg    

4.調節壓縮比 

    大多時候,我們的網站並不需要那麼清晰的圖片,適量調節JPG圖片的壓縮比會減少圖片大小,肉眼並不會分辨出質量被壓縮後的圖片。通常75%是最佳比例。 

  1. convert -quality 75% input.jpg output.jpg    

上面幾個步驟可以一次搞定: 
  1. convert -resize "500x300" -strip -quality 75% input.jpg output.jpg    

上面說的都是針對JPG格式的處理方式,下面說一下BMP,GIF,PNG等格式的處理。 
對於BMP直接轉成JPG就可以了。再按照上面的方式處理。 

而GIF和PNG貌似有些特殊。GIF的一些特性(動畫效果,透明等)是JPG沒有的,可以根據實際情況選擇轉或不轉,如果轉換成jpg,取第一幀只需要這樣: 

  1. convert -format jpg input.gif input.jpg   

PNG也可以通過減少PNG圖片color數量的辦法達到壓縮的目的。但是這種辦法壓縮出來的圖像可以明顯看出來失真,而且呈鋸齒狀。 
對於真實世界的PNG圖片(通常指照片),一般先轉換成JPG,再通過上面的辦法來壓縮。 

但是要注意一點,透明或半透明的PNG圖片在轉換成JPG時透明部分會變成黑色。。。建議做用戶頭像時候不要轉成JPG。。很難看~~~ 
本人頭像就是深受毒害。。 

關於圖片擴展名 

發現大部分網站喜歡把用戶上傳的圖片(頭像,相冊等)都統一轉成特定格式(一般都是jpg)。這樣做的潛在弊端就是在用像ImageMagick這樣的軟件處理的時候會根據擴展名做隱式格式轉換。 
個人覺得在保存圖片的時候不加擴展名處理起來更靈活一些。 

注:把上面的命令行用mini_magick改寫用到rails裏很容易的。mini_magick本質就調用系統命令行嘛~~ 

links: 
本文所說的都是對用戶上傳的圖片處理,對網站自身的圖片(header,banner等)處理《Even Faster Websites》一書第十章裏面寫的很詳細了: 
http://www.graphics.com/modules.php?name=Sections&op=viewarticle&artid=756 

更多ImageMagick用法: 
http://www.imagemagick.org/script/index.php 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章