使用漸進式 JPEG 來提高用戶體驗

今天才認識到原來JPEG文件有兩種保存方式他們分別是Baseline JPEG(標準型)和Progressive JPEG(漸進式)。兩種格式有相同尺寸以及圖像數據,他們的擴展名也是相同的,惟一的區別是兩者顯示的方式不一樣。php

Baseline JPEGpython

這種類型的JPEG文件存儲方式是按從上到下的掃描方式,把每一行順序的保存在JPEG文件中。打開這個文件顯示它的內容時,數據將按照存儲時的順 序從上到下一行一行的被顯示出來,直到全部的數據都被讀完,就完成了整張圖片的顯示。若是文件較大或者網絡下載速度較慢,那麼就會看到圖片被一行行加載的 效果,這種格式的JPEG沒有什麼優勢,所以,通常都推薦使用Progressive JPEG。linux

baseline

Progressive JPEGweb

和Baseline一遍掃描不一樣,Progressive JPEG文件包含屢次掃描,這些掃描順尋的存儲在JPEG文件中。打開文件過程當中,會先顯示整個圖片的模糊輪廓,隨着掃描次數的增長,圖片變得愈來愈清 晰。這種格式的主要優勢是在網絡較慢的狀況下,能夠看到圖片的輪廓知道正在加載的圖片大概是什麼。在一些網站打開較大圖片時,你就會注意到這種技術。網絡

progressive

漸進式圖片帶來的好處是可讓用戶在沒有下載完圖片就能夠看到最終圖像的大體輪廓,必定程度上能夠提高用戶體驗。(瀑布留的網站建議仍是使用標準型的)ide

baseline_vs_progressive

 

 

另外漸進式的圖片的大小並不會和基本的圖片大小相差不少,有時候可能會比基本圖片更小。漸進式的圖片的缺點就是吃用戶的CPU和內存,不過對於如今的電腦來講這點圖片的計算並不算什麼。函數

說了這邊多下面就改講講怎麼講圖片保存爲或者轉化爲Progressive JPEG了。網站

一、PhotoShopspa

在photoshop中有「存儲爲web所用格式」,打開後選擇「連續」就是漸進式JPEG。.net

photoshop

 

二、Linux

檢測是否爲progressive jpeg : identify -verbose filename.jpg | grep Interlace(若是輸出 None 說明不是progressive jpeg;若是輸出 Plane 說明是 progressive jpeg。)

將basic jpeg轉換成progressive jpeg:> convert infile.jpg -interlace Plane outfile.jpg

三、PHP

使用imageinterlaceimagejpeg函數咱們能夠輕鬆解決轉換問題。

 
<?php
$im = imagecreatefromjpeg('pic.jpg');
imageinterlace($im, 1);
imagejpeg($im, './php_interlaced.jpg', 100);
imagedestroy($im);
?>

四、Python

 
import PIL
from exceptions import IOError
 
img = PIL.Image.open("c:\\users\\biaodianfu\\pictures\\in.jpg")
destination = "c:\\users\\biaodianfu\\pictures\\test.jpeg"
try:
img.save(destination, "JPEG", quality=80, optimize=True, progressive=True)
except IOError:
PIL.ImageFile.MAXBLOCK = img.size[0] * img.size[1]
img.save(destination, "JPEG", quality=80, optimize=True, progressive=True)

五、jpegtran

jpegtran -copy none -progressive <inputfile> <outputfile>

六、C#

 
using (Image source = Image.FromFile(@"D:\temp\test2.jpg")) {
ImageCodecInfo codec = ImageCodecInfo.GetImageEncoders().First(c => c.MimeType == "image/jpeg");
EncoderParameters parameters = new EncoderParameters(3);
parameters.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 100L);
parameters.Param[1] = new EncoderParameter(System.Drawing.Imaging.Encoder.ScanMethod, (int)EncoderValue.ScanMethodInterlaced);
parameters.Param[2] = new EncoderParameter(System.Drawing.Imaging.Encoder.RenderMethod, (int)EncoderValue.RenderProgressive);
source.Save(@"D:\temp\saved.jpg", codec, parameters);
}
相關文章
相關標籤/搜索