亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言讀取BMP圖像數據的源碼

2020-02-24 14:34:15
字體:
來源:轉載
供稿:網友

C語言有很多值得學習的地方,不知你對C語言中的讀取BMP圖像數據是否熟悉,今天呢,武林技術頻道的小編就給各位帶來C語言讀取BMP圖像數據的源碼,需要的朋友可以參考一下。

復制代碼 代碼如下:

/* File name: bmpTest.c
Author: WanChuan XianSheng
Date: Oct 01, 2011
Description: Show all Info a bmp file has. including
FileHeader Info, InfoHeader Info and Data Part.

Reference: BMP圖像數據的C語言讀取源碼
*/

#include
#include

#define BITMAPFILEHEADERLENGTH 14 // The bmp FileHeader length is 14
#define BM 19778 // The ASCII code for BM

/* Test the file is bmp file or not */
void bmpFileTest(FILE* fpbmp);
/* To get the OffSet of header to data part */
void bmpHeaderPartLength(FILE* fpbmp);
/* To get the width and height of the bmp file */
void BmpWidthHeight(FILE* fpbmp);
/* Show bmp file tagBITMAPFILEHEADER info */
void bmpFileHeader(FILE* fpbmp);
/* Show bmp file tagBITMAPINFOHEADER info */
void bmpInfoHeader(FILE* fpbmp);
/* Show the Data Part of bmp file */
void bmpDataPart(FILE* fpbmp);

unsigned int OffSet = 0; // OffSet from Header part to Data Part
long BmpWidth = 0; // The Width of the Data Part
long BmpHeight = 0; // The Height of the Data Part


int main(int argc, char* argv[])
{
/* Open bmp file */
FILE *fpbmp = fopen("lena.bmp", "r+");
if (fpbmp == NULL)
{
fprintf(stderr, "Open lena.bmp failed!!!/n");
return 1;
}

bmpFileTest(fpbmp); //Test the file is bmp file or not
bmpHeaderPartLength(fpbmp); //Get the length of Header Part
BmpWidthHeight(fpbmp); //Get the width and width of the Data Part
//bmpFileHeader(fpbmp); //Show the FileHeader Information
//bmpInfoHeader(fpbmp); //Show the InfoHeader Information
bmpDataPart(fpbmp); //Reserve the data to file

fclose(fpbmp);
return 0;
}

/* Test the file is bmp file or not */
void bmpFileTest(FILE* fpbmp)
{
unsigned short bfType = 0;
fseek(fpbmp, 0L, SEEK_SET);
fread(&bfType, sizeof(char), 2, fpbmp);
if (BM != bfType)
{
fprintf(stderr, "This file is not bmp file.!!!/n");
exit(1);
}
}

/* To get the OffSet of header to data part */
void bmpHeaderPartLength(FILE* fpbmp)
{
fseek(fpbmp, 10L, SEEK_SET);
fread(&OffSet, sizeof(char), 4, fpbmp);
//printf("The Header Part is of length %d./n", OffSet);
}

/* To get the width and height of the bmp file */
void BmpWidthHeight(FILE* fpbmp)
{
fseek(fpbmp, 18L, SEEK_SET);
fread(&BmpWidth, sizeof(char), 4, fpbmp);
fread(&BmpHeight, sizeof(char), 4, fpbmp);
//printf("The Width of the bmp file is %ld./n", BmpWidth);
//printf("The Height of the bmp file is %ld./n", BmpHeight);
}

/* Show bmp file tagBITMAPFILEHEADER info */
void bmpFileHeader(FILE* fpbmp)
{
unsigned short bfType; //UNIT bfType;
unsigned int bfSize; //DWORD bfSize;
unsigned short bfReserved1; //UINT bfReserved1;
unsigned short bfReserved2; //UINT bfReserved2;
unsigned int bfOffBits; //DWORD bfOffBits;

fseek(fpbmp, 0L, SEEK_SET);

fread(&bfType, sizeof(char), 2, fpbmp);
fread(&bfSize, sizeof(char), 4, fpbmp);
fread(&bfReserved1, sizeof(char), 2, fpbmp);
fread(&bfReserved2, sizeof(char), 2, fpbmp);
fread(&bfOffBits, sizeof(char), 4, fpbmp);

printf("************************************************/n");
printf("*************tagBITMAPFILEHEADER info***********/n");
printf("************************************************/n");
printf("bfType is %d./n", bfType);
printf("bfSize is %d./n", bfSize);
printf("bfReserved1 is %d./n", bfReserved1);
printf("bfReserved2 is %d./n", bfReserved2);
printf("bfOffBits is %d./n", bfOffBits);
}

