C語言實(shí)現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色的具體代碼,供大家參考,具體內(nèi)容如下
彩色圖像轉(zhuǎn)灰度圖像
彩色(24位)bmp圖像結(jié)構(gòu):
typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHeader biHeader; unsigned char *imgData; }bmp;
灰度(8位)bmp圖像結(jié)構(gòu):
typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHeader biHeader; rgbQUAD palette[256]; unsigned char *imgData; }bmp;
bmp灰度圖像比彩色圖像多了一個(gè)調(diào)色板,調(diào)色板中每個(gè)元素的類型是一個(gè)RGBQUAD結(jié)構(gòu),占四個(gè)字節(jié),其定義如下:
typedef struct{ unsigned char rgbBlue; unsigned char rgbGreen; unsigned char rgbRed; unsigned char rgbReserved; }rgbQUAD;
在實(shí)際的bmp圖像中調(diào)色板:
代碼實(shí)現(xiàn)將彩色bmp圖像轉(zhuǎn)化位灰值圖像:
#include<stdio.h> #include<stdlib.h> #include<string.h> #pragma pack(1) //全緊湊模式 typedef struct { unsigned char bfType[2]; unsigned int bfSize; unsigned short bfReserved1; unsigned short bfReserved2; unsigned int bfOffBits; }bitmapFileHeader; typedef struct { unsigned int biSize; unsigned int biWidth; unsigned int biHeight; unsigned short biPlanes; unsigned short biBitCount; unsigned int biCompression; unsigned int biSizeImage; unsigned int biXPixPerMeter; unsigned int biYPixPerMeter; unsigned int biClrUsed; unsigned int biClrImportant; }bitmapInfoHeader; typedef struct{ unsigned char rgbBlue; unsigned char rgbGreen; unsigned char rgbRed; unsigned char rgbReserved; }rgbQUAD; typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHeader biHeader; rgbQUAD palette[256]; unsigned char *imgData; }bmp; int main(){ FILE *fp; if((fp=fopen("d:\Temp\\test.bmp","rb"))==NULL){ perror("can not open file!"); return -1; } //讀入彩色bmp圖像文件頭,信息頭和圖像數(shù)據(jù) bitmapFileHeader bfHeader; fread(&bfHeader,14,1,fp); bitmapInfoHeader biHeader; fread(&biHeader,40,1,fp); int imSize=biHeader.biSizeImage; int width=biHeader.biWidth; int height=biHeader.biHeight; int bitCount=biHeader.biBitCount; int lineBytes=(width*bitCount+31)/32*4; fseek(fp,bfHeader.bfOffBits,SEEK_SET); unsigned char*imageData=(unsigned char*)malloc(imSize*sizeof(unsigned char)); fread(imageData,imSize*sizeof(unsigned char),1,fp); fclose(fp); bmp b; int i,j,k; memcpy(&(b.bfHeader),&bfHeader,sizeof(bfHeader)); memcpy(&(b.biHeader),&biHeader,sizeof(biHeader)); b.bfHeader.bfOffBits=1078; //因新增了調(diào)色板,需調(diào)整圖像數(shù)據(jù)偏移位置 b.biHeader.biBitCount=8; //改變圖像位數(shù) int lineBytes_new=(width*8+31)/32*4; //重新計(jì)算每行數(shù)據(jù)字節(jié) b.biHeader.biSizeImage=lineBytes_new*height; //改變圖像數(shù)據(jù)大小 b.bfHeader.bfSize=1078+b.biHeader.biSizeImage; //改變文件數(shù)據(jù)大小 b.imgData=(unsigned char*)malloc(sizeof(unsigned char)*b.biHeader.biSizeImage); memset(b.imgData,0,sizeof(unsigned char)*b.biHeader.biSizeImage); for(i=0;i<256;i++){ b.palette[i].rgbBlue=i; b.palette[i].rgbGreen=i; b.palette[i].rgbRed=i; } for(i=0;i<height;i++){ for(j=0;j<width;j++){ //將每一個(gè)像素都按公式y(tǒng)=B*0.299+G*0.587+R*0.114進(jìn)行轉(zhuǎn)化 b.imgData[lineBytes_new*i+j]=imageData[lineBytes*i+j*3]*0.299+imageData[lineBytes*i+j*3+1]*0.587+imageData[lineBytes*i+j*3+2]*0.114; } } char savePath[]="D:\Temp\\save_test.bmp"; FILE *f=fopen(savePath,"wb"); if(f==NULL){ perror("can not open file!"); return -2; } fwrite(&b.bfHeader,sizeof(bitmapFileHeader),1,f); fwrite(&b.biHeader,sizeof(bitmapInfoHeader),1,f); fwrite(&b.palette,1024,1,f); fwrite(b.imgData,sizeof(unsigned char)*b.biHeader.biSizeImage,1,f); fclose(f); free(imageData); free(b.imgData); return 0; }
代碼效果:
灰度圖像反色
int i,j; for(i=0;i<height;i++){ for(j=0;j<width;j++){ b.imgData[lineBytes*i+j]=255-imageData[lineBytes*i+j]; } }
代碼效果:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言中結(jié)構(gòu)體的內(nèi)存對(duì)齊規(guī)則講解
C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),本篇讓我們來了解C 的結(jié)構(gòu)體內(nèi)存對(duì)齊2022-05-05C語言演示對(duì)歸并排序算法的優(yōu)化實(shí)現(xiàn)
這篇文章主要介紹了C語言演示對(duì)歸并排序算法的優(yōu)化實(shí)現(xiàn),歸并排序的最差時(shí)間復(fù)雜度為(n\log n),最優(yōu)時(shí)間復(fù)雜為(n),存在可以改進(jìn)的空間,需要的朋友可以參考下2016-05-05深入理解C++中的new和delete并實(shí)現(xiàn)對(duì)象池
這篇文章主要介紹了C++中的new和delete并實(shí)現(xiàn)對(duì)象池,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09淺談C語言中的強(qiáng)符號(hào)、弱符號(hào)、強(qiáng)引用和弱引用
這篇文章主要介紹了C語言中的強(qiáng)符號(hào)、弱符號(hào)、強(qiáng)引用和弱引用的定義及相關(guān)內(nèi)容,非常的簡(jiǎn)單易懂,有需要的朋友可以參考下2014-10-10Matlab實(shí)現(xiàn)繪制立體玫瑰花的示例代碼
這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)繪制更立體的玫瑰花,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定的幫助,需要的可以參考一下2023-02-02