Chinaunix首页 | 论坛 | 博客
  • 博客访问: 841774
  • 博文数量: 372
  • 博客积分: 10063
  • 博客等级: 中将
  • 技术积分: 4220
  • 用 户 组: 普通用户
  • 注册时间: 2012-02-24 11:36
文章分类

全部博文(372)

文章存档

2012年(372)

分类: 虚拟化

2012-03-25 19:45:55

猛然发现三月份没写随笔,于是把上星期总结的IE6对PNG的支持情况放上来吧,也当是一个备份和分享:

1, 关于PNG图片需要知道的

Ø PNG有8,24,32位三种格式(8位,24位,32);

Ø 索引透明:某一个像素只有全透和全不透明两种效果;

Ø Alpha透明半透明效果;

Ø 8PNG:最多支持256(2的8次方)种颜色,支持索引透明和Alpha透明

Ø 24PNG:最多支持2的24次方种颜色,不支持透明信息

Ø 32PNG:在24位基础上增加8位透明信息,Alpha透明(不同程度的半透明效果)

也就是说,平常用到的透明(或半透)PNG图片都是8位的或者32位的,24位的PNG是不支持透明信息的,

在平常使用Firewoks导出PNG图片的优化面板中也可以看到:

1-->clip_image002导出8PNG,在下方可以选择不透明,索引透明,Alpha透明

2-->clip_image004 clip_image006导出24PNG,下方没有任何附加选项,右方预览图显示不透明的白色背景

3-->clip_image008 clip_image010导出32PNG,下方没有附加选项,但是右方显示透明的PNG图片

2, 关于IE6PNG支持情况:

Ø 首先我们不使用IE6中的滤镜支持,直接使用img标签的src引用PNG(经测试,展现效果和作为background背景图,以及input typeimage两种情况的展现效果相同)

测试代码:

1
2
3
4
5
Img 标签:
PNG8:


PNG8-index:


PNG8-alpha:


PNG32:


PNG8代表最原始的PNG8位图片,不带透明信息;PNG8-index代表PNG8位图片附带索引透明;PNG8-alpha代表PNG8位图片附带alpha透明;PNG32则是PNG32位图片。

由上至下,由左至右,效果截图(测试页面为灰色背景):

PNG8: clip_image004[5]PNG8-index: clip_image006[4]

PNG8-alpha: clip_image008[4]PNG32: clip_image010[4]

Ø 使用IE6滤镜效果,同时使用div背景+filter

测试代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
使用滤镜:
PNG8:


PNG8-index:


PNG8-alpha:


PNG32:


效果截图:

clip_image014 clip_image016 clip_image018

clip_image020

Ø 总结:

1, IE6下可以使用PNG8位或者PNG32位实现透明效果;

2, 无论是否使用滤镜,IE6支持PNG8位的索引透明,但是效果很烂;(不是因为IE6本身的原因,非IE6也是这样的效果,原因在于PNG8-index图片本身的问题);

3, 无论是否使用滤镜,IE6PNG8位的alpha透明支持不好, 对于半透明的部分,IE6直接视为全透明(100%透明),而在非IE6浏览器中能正确渲染出来PNG8位的alpha半透效果;

4, IE6不使用滤镜的情况下不能正确显示PNG32位图片,会显示一个灰底;在滤镜的帮助下,可以正确渲染PNG32图片,且效果和非IE6浏览器相同;

5, PNG24位图片不支持透明效果;


阅读(436) | 评论(0) | 转发(0) |
0

上一篇:缓存总结

下一篇:Mondrian中聚合表的应用

给主人留下些什么吧!~~