/* Show bmp file tagBITMAPINFOHEADER info */
void bmpInfoHeader(FILE* fpbmp)
{
unsigned int biSize; // DWORD biSize;
long biWidth; // LONG biWidth;
long biHeight; // LONG biHeight;
unsigned int biPlanes; // WORD biPlanes;
unsigned int biBitCount; // WORD biBitCount;
unsigned int biCompression; // DWORD biCompression;
unsigned int biSizeImage; // DWORD biSizeImage;
long biXPelsPerMerer; // LONG biXPelsPerMerer;
long biYPelsPerMerer; // LONG biYPelsPerMerer;
unsigned int biClrUsed; // DWORD biClrUsed;
unsigned int biClrImportant; // DWORD biClrImportant;

fseek(fpbmp, 14L, SEEK_SET);

fread(&biSize, sizeof(char), 4, fpbmp);
fread(&biWidth, sizeof(char), 4, fpbmp);
fread(&biHeight, sizeof(char), 4, fpbmp);
fread(&biPlanes, sizeof(char), 4, fpbmp);
fread(&biBitCount, sizeof(char), 4, fpbmp);
fread(&biCompression, sizeof(char), 4, fpbmp);
fread(&biSizeImage, sizeof(char), 4, fpbmp);
fread(&biXPelsPerMerer, sizeof(char), 4, fpbmp);
fread(&biYPelsPerMerer, sizeof(char), 4, fpbmp);
fread(&biClrUsed, sizeof(char), 4, fpbmp);
fread(&biClrImportant, sizeof(char), 4, fpbmp);

printf("************************************************/n");
printf("*************tagBITMAPINFOHEADER info***********/n");
printf("************************************************/n");
printf("biSize is %d. /n", biSize);
printf("biWidth is %ld./n", biWidth);
printf("biHeight is %ld./n", biHeight);
printf("biPlanes is %d. /n", biPlanes);
printf("biBitCount is %d. /n", biBitCount);
printf("biCompression is %d. /n", biCompression);
printf("biSizeImage is %d. /n", biSizeImage);
printf("biXPelsPerMerer is %ld./n", biXPelsPerMerer);
printf("biYPelsPerMerer is %ld./n", biYPelsPerMerer);
printf("biClrUsed is %d. /n", biClrUsed);
printf("biClrImportant is %d. /n", biClrImportant);
}

/* Show the Data Part of bmp file */
void bmpDataPart(FILE* fpbmp)
{
int i, j;
unsigned char bmpPixel[BmpWidth][BmpHeight];
unsigned char* bmpPixelTmp = NULL;
FILE* fpDataBmp;

/* New a file to save the data matrix */
if((fpDataBmp=fopen("bmpData.dat","w+")) == NULL)
{
fprintf(stderr, "Failed to construct file bmpData.dat.!!!");
exit(1);
}

fseek(fpbmp, OffSet, SEEK_SET);
if ((bmpPixelTmp=(unsigned char*)malloc(sizeof(char)*BmpWidth*BmpHeight))==NULL)
{
fprintf(stderr, "Data allocation failed.!!!/n");
exit(1);
}
fread(bmpPixelTmp, sizeof(char), BmpWidth*BmpHeight, fpbmp);

/* Read the data to Matrix and save it in file bmpData.dat */
for(i =0; i < BmpHeight; i++)
{
fprintf(fpDataBmp, "The data in line %-3d:/n", i+1);
for(j = 0; j < BmpWidth; j++)
{
bmpPixel[i][j] = bmpPixelTmp[BmpWidth*(BmpHeight-1-i)+j];
//fwrite(&chartmp, sizeof(char), 1, fpDataBmp);
fprintf(fpDataBmp, "%-3d ", bmpPixel[i][j]);
if ((j+1)%32 == 0)
{
fprintf(fpDataBmp, "/n");
}
}
}
/* Used to test the data read is true or false
You can open the file using Matlab to compare the data */
//printf("bmpPixel[2][3] is %d./n", bmpPixel[2][3]);
//printf("bmpPixel[20][30] is %d./n", bmpPixel[20][30]);

free(bmpPixelTmp);
fclose(fpDataBmp);
}

