Matlab处理彩色图像 RGB888-RGB565

本文介绍了如何在Matlab中将24位RGB888彩色图像转换为16位RGB565格式,探讨了转换过程中线性缩放的原理,并提供了转换代码。转换涉及右移操作以适应不同颜色分量的位宽,从而减少存储需求和数据量。同时,也提及了从RGB565回转到RGB888的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

image=imread('E:\64c.bmp');
fr=image(:,:,1);
fg=image(:,:,2);

fb=image(:,:,3);

以上代码为打开bmp图片并分开RGB三种分量,所以怎么把RGB888转化成RGB56516位真彩色呢?

“著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:萧Brenda
链接:http://www.zhihu.com/question/26038646/answer/46135041
来源:知乎

我猜想楼主的意思并不是要问为什么要右移,而是为什么是右移3位吧。如果是这样的话,我来解释一下。先反过来看,当把16位转换为24位的时候,(假设是5.5.5的格式)此时通过掩码和右移操作获取到的R、G、B分量需要进行一个线性的放大过程,这个放大因子是:256/32= 8. (256,32是各分量取值的最大范围)操作上而言,放大8倍,就是左移3位。 那反过来,当把24位转换成16位的时候(5.5.5格式),自然是需要一个线性的缩小因子,也就是右移3位。

当在5.6.5的格式下,R和B操作不变,但是G的分量放大或缩小的因子变成了 256/64 = 4. 于是就变成了左移或者右移2位。”

线性缩小的过程 留下高五位

背景:在我们的计算机中图像是以RGB888格式显示图像的,24位图每个像素保存了32bit的数据,即RGB888+Alpha,Alpha就是半透明填充字节……但是对于真彩的图像而言,肉眼在16bit的时候已经难以分辨了,因此,有些时候,可以讲RGB888转换为RGB565来存储,减少了存储器的容量的同时,降低了数据量;在后端显示的时候,再次把RGB565转换为RGB888,实现数据宽度的匹配!!

 

一.RGB888->RGB565

方法只要提取相应单色高位即可(R5 G6 B5),但会导致低位的缺失,影响精度,而且无法恢复。

二.RGB565->RGB888

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值