ARGB_8888、ARGB_4444、RGB_565、ALPHA_8深入分析及常见误区纠正
2016-06-22 16:27
344 查看
ARGB_8888、ARGB_4444、RGB_565、ALPHA_8深入分析及常见误区纠正
区别体现:标题中的四种类型为bitmap在内存中存在的四种色彩的存储模式,他们本质区别体现在每种模式下的bitmap内部的每个像素点,在内存中的大小和组成成分的区别。
基础知识:
A->alpha(透明度),R->red(红色),G->green(绿色),B->blue(蓝色)
深入分析(每种模式下的一个像素的具体存储大小):
ARGB_8888:A->8bit->一个字节,R->8bit->一个字节,G->8bit->一个字节,B->8bit->一个字节,即8888,一个像素总共占四个字节,8+8+8+8=32bit=8byte
ARGB_4444:A->4bit->半个字节,R->4bit->半个字节,G->4bit->半个字节,B->4bit->半个字节,即4444,一个像素总共占两个字节,4+4+4+4=16bit=2byte
RGB_565:R->5bit->半个字节,G->6bit->半个字节,B->5bit->半个字节,即565,一个像素总共占两个字节,5+6+5=16bit=2byte
ALPHA_8:A->8bit->一个字节,即8,一个像素总共占一个字节,8=8bit=1byte
计算大小方式:
一张bitmap的大小 = 有多少个像素点 * 每个像素点内存中占用的大小 = 长 * 宽 * 3中讲的各种模式下对应的像素点占用的比特位
例子:计算一张长宽为1000/1000,ARGB_8888格式的一张bitmap的大小:
1000 * 1000 * 4byte = 4000kb = 4M
常见误区:
网上很多人分享的四种格式下的像素大小中,ARGB_4444中每个像素占用了4个字节,有些是2个字节,我自己写了demo,跑了一下,发现创建宽高相同的两张图片,在ARGB_8888,ARGB_4444两种格式下,输出大小是相同的,后来仔细看了下介绍,发现在API level 13之后,ARGB_4444由于图片效果较差等原因,在以该种格式操作图片时,会被ARGB_8888,默认替代,所以实际上demo中的两种格式,都是ARGB_8888格式,在这里给大家说明一下,希望对大家能有帮助。
相关文章推荐
- C#实现位图转换成图标的方法
- C++实现位图排序实例
- C语言实现的bitmap位图代码分享
- 数据结构之位图(bitmap)详解
- 转:抗锯齿方法两种(其一:paint.setAntiAlias(ture);paint.setBitmapFilter(true))
- 位图索引 btree索引
- 位图排序算法的一个实践
- IOS处理位图
- 学习opencv——图像颜色分布直方图
- 学习opencv——sift与suft的应用
- vc 将位图多余部分变为透明
- 2.1-2.4.文件读取时间测试
- (nehe教程)不使用auxDIBImageLoad,加载bmp文件
- 双缓冲绘图
- 对图像进行FFT
- 数字图像处理,bmp位图灰度化
- 对图像进行FFT
- Android开发之网络图片查看方法BitmapFactory.decodeStream()学习01
- Bmp学习
- AS3.0视觉特效:像素风格图像切换