获取摄像头的格式的不同
根据摄像头的不同,可以获取多种格式,我遇到的是两种:YUV,RGB,一般意义上是RGB(个人了解)。我没学过多媒体技术,所以这些是我自己所查所了解的。YUV和RGB的不同点在什么地方呢?主要在存储格式上。RGB的存储的话我们很好理解,一个像素点一个三个数据,R,G,B,这个应该很清楚吧。我们可以通过VFW捕获的帧数据,来说明白RGB格式。vfw捕获的帧数据,我捕获的是bmp格式的。bmp格式这里可以简单的说一下。bmp存储分为两部分:头文件数据结构,像素信息区域。头文件数据结构主要存储了bmp图像信息。比较重要的用红字标出。
A. BMP文件头(14字节)
BMP文件头数据结构含有BMP文件的类型、文件大小和位图起始位置等信息。
其结构定义如下:
typedef struct tagBITMAPFILEHEADER
{
WORD bfType; // 位图文件的类型,必须为BM(1-2字节)
DWORD bfSize; // 位图文件的大小,以字节为单位(3-6字节)
WORD bfReserved1; // 位图文件保留字,必须为0(7-8字节)
WORD bfReserved2; // 位图文件保留字,必须为0(9-10字节)
DWORD bfOffBits; // 位图数据的起始位置,以相对于位图(11-14字节)
// 文件头的偏移量表示,以字节为单位
} BITMAPFILEHEADER;
B.?位图信息头(40字节)
BMP位图信息头数据用于说明位图的尺寸等信息。?
typedef struct tagBITMAPINFOHEADER{
DWORD biSize; // 本结构所占用字节数
LONG biWidth; // 位图的宽度,以像素为单位
LONG biHeight; // 位图的高度,以像素为单位
WORD biPlanes; // 目标设备的级别,必须为1
WORD biBitCount;// 每个像素所需的位数,必须是1(双色),// 4(16色),8(256色)或24(真彩色)之一
DWORD biCompression; // 位图压缩类型,必须是 0(不压缩),// 1(BI_RLE8压缩类型)或2(BI_RLE4压缩类型)之一
DWORD biSizeImage; // 位图的大小,以字节为单位
LONG biXPelsPerMeter; // 位图水平分辨率,每米像素数
LONG biYPelsPerMeter; // 位图垂直分辨率,每米像素数
DWORD biClrUsed;// 位图实际使用的颜色表中的颜色数
DWORD biClrImportant;// 位图显示过程中重要的颜色数
} BITMAPINFOHEADER;
C. 下面就是数据区域了,数据区域就是按R,B数组存储的。
有一点需要注意的是,BMP文件的图像深度可选lbit、4bit、8bit及24bit。以24bit为例,一个像素点需要24位存储,那R,B分别需要8bit,一个字节。请记住:bmp文件图像的扫描方式是按从左到右、从下到上的顺序。这个在你对图像数据处理时会特别有用,图像切割,重叠等操作。
获取摄像头的图像格式不同
vfw获取的摄像头存在两种格式:RGB,YUV,这个在vfw通过回调函数返回的数据指针中,可以查询。
RGB格式比较清晰,位图信息头都很正常,但是YUV就很奇怪,YUV显示的biCompression= 844715353。
YUV存储格式为:YUV 4:4:4,YUV 4:2:2,YUV 4:1:1,YUV4:2:0,
这里主要说一下YUV 4:2:2结构方式,4个像素Y0 U0 Y1 V1 Y2 U2 Y3 V3,读取的方式为:[Y0 U0 V0] [Y1 U0 V0] [Y2 U1 V1] [Y2 U1 V1] [Y3 U2 V2]...。Y0,U0,V0做为一个点(类似于RGB),在我抓取的数据中LPVIDEOHDR结构类型,显示的biCompression= 844715353。
内存布局如下,每像素 16 位。所以LPVIDEOHDR结构类型显示biBitCount=16

在处理的时候,你会发现,YUV2的两个像素内存存储为[Y0 U0 Y1 V0](16*2 bit)相当于RGB的两个像素(24*2),也就是说,YUV2:RGB=2:3.这也就可以理解LPVIDEOHDR结构类型中为什么data长度为什么会是同等像素的RGB的2/3了。