• 大小: 58KB
    文件类型: .zip
    金币: 1
    下载: 0 次
    发布日期: 2021-06-22
  • 语言: C/C++
  • 标签:

资源简介

数字图像处理课程,直方图均衡化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  新建文件夹\

评论

共有 条评论