[代码片段]读取BMP文件

文件名mybmp.c

//实现了读取24位BMP文件,还有一些测试信息

 

  1 //定义mybmp.c里面用到的函数和相关头文件、常量
  2 //参考了网友sailinghz在CSDN论坛的帖子:http://bbs.csdn.net/topics/220060950
  3 
  4 
  5 
  6 #include <stdio.h>
  7 #include <stdlib.h>
  8 
  9 
 10 /*定义U16为两个字节的类型*/
 11 typedef unsigned short U16;
 12 /*定义U32为四个字节的类型*/
 13 typedef unsigned long U32;
 14 
 15 /*位图文件头*/
 16 typedef struct BMP_FILE_HEADER
 17 {
 18     unsigned bType:16;             /*  文件标识符          */
 19     unsigned bSize:32;           /*  文件的大小          */
 20     unsigned bReserved1:16;        /*  保留值,必须设置为0  */       
 21     unsigned bReserved2:16;        /*  保留值,必须设置为0  */
 22     unsigned bOffset:32;          /*  文件头的最后到图像数据位开始的偏移量    */
 23 } BMPFILEHEADER;
 24 
 25 /*位图信息头*/
 26 typedef struct BMP_INFO
 27 {
 28     U32 bInfoSize;       /*  信息头的大小             */
 29     U32 bWidth;          /*  图像的宽度               */
 30     U32 bHeight;         /*  图像的高度               */
 31     U16 bPlanes;          /*  图像的位面数             */
 32     U16 bBitCount;        /*  每个像素的位数           */
 33     U32 bCompression;    /*  压缩类型                 */
 34     U32 bmpImageSize;    /*  图像的大小,以字节为单位  */
 35     U32 bXPelsPerMeter;  /*  水平分辨率               */
 36     U32 bYPelsPerMeter;  /*  垂直分辨率               */
 37     U32 bClrUsed;        /*  使用的色彩数             */
 38     U32 bClrImportant;   /*  重要的颜色数             */
 39 } BMPINF;
 40 
 41 /*彩色表*/
 42 typedef struct RGB_QUAD 
 43 {
 44     U16 rgbBlue;         /*  蓝色强度  */
 45     U16 rgbGreen;        /*  绿色强度  */
 46     U16 rgbRed;          /*  红色强度  */
 47     U16 rgbReversed;     /*  保留值    */
 48 } RGBQUAD;
 49 
 50 int myLoadImage(unsigned char *image, char *filename);
 51 
 52 
 53 //只能读取24位的位图
 54 int myLoadImage(unsigned char *image, char *filename)
 55 {
 56     FILE *fp;    //文件指针
 57     BMPFILEHEADER fileHeader;        //位图文件头
 58     BMPINF infoHeader;        //位图信息头
 59     long offset, bmpImageSize, width, height, bytesPerPixel, size, bitCount;
 60     int i = 0, j, count = 0;
 61     int lcount = 0;
 62     int cl[3] = {0};
 63     //    unsigned char **p;
 64     U16 c;
 65 
 66     char fname_bmp[128];
 67     sprintf(fname_bmp, "%s", filename);
 68     printf("FileName:%s\n",fname_bmp);
 69 
 70     if((fp = fopen(fname_bmp, "rb")) == NULL)
 71     {
 72         printf("Cann't open the file!\n");
 73         return -1;        //读取失败,直接返回
 74     }
 75 
 76     fseek(fp, 54L, 0);    //指定偏移量
 77     fread(&fileHeader, sizeof(fileHeader), 1, fp);        //读取文件头
 78     fread(&infoHeader, sizeof(infoHeader), 1, fp);        //读取位图信息头
 79     
 80     //system("pause");        //暂停
 81 
 82     /*
 83     printf("typedef struct BMP_FILE_HEADER\n");
 84     printf("{\n");
 85     printf("    U16 bType;     #%04x        *  文件标识符          *\n",fileHeader.bType);
 86     printf("    U32 bSize;     #%08x        *  文件的大小          *\n",fileHeader.bSize);
 87     printf("    U16 bReserved1;#%04x        *  保留值,必须设置为0  *\n",fileHeader.bReserved1);
 88     printf("    U16 bReserved2;#%04x        *  保留值,必须设置为0  *\n",fileHeader.bReserved2);
 89     printf("    U32 bOffset;   #%08x        *  文件头的最后到图像数据位开始的偏移量*\n",fileHeader.bOffset);
 90     printf("} BMPFILEHEADER;%d个字节\n",sizeof(fileHeader));
 91     */
 92 
 93     /*
 94     printf("typedef struct BMP_INFO\n");
 95     printf("{\n");
 96     printf("    U32 bInfoSize;      #%08x       /*  信息头的大小             *\n",infoHeader.bInfoSize);
 97     printf("    U32 bWidth;         #%08x          /*  图像的宽度               *\n",infoHeader.bWidth);
 98     printf("    U32 bHeight;        #%08x         /*  图像的高度               *\n",infoHeader.bHeight);
 99     printf("    U16 bPlanes;        #%04x          /*  图像的位面数             *\n",infoHeader.bPlanes);
100     printf("    U16 bBitCount;      #%04x        /*  每个像素的位数           *\n",infoHeader.bBitCount);
101     printf("    U32 bCompression;   #%08x    /*  压缩类型                 *\n",infoHeader.bClrImportant);
102     printf("    U32 bmpImageSize;   #%08x    /*  图像的大小,以字节为单位  *\n",infoHeader.bmpImageSize);
103     printf("    U32 bXPelsPerMeter; #%08x  /*  水平分辨率               *\n",infoHeader.bXPelsPerMeter);
104     printf("    U32 bYPelsPerMeter; #%08x  /*  垂直分辨率               *\n",infoHeader.bYPelsPerMeter);
105     printf("    U32 bClrUsed;       #%08x        /*  使用的色彩数             *\n",infoHeader.bClrUsed);
106     printf("    U32 bClrImportant;  #%08x   /*  重要的颜色数             *\n",infoHeader.bClrImportant);
107     printf("} BMPINF;%d个字节\n\n",sizeof(infoHeader));
108     */
109 
110     //printf("unsigned short:%d\n",8*sizeof(U16));
111     //printf("unsigned long:%d\n",8*sizeof(U32));
112 
113     printf("Size:%d个字节\n",sizeof(infoHeader) + sizeof(fileHeader));
114 
115     //计算并输出位图数据的偏移量,图像的大小,宽度和高度,每个像素点所占的字节
116     /*size = fileHeader.bSize;
117     offset = fileHeader.bOffset;
118     bmpImageSize = infoHeader.bmpImageSize;
119     width = infoHeader.bWidth;
120     height = infoHeader.bHeight;
121     bitCount = infoHeader.bBitCount;
122     bytesPerPixel = infoHeader.bBitCount / 8;*/
123 
124     //输出基本信息,文件信息 & 位图信息
125     //printf("bSize:%#x\nbOffset:%#x\n\bmpImageSize:%#x\nbWidth:%#x\nbHeight:%#x\nbBitCount:%#x\nbytesPerPixel:%#x\n", \
126             size, offset, bmpImageSize, width, height, bitCount, bytesPerPixel);
127 
128     //system("pause");        //暂停
129 
130     
131     //fread(&image, sizeof(unsigned char), (size_t)(long)width*height*3, fp);    //直接读取像素信息给image数组
132 
133 
134     
135     //输出每个像素点所占字节中的内容
136     c = fgetc(fp);
137 
138     
139     //直接输出
140     while (!feof(fp))
141     {
142         cl[count] = fgetc(fp);
143         count++;
144         if (count == 3)        //读一个像素
145         {
146             lcount++;
147             c = (unsigned char)((cl[0]*11 + cl[1]*59 +cl[2]*30+ 50)/100);        //BGR 2 GRAY
148             printf("%d",c>0?1:0);
149             image[i] = (c>0?1:0) + 48;
150             i++;
151             count = 0;
152             if (lcount == 64)
153             {
154                 printf("\n");
155                 lcount = 0;
156             }
157         }
158         
159         
160     }
161 
162     printf("\ncount = %d\n",count);
163     
164 
165     //格式输出
166     /*for (i = 0; i<64; i++)
167     {
168         for (j = 0; j<64; j++)
169         {
170             cl[0] = fgetc(fp);
171             cl[1] = fgetc(fp);
172             cl[2] = fgetc(fp);
173             c = (unsigned char)((cl[0]*11 + cl[1]*59 +cl[2]*30+ 50)/100);
174             printf("%d", c>0?1:0);
175             //image[i][j] = c;        //直接给image
176         }
177         printf("\n");
178     }*/
179 
180     printf("\n");
181 
182     //system("pause");        //暂停
183 
184     fclose(fp);
185 
186     printf("Call myLoadImage() Ok!\n");
187 
188     return 0;
189 }

 

代码片段:2014年2月7日

 

posted @ 2014-02-07 21:27  柳如风  阅读(897)  评论(0编辑  收藏  举报
https://www.vultr.com/?ref=7677570