C語言實(shí)現(xiàn)24位彩色圖像二值化
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)24位彩色圖像二值化的具體代碼,供大家參考,具體內(nèi)容如下
// huiduhua.cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)。
//
#include "stdafx.h"
#include<stdio.h>
#include<windows.h>
int _tmain(int argc, _TCHAR* argv[])
{
BITMAPFILEHEADER bfhead;
BITMAPINFOHEADER bihead;
RGBQUAD *pColorTable;
unsigned char *pBmpBuf;
FILE *fp1=fopen("鼠.bmp","rb");
if(fp1==0)
return 0;
fread(&bfhead,14,1,fp1); //將文件頭讀入內(nèi)存
fread(&bihead,40,1,fp1); //將信息頭讀入內(nèi)存
int LineByte=(bihead.biWidth*24/8+3)/4*4; //保證每行字節(jié)數(shù)為4的整數(shù)倍
pBmpBuf=new unsigned char[LineByte*bihead.biHeight]; //為數(shù)據(jù)區(qū)分配內(nèi)存空間
fread(pBmpBuf,LineByte*bihead.biHeight,1,fp1); //將bmp數(shù)據(jù)區(qū)讀入內(nèi)存
fclose(fp1);
printf("Width:%d, Height: %d,biBitCount:%d\n",bihead.biWidth,bihead.biHeight,bihead.biBitCount);
//現(xiàn)將真彩圖灰度化
int LineByte1=(bihead.biWidth*8/8+3)/4*4; //由于灰度化后每像素位數(shù)變?yōu)?,所以每行字節(jié)數(shù)發(fā)生改變,但仍要求為4的整數(shù)倍
FILE *fp2=fopen("鼠2.bmp","wb");
if(fp2==0)
return 0;
//更改文件頭,并將其保存
bfhead.bfSize=14+40+sizeof(RGBQUAD)*256+LineByte1*bihead.biHeight; //更改文件大小
bfhead.bfOffBits=14+40+sizeof(RGBQUAD)*256; //更改偏移值
fwrite(&bfhead,14,1,fp2);
//更改信息頭并將其保存
bihead.biBitCount=8; //更改每像素位數(shù)
bihead.biSizeImage=LineByte1*bihead.biHeight; //更改數(shù)據(jù)區(qū)大小
fwrite(&bihead,40,1,fp2);
//因?yàn)榛叶然瘓D像有顏色表,所以創(chuàng)建顏色表并保存
pColorTable=new RGBQUAD[256];
for(int i=0;i<256;i++)
pColorTable[i].rgbRed = pColorTable[i].rgbGreen = pColorTable[i].rgbBlue = i;//使顏色表中每種顏色的R,G,B分量相等且等于索引值
fwrite(pColorTable,sizeof(RGBQUAD),256,fp2);
//改變數(shù)據(jù)區(qū)
unsigned char *pBmpBuf1;
pBmpBuf1=new unsigned char[LineByte1*bihead.biHeight];
for(int i=0;i<bihead.biHeight;i++)
for(int j=0;j<bihead.biWidth;j++)
{
unsigned char *pb1,*pb2;
pb1=pBmpBuf+i*LineByte+j*3;
int y=*(pb1)*0.299+*(pb1+1)*0.587+*(pb1+2)*0.114;
pb2=pBmpBuf1+i*LineByte1+j;
*pb2=y;
}
//二值化方法一:閾值設(shè)為127,灰度值小于127的置零,其他的置為255;
//for(int i=0;i<bihead.biHeight;i++)
// for(int j=0;j<bihead.biWidth;j++)
// {
// unsigned char *pb;
// pb=pBmpBuf1+i*LineByte1+j;
// if(*pb<127) //將每個(gè)像素值與127比較
// *pb=0;
// else
// *pb=255;
// }
//方法二:計(jì)算像素的平均值K,掃描圖像的每個(gè)像素值如像素值大于K像素值設(shè)為255(白色),值小于等于K像素值設(shè)為0(黑色)
int y=0;//像素和
int k=0;//像素個(gè)數(shù)
for(int i=0;i<bihead.biHeight;i++)
for(int j=0;j<bihead.biWidth;j++)
{
unsigned char *pb;
pb=pBmpBuf1+i*LineByte1+j;
y=y+*pb; //計(jì)算所有像素灰度值之和
k++; //統(tǒng)計(jì)像素個(gè)數(shù)
}
y=y/k; //求像素平均值
for(int i=0;i<bihead.biHeight;i++)
for(int j=0;j<bihead.biWidth;j++)
{
unsigned char *pb1;
pb1=pBmpBuf1+i*LineByte1+j;
if(*pb1<y) //將每個(gè)像素值與平均值作比較
*pb1=0;
else
*pb1=255;
}
fwrite(pBmpBuf1,LineByte1*bihead.biHeight,1,fp2);
fclose(fp2);
system("pause");
return 0;
}


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言模擬實(shí)現(xiàn)字符串庫(kù)函數(shù)的示例講解
這篇文章主要為大家詳細(xì)介紹了C語言模擬實(shí)現(xiàn)字符串庫(kù)函數(shù)的具體方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
C++紅黑樹的底層實(shí)現(xiàn)機(jī)制詳解
紅黑樹與AVL樹一樣,也是一種自平衡的二叉搜索樹,它在每個(gè)結(jié)點(diǎn)上增加一個(gè)存儲(chǔ)位表示結(jié)點(diǎn)的顏色,可以是Red或Black,通過對(duì)任何一條從根到葉子的路徑上各個(gè)結(jié)點(diǎn)著色方式的限制,本文介紹了C++紅黑樹的底層實(shí)現(xiàn)機(jī)制,需要的朋友可以參考下2024-08-08
C++六大默認(rèn)成員函數(shù)的實(shí)現(xiàn)
C++中的六大默認(rèn)成員函數(shù)包括默認(rèn)構(gòu)造函數(shù)、默認(rèn)析構(gòu)函數(shù)、默認(rèn)拷貝構(gòu)造函數(shù)、默認(rèn)拷貝賦值運(yùn)算符、移動(dòng)構(gòu)造函數(shù)和移動(dòng)賦值運(yùn)算符,本文就來介紹一下這些函數(shù)的使用,感興趣的可以了解一下2025-02-02
C++實(shí)現(xiàn)LeetCode(186.翻轉(zhuǎn)字符串中的單詞之二)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(186.翻轉(zhuǎn)字符串中的單詞之二),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
c++ rtti判斷基類指針指向的真實(shí)對(duì)象類型
這篇文章主要為大家介紹了c++ 判斷基類指針指向的真實(shí)對(duì)象類型示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
C++數(shù)據(jù)結(jié)構(gòu)模板進(jìn)階的多方面分析
今天我要給大家介紹C++中的模板更深的一些知識(shí)。有關(guān)于非類型的模板參數(shù)和模板特化的一些知識(shí),感興趣的朋友快來看看吧2022-02-02
C語言演示對(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

