欢迎来到天天文库
浏览记录
ID:55278808
大小:26.50 KB
页数:8页
时间:2020-05-08
《用VC编程实现BMP图像裁切.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、5.5用VC编程实现BMP图像裁切随着计算电子技术和计算机技术的发展,数字图像处理进入高速发展时期,许多成熟的图像处理软件如雨后春笋般层出不穷。在大多数图像处理软件中都有图像裁切功能,用它能够快速提取感兴趣区域,去掉多余的图像内容。那么怎样编程实现图像裁切呢,下面以BMP图像为例介绍一下如何用VC实现图像裁切。先介绍第一种方法,将图像数据全部读入内存,然后将感兴趣区域裁切下来。在许多数字图像处理的书中都有关于BMP图像存储结构的章节,这里就不再详细介绍了。BMP文件一般分为四个部分:位图头文件、位图信息头、调色板和图像数据。图像裁切要用到位图信息头中的几个参数值:biWidth
2、(图像宽度)、biHeight(图像高度)、biBitCount(每个像素的位数)、biSizeImage(图像长度)。图像裁切首先要确定裁切区域内每个像素在整幅图像中的位置,我们以裁切区域中心点像素位置起算,要注意的是图像数据的存储是从最下面一行的左边开始的。如下图,Height是图像高,Width是图像宽,ctPoint是裁切区域中心点坐标,dwX和dwY分别是裁切区域的宽和高。以256色图像为例(每个像素占一个字节),裁切区域左下角像素(也就是裁切后图像的第一个像素)位置为(Height-ctPoint.y-dwY/2-1)×Width+ctPoint.x-dwX/2,左
3、下角像素位置确定了,裁切区域内的其他像素位置就很容易确定。确定了裁切区域内每个像素的位置后,就可以把这些像素的值赋给裁切后图像的相应像素。裁切后图像的位图信息头和调色板只要从原图像数据中拷贝就可以了,修改信息头中图像宽、高和长度值为裁切后的值。按照上面的思路笔者用VC++6.0编写了一个图像裁切函数ClipDIB(),该函数首先计算裁切区域图像数据的大小,为裁切后的图像分配内存,然后将原图像的信息头、调色板拷贝给裁切后的图像,最后将原图像中裁切区域内的像素值赋给裁切后影像。HDIBCBMP_ViewView::ClipDIB(HDIBhDib,CPointctpoint,DWO
4、RDdwX,DWORDdwY){//假如图像为空则返回if(hDib==NULL){returnNULL;}//获得图像指针LPSTRlpDIB=(LPSTR)::GlobalLock((HGLOBAL)hDib);//图像信息头指针LPBITMAPINFOHEADERlpBMIH=(LPBITMAPINFOHEADER)lpDIB;//如果裁切中心点超出图像范围if(ctpoint.x>(int)DIBWidth(lpDIB)
5、
6、ctpoint.y>(int)DIBHeight(lpDIB)){AfxMessageBox("中心点不在图像范围内");returnNULL;}D
7、WORDdwxSave;//实际影像保存的宽度DWORDdwBitsSize;//裁切后图像区域大小if((int(ctpoint.x-dwX/2)<0)&&(int(ctpoint.y-dwY/2)<0)&&(ctpoint.x+dwX/2)>DIBWidth(lpDIB)&&(ctpoint.y+dwY/2)>DIBHeight(lpDIB)){AfxMessageBox("裁切区域超出图像范围");returnNULL;}//实际影像保存的宽度为4字节的整数倍dwxSave=(dwX*lpBMIH->biBitCount+31)/32*4;//实际影像块的大小dwBits
8、Size=dwxSave*dwY;//裁切后的DIB图像大小(不包含文件头)DWORDdwClipedSize;dwClipedSize=sizeof(BITMAPINFOHEADER)+PaletteSize(lpDIB)+dwBitsSize;//为裁切后的DIB分配内存HDIBhClipedDIB;hClipedDIB=(HDIB)::GlobalAlloc(GMEM_MOVEABLE
9、GMEM_ZEROINIT,dwClipedSize);//获得图像指针LPSTRlpClipedDIB=(LPSTR)::GlobalLock((HGLOBAL)hClipedDIB);
10、//拷贝信息头和调色板memcpy(lpClipedDIB,lpDIB,sizeof(BITMAPINFOHEADER)+PaletteSize(lpDIB));//修改信息头中影像长、宽、长度LPBITMAPINFOHEADERpClipedDibIFH=(LPBITMAPINFOHEADER)lpClipedDIB;pClipedDibIFH->biWidth=dwX;pClipedDibIFH->biHeight=dwY;pClipedDibIFH->biSizeImage=dwX*d
此文档下载收益归作者所有