到這里,C語言讀取BMP圖像數據的源碼就講完了。如果有什么不清楚可以留言給我。如果覺得我寫得不錯的話,請給我一個大拇指,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本韩国在线不卡| 亚洲精品午夜精品| 琪琪亚洲精品午夜在线| 国产亚洲精品综合一区91| 在线观看久久久久久| 亚洲天堂男人天堂女人天堂| 91国产精品视频在线| 国产精品视频久| 欧美中文字幕在线观看| 日韩成人激情在线| 国产精品亚洲一区二区三区| 视频一区视频二区国产精品| 国产欧美日韩中文字幕在线| 中文字幕av一区| 精品福利免费观看| 一本色道久久综合亚洲精品小说| 亚洲欧美成人在线| 欧美一区三区三区高中清蜜桃| 久久青草精品视频免费观看| 欧美日韩精品在线观看| 成人黄色av免费在线观看| 欧美人在线视频| 5566成人精品视频免费| 欧美精品在线播放| 国产精品一区av| 国产欧洲精品视频| 国产日韩欧美另类| 国产精品青青在线观看爽香蕉| 日本午夜人人精品| 亚洲乱码av中文一区二区| 日本免费在线精品| 日本老师69xxx| 日韩中文字幕在线| 日韩精品免费视频| 亚洲аv电影天堂网| 欧美日韩精品在线播放| 亚洲91精品在线| 国产精品吊钟奶在线| 久久黄色av网站| 欧美高清性猛交| 欧美激情在线有限公司| 永久免费看mv网站入口亚洲| 欧美电影电视剧在线观看| 亚洲一品av免费观看| www.久久久久久.com| 亚洲网站在线播放| 日韩精品欧美国产精品忘忧草| 韩国日本不卡在线| 91久久久久久久久久久| 韩剧1988在线观看免费完整版| 久热精品视频在线观看一区| 精品av在线播放| 欧美日韩亚洲成人| 狠狠躁夜夜躁人人爽超碰91| 精品国产一区二区三区四区在线观看| 亚洲欧美中文在线视频| 日韩视频免费大全中文字幕| 久久男人资源视频| 国产欧美精品xxxx另类| 欧美日韩国产一区中文午夜| 国产精品极品尤物在线观看| 欧美另类xxx| 在线播放日韩欧美| 欧美激情亚洲自拍| 日韩网站免费观看高清| 日本aⅴ大伊香蕉精品视频| 日本在线观看天堂男亚洲| 国产91精品久久久久| 91高清视频在线免费观看| 亲爱的老师9免费观看全集电视剧| 久久久久久久久久久成人| 欧美成人第一页| 色偷偷av一区二区三区乱| 色午夜这里只有精品| 久久久久久久久久久久久久久久久久av| 国产成人a亚洲精品| 九九热这里只有在线精品视| www.日韩免费| 国产精品视频久久久久| 亚洲一区二区久久久久久| 精品欧美国产一区二区三区| 欧美成人中文字幕在线| 狠狠躁夜夜躁人人爽超碰91| 日av在线播放中文不卡| 91地址最新发布| 国产精品一区二区三区毛片淫片| 成人在线视频福利| 福利精品视频在线| 欧美国产日产韩国视频| 91精品国产高清自在线看超| 亚洲激情 国产| 欧美激情视频在线免费观看 欧美视频免费一| 国模吧一区二区三区| 7m精品福利视频导航| 国内成人精品视频| 国产mv免费观看入口亚洲| 在线电影av不卡网址| 国产精品18久久久久久首页狼| 亚洲人成在线观看| 欧美大胆a视频| 韩剧1988免费观看全集| 国产精品高潮呻吟久久av无限| 国产精品永久免费视频| 91精品国产91久久久久| 性欧美xxxx视频在线观看| 欧美极品欧美精品欧美视频| 国产精品99久久久久久白浆小说| 国产91在线视频| 日韩国产欧美精品在线| 久久久av亚洲男天堂| 操91在线视频| 日韩一区二区欧美| 萌白酱国产一区二区| 精品毛片三在线观看| 在线播放精品一区二区三区| 久久久久久国产三级电影| 亚洲国产精品热久久| 久久亚洲电影天堂| 日本欧美爱爱爱| 91亚洲国产成人久久精品网站| 97超碰色婷婷| 亚洲成av人片在线观看香蕉| 欧美日韩国产丝袜美女| 亚洲成人精品av| 亚洲福利视频网| 国产日韩欧美黄色| 日韩av理论片| 人妖精品videosex性欧美| 亚洲国产毛片完整版| 亚洲xxx自由成熟| 国产精品免费视频xxxx| 日韩有码在线播放| 国产精品久久久久久影视| www日韩欧美| 久久精品久久久久久| 欧美日韩一区二区三区| 亚洲护士老师的毛茸茸最新章节| 欧美极品在线视频| 久久久亚洲影院| 欧美精品在线视频观看| 欧美视频精品一区| 国产欧美在线观看| 国产999精品久久久影片官网| 亚洲码在线观看| 国内外成人免费激情在线视频| 国产在线精品播放| 国产精品高潮呻吟久久av无限| 久久69精品久久久久久久电影好| 日韩精品在线观看视频| 午夜精品久久久久久久久久久久久| 91高潮精品免费porn| 国产日本欧美一区二区三区在线| 久久免费观看视频| 777精品视频| 91视频九色网站| 国产精品日韩电影| 久久综合色影院| 久久久精品一区二区| 精品中文字幕乱| 国产69精品久久久久9999| 欧美国产日韩视频| 亚洲视频在线播放| 伦理中文字幕亚洲| 久久精品亚洲精品|