C语言实现24位彩色图像二值化

 更新时间:2021年10月25日 17:05:37   作者:@leozhang  
这篇文章主要为大家详细介绍了C语言实现24位彩色图像二值化,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现24位彩色图像二值化的具体代码,供大家参考,具体内容如下

// huiduhua.cpp : 定义控制台应用程序的入口点。
//
 
#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);   //将文件头读入内存
 fread(&bihead,40,1,fp1);   //将信息头读入内存
 int LineByte=(bihead.biWidth*24/8+3)/4*4; //保证每行字节数为4的整数倍
 
 pBmpBuf=new unsigned char[LineByte*bihead.biHeight]; //为数据区分配内存空间
 fread(pBmpBuf,LineByte*bihead.biHeight,1,fp1);       //将bmp数据区读入内存
 fclose(fp1); 
 
 printf("Width:%d, Height: %d,biBitCount:%d\n",bihead.biWidth,bihead.biHeight,bihead.biBitCount);
 
 
 //现将真彩图灰度化
 int LineByte1=(bihead.biWidth*8/8+3)/4*4;  //由于灰度化后每像素位数变为8,所以每行字节数发生改变,但仍要求为4的整数倍
 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;    //更改每像素位数
 bihead.biSizeImage=LineByte1*bihead.biHeight;  //更改数据区大小
 fwrite(&bihead,40,1,fp2);
 
 //因为灰度化图像有颜色表,所以创建颜色表并保存
 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);
 
 //改变数据区
 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;
  }
  //二值化方法一:阈值设为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)   //将每个像素值与127比较
 //   *pb=0;
 //  else
 //   *pb=255;
 // }
 //方法二:计算像素的平均值K,扫描图像的每个像素值如像素值大于K像素值设为255(白色),值小于等于K像素值设为0(黑色)
 int y=0;//像素和
 int k=0;//像素个数
 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;  //计算所有像素灰度值之和
   k++;      //统计像素个数
  }
 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)         //将每个像素值与平均值作比较
    *pb1=0;
   else
    *pb1=255;
  }

 fwrite(pBmpBuf1,LineByte1*bihead.biHeight,1,fp2);
 fclose(fp2);

 system("pause");
 return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言模拟实现字符串库函数的示例讲解

    C语言模拟实现字符串库函数的示例讲解

    这篇文章主要为大家详细介绍了C语言模拟实现字符串库函数的具体方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01
  • C++红黑树的底层实现机制详解

    C++红黑树的底层实现机制详解

    红黑树与AVL树一样,也是一种自平衡的二叉搜索树,它在每个结点上增加一个存储位表示结点的颜色,可以是Red或Black,通过对任何一条从根到叶子的路径上各个结点着色方式的限制,本文介绍了C++红黑树的底层实现机制,需要的朋友可以参考下
    2024-08-08
  • 一文详解C++11中decltype的使用

    一文详解C++11中decltype的使用

    这篇文章主要为大家分享了C++11中decltype关键字的使用示例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2023-07-07
  • C++六大默认成员函数的实现

    C++六大默认成员函数的实现

    C++中的六大默认成员函数包括默认构造函数、默认析构函数、默认拷贝构造函数、默认拷贝赋值运算符、移动构造函数和移动赋值运算符,本文就来介绍一下这些函数的使用,感兴趣的可以了解一下
    2025-02-02
  • C++实现LeetCode(186.翻转字符串中的单词之二)

    C++实现LeetCode(186.翻转字符串中的单词之二)

    这篇文章主要介绍了C++实现LeetCode(186.翻转字符串中的单词之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C语言编程const遇上指针分析

    C语言编程const遇上指针分析

    本篇文章是C语言编程篇,主要为大家介绍C语言编程中当Const遇上指针的分析讲解,有需要的朋友可以借鉴参考下,希望可以有所帮助
    2021-09-09
  • 基于C语言实现三子棋小游戏

    基于C语言实现三子棋小游戏

    这篇文章主要为大家详细介绍了基于C语言实现三子棋小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • c++ rtti判断基类指针指向的真实对象类型

    c++ rtti判断基类指针指向的真实对象类型

    这篇文章主要为大家介绍了c++ 判断基类指针指向的真实对象类型示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • C++数据结构模板进阶的多方面分析

    C++数据结构模板进阶的多方面分析

    今天我要给大家介绍C++中的模板更深的一些知识。有关于非类型的模板参数和模板特化的一些知识,感兴趣的朋友快来看看吧
    2022-02-02
  • C语言演示对归并排序算法的优化实现

    C语言演示对归并排序算法的优化实现

    这篇文章主要介绍了C语言演示对归并排序算法的优化实现,归并排序的最差时间复杂度为(n\log n),最优时间复杂为(n),存在可以改进的空间,需要的朋友可以参考下
    2016-05-05

最新评论