游刃于用户体验和技术实现之间,创造用户利益和商业利益之巅。
在网站优化中,如果图片优化得好,不但可以提高页面的加载速度,提升网站的用户体验,而且还可以通过图片优化来节省网站的带宽。那么作为页面重构师应该采用什么方法来优化图片,既能保证UI的还原度,又使图片最精简呢?下面我就个人经验,来简单介绍一下图片优化的方法,首先我们了解一些图片方面的知识:
十字绣十字绣放大
下表为矢量图和位图的对比:
右上角的白色格子刚好没有在8*8像素的网格单元中,所以保存时会跟周围的8*8的网格单元颜色融合,下图的效果:
这就是平时保存JPG图片时图像会模糊的原因,下面是几张彩色图的局部对比效果:
为什么无损压缩的图也会有失真的?因为他的压缩原理是通过索引图像上相同区域的颜色进行压缩和还原,也就是说只有在图像的颜色数量小于我们可以保存的颜色数量时,才能真实的记录和还原图像,否则就会丢失一些图像信息。例如,PNG-8和GIF格式:
而PNG24为真彩色所以颜色表为空,不会失真。
在我们进行图像优化技术前,需要学习有关的图片格式的一些技术细节。每个图形格式都有自己的优势和弱点,知道他们会使你得到更好的视觉质量和压缩品质。
网页图片优化是网页加速中非常重要的一步,对图片进行压缩,不仅能够节约带宽,并且加快网页的速度。我们常用的图片编辑软件都可以在压缩图片。
切图时,有时选择PNG-8可以获得更高的压缩比。注意,是PNG-8,不是PNG-24。不过有些情况下还是GIF或JPG会小一些,需要根据实际情况调试以选择最佳方案。
拿微博左侧导航的小icon为例,压缩后的图像大小对比如下图:
PS色调分离的操作步骤如下:
对比大小:
使用工具优化后,还能够小一些:
图片优化在微博首页上的应用:
1.图型类、照片类
对于图像格式的选择,我们还需要考虑图片的使用场景或功能,概括为两类:图型类、照片类
图型类:图形符号,具有高度浓缩并快捷传达信息、便于记忆的特性,颜色数量较少。
图型类一般可以使用PNG格式或者GIF格式。优化时可采用PNG格式为PNG8或者PNG24,品质为32,如果色彩有损失可采用品质64或者128。
例如:首页左导的图标、feed区图标、勋章图、表情动画都属于图形。
照片类:照片通常含有百万数量级的颜色,包括平滑的颜色过度和渐变,如果是图形较为复杂,图中有时会出现真实的照片。
照片类一般用PNG和JPG。可以根据图片色彩的丰富程度而定。
PNG的品质一般要到128。JPG的品质一般要在70-80之间,以噪点的程度确定。
2.通用类、随机类
按照首页图片出现的频率分成:通用类、随机类
通用类:每个人首页都会看到,图标、按钮、小背景。
例如,顶部托盘图标、左导图标、feed区图标、发布器图标、身份图标、操作类图标、状态类图标、按钮。尽可能的采用PNG的格式保存,文件会相对来说较小一些。
下图为微博的按钮和左侧导航icon小图的,使用GIF和PNG格式的大小对比:
下图为微博的按钮背景图分别使用GIF和PNG格式保存的大小对比:
随机类:根据自己定义和发布的内容而定。
A.表情GIF
可以使用FireWorks或者ImageReady,建议使用ImageReady。
最好是手动一张张的调整,因为这些表情图的色彩值都比较少,如果使用比较大的颜色时会存储量较大。
另外,批处理的话也是需要一个文件夹一个文件夹去处理,表情的文件夹太多了,基本上批处理还是很慢。批处理如果是使用FireWorks的话,有的动画会出现变快或者是缺边的情况。
手动处理时,根据索引色的多少来存,一般来说4-128索引色存储。
B.换肤类图片:
采用JPG格式或者PNG格式。
皮肤的主要背景图中如含有真实的照片或者文字,可采用JPG格式,为了保证更接近设计图需采用85以上的品质压缩图片。如果色彩跨度不大的背景图片,可采用PNG格式。
C.勋章类:
目前有GIF和PNG两种格式,GIF的是小图、PNG的是中图和大图。品质选128即可。
这个目录批处理比较快。因为都是在同一个文件夹里。但是手动的话会更小一点。
头像、用户发布的图这个需要在后台控制压缩品质。采用JPG格式或者PNG格式。
图片优化工具Smush.it介绍
Smush.it是YUI团队制作的一款基于YUI的在线图片优化工具。
它是基于以下四条图片优化建议制作的服务:
·移除JPG中的meta数据。
·优化JPG的压缩率。
·转化特定GIF图片到可索引的PNG格式图片。
·从可索引的图片中移除没用到颜色信息。
所以使用Smush.it压缩图片可以删除图片中多余的字节而不改变图片的视觉效果和质量。
在实际使用中发现:
·它还能把某些JPG图片转化为PNG图片。
·对于PNG24真彩色图片,能够去掉一些肉眼察觉不到的颜色信息,弥补photoshop和firework优化不了PNG24图片的不足。
·可以优化GIF动画图片。
Smush.it使用
方法一:使用Firefox的插件Yslow里的Tools工具中的AllSmush.it
拿微博首页为例:
Firebug,使用Yslow工具,运行后,选择Tools
点击按钮DownloadSmushedImages后,会让下载一个zip的压缩文件。
下图为直接填写线上URL的方式(以逗号隔开):
下图为从本地电脑上选取图片的方式:
下图为优化结果:
PunyPNG是一个免费网站优化工具,PunyPNG能够降低没有任何质量损失的图像文件的大小。PunyPNG支持PNG,JPG格式,GIF和动画GIF(最大为500KB每个)。