资源简介
数字图像处理课程,直方图均衡化C++代码的实现
代码片段和文件信息
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;
unsigned char *pBmpBuf;//读入图像数据的指针
int bmpWidth;//图像的宽
int bmpHeight;//图像的高
RGBQUAD *pColorTable;//颜色表指针
int biBitCount;//图像类型,每像素位数 根据BMP文件结构,
/****************************************
*******************************
* 函数名称:
* readBmp()
*
*函数参数:
* char *bmpName -文件名字及路径
*
*返回值:
* 0为失败,1为成功
*
*说明:给定一个图像文件名及其路径,读图像的位图数据、宽、高、颜色表及每像素
* 位数等数据进内存,存放在相应的全局变量中
****************************************
*******************************/
bool readBmp(char *bmpName)
{
//二进制读方式打开指定的图像文件
FILE *fp=fopen(bmpName“rb“);
if(fp==0) return 0;
//跳过位图文件头结构BITMAPFILEHEADER
fseek(fp sizeof(BITMAPFILEHEADER)0);
//定义位图信息头结构变量,读取位图信息头进内存,
//存放在变量head中
BITMAPINFOHEADER head;
fread(&head sizeof(BITMAPINFOHEADER) 1fp); //获取图像宽、高、每像素所占位数等信息
bmpWidth = head.biWidth;
bmpHeight = head.biHeight;
biBitCount = head.biBitCount; //定义变量,计算图像每行像素所占的字节数(必须是4的倍数)
int lineByte=(bmpWidth * biBitCount/8+3)/4*4; //灰度图像有颜色表,且颜色表表项为256
if(biBitCount==8){
//申请颜色表所需要的空间,读颜色表进内存
pColorTable=new RGBQUAD[256];
fread(pColorTablesizeof(RGBQUAD)256fp);
} //申请位图数据所需要的空间,读位图数据进内存
pBmpBuf=new unsigned char[lineByte * bmpHeight];
fread(pBmpBuf1lineByte * bmpHeightfp); //关闭文件
fclose(fp);
return 1;
}
/*****************************************
* 函数名称:
* saveBmp()
*
*函数参数:
* char *bmpName-文件名字及路径
* unsigned char *imgBuf-待存盘的位图数据
* int width-以像素为单位待存盘位图的宽
* int height-以像素为单位待存盘位图高
* int biBitCount-每像素所占位数
* RGBQUAD *pColorTable-颜色表指针 *返回值:
* 0为失败,1为成功
*
*说明:给定一个图像位图数据、宽、高、颜色表
指针及每像素所占的位数等信息,
* 将其写到指定文件中
******************************************
*****************************/
bool saveBmp(char *bmpName unsigned char
*imgBuf int width int height
int biBitCount RGBQUAD *pColorTable)
{
//如果位图数据指针为0,则没有数据传入,函数返回
if(!imgBuf)
return 0; //颜色表大小,以字节为单位,灰度图像颜色表 为1024字节,彩色图像颜色表大小为0
int colorTablesize=0;
if(biBitCount==8)
colorTablesize=1024; //待存储图像数据每行字节数为4的倍数
int lineByte=(width * biBitCount/8+3)/4*4; //以二进制写的方式打开文件
FILE *fp=fopen(bmpName“wb“);
if(fp==0) return 0; //申请位图文件头结构变量,填写文件头信息
BITMAPFILEHEADER fileHead;
fileHead.bfType = 0x4D42;//bmp类型 //bfSize是图像文件4个组成部分之和
fileHead.bfSize= sizeof(BITMAPFILEHEADER)
+ sizeof(BITMAPINFOHEADER)
+ colorTablesize + lineByte*height;
fileHead.bfReserved1 = 0;
fileHead.bfReserved2 = 0; //bfOffBits是图像文件前3个部分所需空间之和
fileHead.bfOffBits=54+colorTablesize; //写文件头进文件
fwrite(&fileHead sizeof(BITMAPFILEHEADER)1 fp); //申请位图信息头结构变量,填写信息头信息
BITMAPINFOHEADER head;
head.biBitCount=biBitCount;
head.biClrImportant=0;
head.biClrUsed=0;
head.biCompression=0;
head.biHeight=height;
head.biPlanes=1;
head.biSize=40;
head.biSizeImage=lineByte*height;
head.biWidth=width;
head.biXPelsPe
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 66614 2013-06-06 15:55 新建文件夹\1.bmp
文件 10229 2013-07-04 11:18 新建文件夹\main.cpp
目录 0 2013-07-04 11:17 新建文件夹\
- 上一篇:指纹识别算法源代码C语言
- 下一篇:C语言,计算一个文件的16位校验和
评论
共有 条评论