从PNG格式和透明度来看PC端和手机端该用哪种Png图片
时间:2022-05-25 20:03:02 | 来源:网络营销
时间:2022-05-25 20:03:02 来源:网络营销
相信经常做图片的朋友对Png格式图片都很熟悉了,Png是图像文件存储格式,在网页设计中已经不是一个陌生的名词,在前端开发中经常使用到它。PNG格式有8位、24位、32位三种形式,其中8位PNG支持两种不同的透明形式(索引透明和alpha透明),24位PNG不支持透明,32位PNG在24位基础上增加了8位透明通道,因此可展现256级透明程度。
虽然有很多人每天都在用Png格式图片,也每天都会提到Png图片,但是却很少有人能完全的了解Png有多少种格式?有哪些特点?PNG的透明度分类?PC端中常用的Png格式是哪些?手机端最合适的Png格式是什么呢?如果你也是其中的一员的话,对这些问题仍有疑问的话,那么今天我要在亿企邦上分享的这篇文章里就有你需要的答案。
一、PNG的格式和透明度 关于PNG的格式和透明度,我们使用Fireworks开查看会比较清楚,打开Fireworkd优化面板,可以清楚看到png有3种不同深度的格式:png8、png24、png32。如下图所示:
1、PNG的3种格式 其中,在优化面板选择png8,可发现png8包括不透明、索引色透明、alpha透明3种格式。如下图所示:
(1)、PNG8 8位的png最多支持256(2的8次方)种颜色,8位的png其实8支持不透明、索引透明、alpha透明。
(2)、PNG24 支持2的24次方种颜色,表现为不透明。
(3)、PNG32 支持2的32次方种颜色,32位是我们最常使用的格式,它是在png在24位的png基础上增加了8位的透明信息,支持不同程度的半透效果。
其实PNG8的3种格式不透明、索引透明、alpha透明,正好把png的所有格式都归类好了:
(1)、『png 不透明』格式
(2)、『png 索引透明』格式
(3)、『png alpha透明』格式
2、PNG的不透明格式 说到不透明,就像jpg格式一样,『png 不透明』只能为不透明,代表格式有:『png8 不透明』和『png24』,导出软件有:Photoshop、Fireworks。不推荐使用『png 不透明』格式,建议用jpg图片来代替它。
可能会有同学会问为什么png24是不透明的,我使用photoshop导出来的就是png24啊?可实际Png24为不透明图片。
打开photoshop,任意打开一个带透明的psd文件,存储为web所有格式(ctrl+shift+alt+s),如下面板所示:
不勾选透明度单选框,图片的透明背景会被默认的白色填充,如下图所示:
导出来的png图片深度为24位,图片为不透明,表现跟jpg图片相似:
如果勾选了透明度(alpha通道),导出深度为32位的透明图片。如下图所示:
从photoshop存储为web所有格式面板中这样理解,png24深度其实为24位,再勾选上8位的alhpa通道,24+8=32,即『png32』 = 『png24+alpha』,这也许是photoshop软件开发者不添加png32位格式的原因,如下图所示:为Photoshop存储为web所有格式界面的图片格式选择,并没有png32位的选项。
3、PNG的索引透明格式 说到索引颜色透明,我们可以了解下什么是索引颜色,『png 索引透明』代表格式有『png8 索引透明』,导出软件有:Photoshop、Fireworks,它的特点总结如下:
a、挑选一副图片中最有代表性的若干种颜色(通常不超过256种)。
b、只能为不透明或全透明。
c、文件体积小。
d、带有杂边锯齿。
e、支持IE6。
(1)、如何使用Photoshop导出『png8 索引透明』 使用Photoshop,存储为web所有格式,按照如下图片的红色边框配置,可导出png8索引透明。
亿企邦注:使用Photoshop导出『png8 索引透明』的效果比Fireworks导出的效果良好,这里不介绍使用Fireworks导出『png8 索引透明』
(2)、『png8 索引透明』产生杂边锯齿原因 『png8 索引透明』只有透明索引颜色,没有半透明索引颜色,下图左侧为带半透明像素的图片,在浏览器中打开不会有锯齿,而右侧图片为全透明或不透明的像素,在浏览器打开后有锯齿。
由于『png8 索引透明』没有半透明索引颜色,使用Photoshop导出时,原有的半透明转化为不透明,从而产生锯齿。
(3)、如何避免『png8 索引透明』的杂边锯齿 方法:设置杂边与背景色颜色一致可达到视觉上透明。
相信不难理解,利用杂边与背景色一致,可以来满足视觉上的透明,缺点是只能适应一种背景色,在其它背景色下同样会产生杂边。如下图所示:
那么我们该怎么设置呢?在此亿企邦推荐的方法是:打开Photoshop,在存储为web格式面板中进行如下操作,在杂边选项中选择与背景色一致的颜色。
4、PNG的Alpha透明格式 说到alpha透明,我们就要先了解下什么是alpha通道,『png alpha透明』代表格式有『png8 alpha透明』和『png32』,导出软件有Fireworks,它的特点总结如下:
a、一个8位的灰度通道,该通道用256级灰度来记录图像中的透明度信息,定义透明、不透明和半透明区域。
b、支持全透明和半透明。
c、Png8的alpha透明文件体积小
d、Png8的alpha透明在IE6下有毛边
如何使用Fireworks导出PNG的Alpha透明? Firewoks中,在优化面板,按照如下图片的红色边框配置,可导出png8 alpha透明。
亿企邦注:Firewoks支持导出『png8 alpha透明』,Photoshop不支持导出『png8 alpha透明』
二、手机端选择哪种Png? 说到手机,考虑流量的问题是必不可少的,所选png需要满足体积小和视觉效果良好,那么哪种png格式符合这2个要求呢?在此亿企邦不妨来跟大家做个实验吧!
不同Png格式测试 测试平台:ios&android webkit浏览器。
测试图片:彩种雪碧图。如下图所示:
测试内容:同一张雪碧图导出不同png格式的大小、透明度、杂边以及在retina显示屏和普通显示屏下的对比。
测试结果如下表所示:
从上图我们可见png32和png24体积太大了,十分消耗手机用户流量,不是我们选择的范围,那么可以锁定目标在『png8 alpha透明』和『png8 索引透明』中,2者对比,可以看出『png8 alpha』在手机端的支持是良好,可能有童鞋会认为,单凭一张图片也不能下结论。
而经过亿企邦使用多图片测试后使用Fireworks导出的『png8 alpha』,在手机端的支持是比较好的~不仅文件体积小,节省流量,而且半透明效果良好。
于是,移动端采用『Png8 alpha透明』,亿企邦也坚信未来使用『Png8 alpha透明』将是一种趋势!
三、PC端选择哪种Png? PC端使用哪种png,其实这个话题很早就有结论了,这里简单介绍下。
1、使用png8的方案 使用photoshop打开雪碧图,分别导出一张png32和一张『png8 索引透明』的图片,高级浏览器使用png32位图片,针对IE6使用『png8 索引透明』,并设置『png8 索引透明』杂边与背景色颜色一致可达到视觉上透明。
.bg{
background:url(global.png?v=20130530) no-repeat;
_background:url(global_png8.png?v=20130530) no-repeat;//IE6使用的背景图
}
亿企邦注:为啥使用png32而不使用『png8 alpha透明』?因为pc端的网速大多良好,建议使用表现更佳的png图片,显然png32是最合适的,当然你也可以使用『png8 alpha透明』,但是在高清显示器下的质量不如png32。
2、使用IE滤镜的方案 比较耗性能,而且存在不支持背景平铺,导致链接失效等缺点,不推荐该方案,不要为了IE而把自己搞得像IE~
.bg{filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="img. png", sizingMethod="scale");}
另外还有js和打补丁的办法,这里就暂时不做介绍,以后我会在亿企邦上为大家再做详细的介绍。
亿企邦知识扩展总结: Png的格式、颜色种类、位数、透明度、浏览器支持一览表:
亿企邦点评: PNG用来存储灰度图像时,灰度图像的深度可多到16位,存储彩色图像时,彩色图像的深度可多到48位,并且还可存储多到16位的α通道数据。
总的来说,png可以说是一种无损耗的图像格式,这也意味着你可以对png图片做任何操作也不会使得图像质量产生损耗。这也使得png可以作为jpeg编辑的过渡格式。